读SQL学习指南(第3版)笔记02_数据类型

news2025/1/23 2:02:11

 

1. 命令行工具

1.1. mysql -u root -p;

1.2. mysql> show databases;

1.3. mysql> use sakila;

1.4. mysql> SELECT now();

1.4.1. now()是MySQL的内建函数

1.4.2. 返回当前日期和时间

1.5. mysql> SELECT now() FROM dual;

1.5.1. Oracle数据库服务器要求查询语句中必须包含from子句

1.6. 只需要输入quit;或exit;就可以返回Windows或UNIX shell

2. 数据类型

2.1. 字符集

2.1.1. 拉丁字母的语言

2.1.1.1. 单字节字符集

2.1.1.2. 字符数量很少,只需要单字节就能存储每个字符

2.1.1.3. 之前版本的MySQL服务器中,默认字符集是latin1

2.1.2. 多字节字符集

2.1.2.1. 日语

2.1.2.2. 韩语

2.1.2.3. 多字节来存储每个字符

2.1.2.4. 版本8中改为了utf8mb4

2.1.3. mysql> SHOW CHARACTER SET;

2.1.4. 可以在同一个数据表内存储不同的字符集数据

2.1.5. 为数据列指定非默认字符集,只需要在类型定义后加上系统支持的字符集名称

2.1.5.1. varchar(20) character set latin1

2.1.6. 设置整个数据库的默认字符集

2.1.6.1. create database european_sales character set latin1;

2.2. 字符型数据

2.2.1. 定长字符串

2.2.1.1. char类型

2.2.1.2. 使用空格向右填充

2.2.1.3. 并始终占用同样数量的字节

2.2.1.4. 最大长度为255字节

2.2.1.5. 存储的所有字符串长度都一样时使用

2.2.2. 变长字符串

2.2.2.1. varchar类型

2.2.2.2. 不需要向右填充

2.2.2.3. 占用的字节数不固定

2.2.2.4. 最大长度为65,535字节

2.2.2.4.1. 64KB

2.2.2.5. 字符串长度各不相同时使用

2.2.3. Oracle

2.2.3.1. char类型

2.2.3.1.1. 最大长度为2000字节

2.2.3.2. varchar2类型

2.2.3.2.1. 最大长度为4,000字节

2.2.3.3. 更大的文档,可以选择clob类型

2.2.4. SQL Server

2.2.4.1. 最大长度为8,000字节的char和varchar类型的数据

2.2.4.2. varchar(max)的列中存储最大长度达2GB的数据

2.3. 文本数据

2.3.1. 需要存储的数据超出了varchar类型的最大长度(64KB)

2.3.2. 如果所加载的数据超出了文本列类型的最大长度,会被截断

2.3.3. 在加载时,文本列数据尾部的空格不会被删除

2.3.4. 在对text类型的文本列进行排序或分组时,只使用前1,024字节

2.3.4.1. 该限制量可以根据需要增加

2.3.5. tinytext

2.3.5.1. 最大255字节

2.3.6. text

2.3.6.1. 最大65535字节

2.3.7. 一般情况下没有什么必要再使用tinytext或text类型了

2.3.8. mediumtext

2.3.8.1. 最大16777215字节

2.3.9. longtext

2.3.9.1. 最大4294967295字节

2.3.10. 存储文档

2.4. 数值型数据

2.4.1. 布尔型

2.4.1.1. 0表示false

2.4.1.2. 1表示true

2.4.2. 从1字节(tinyint)到8字节(bigint)

2.4.3. 最常用的是存储整数的数值类型

2.4.3.1. 定义为unsigned,通知服务器该列中存储的所有数据均大于或等于0

2.4.4. 如果为浮点数类型的列指定了精度和有效位,记住,超出有效位和/或精度的数据会被四舍五入

2.4.4.1. 定义为unsigned,但这只表示禁止列中存储负数,并不会改变该列所存储数据的取值范围

2.4.5. 高精度的科学或制造业数据往往需要精确到小数点后8位

2.5. 时间型(temporal)数据

2.5.1. datetime、timestamp和time类型也允许包含小数点后面最多有6位数字的秒数(微秒)

2.5.1.1. 当使用这些数据类型定义列时,可以提供一个0~6的数字

2.5.2. datetime(2)表示允许时间精确到1/100秒

2.5.3. timestamp类型

2.5.3.1. 存放的信息与datetime类型一样(包括年、月、日、时、分、秒)

2.5.3.2. 当行被添加到数据表或被修改时,MySQL服务器会自动为timestamp类型的列填充当前的日期/时间

2.5.4. 只需要存放年份的列可以使用year类型

2.5.5. 存放完成某项任务所需时间的列可以使用time类型

2.5.5.1. 通过两个datetime类型的列来获取(一个存放任务开始的日期/时间,另一个存放任务结束的日期/时间),计算两者的差值就可以得到所花费的时间

2.5.5.2. 使用单个time类型的列更简单

2.5.6. Oracle Datebase接受的日期范围是公元前4712年至公元9999年

2.5.7. MySQL其时间范围是公元1000年至公元9999年

2.5.8. SQL Server则只能处理公元1753年至公元9999年

2.5.8.1. SQL Server 2008的datetime2数据类型,其日期范围从公元1年至公元9999年

2.5.9. 如果存储的是历史日期,就需要注意了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/910106.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

DFT计算入门新手坑:能带不连续

新手在学习DFT计算时,在熟悉了基本的操作和VASP输入文件后,首先就会学习到结构优化、自洽计算和能带的计算。 而笔者学习DFT计算这些年来看到太多新手学者踩到大大小小的坑,其中能带看起来不连续或者能带不连续则是几乎必踩的坑之一。 这些初…

【HCIP】04.VRRP与BFD

VRRP VRRP基本概念 VRRP路由器 运行VRRP协议的路由器,VRRP是配置在路由器的接口上的,而且也是基于接口来工作的。 VRID 一个VRRP组由多台协同工作的路由器(的接口)组成,使用相同的VRID(Virtual Router…

Spring统一功能处理

1. AOP存在的问题 获取参数复杂AOP的规则相对简单 2. 拦截器 2.1. 应用(以登录为例) 2.1.1. 自定义拦截器 新建interceptor文件夹 import org.springframework.web.servlet.HandlerInterceptor;import javax.servlet.http.HttpServletRequest; import javax.servlet.http…

Blend for Visual Studio:提升用户界面设计的专业工具

随着软件行业的迅速发展,用户界面设计变得越来越重要。一个好的用户界面能够吸引用户的注意力,提供良好的用户体验,并增加应用程序的成功率。在这个背景下,Blend for Visual Studio作为一款专业的用户界面设计工具,为开…

SpringCloud学习笔记(二)_Eureka注册中心

一、Eureka简介 Eureka是一项基于REST(代表性状态转移)的服务,主要在AWS云中用于定位服务,以实现负载均衡和中间层服务器的故障转移。我们称此服务为Eureka Server。Eureka还带有一个基于Java的客户端组件Eureka Client&#xff…

从电子表格到纸张:Excel转PDF的神奇变身之旅!

当你需要将Excel文件转换为PDF时,可以使用Python编程语言和一些流行的库来实现这个任务。在本篇博客中,我将介绍如何使用wxPython、pandas和PyMuPDF库创建一个简单易用的图形用户界面(GUI)工具来完成这项工作。 C:\pythoncode\new\excelexportpdf.py …

SCCB与IIC的异同及FPGA实现的注意事项

文章目录 前言一、信号线二、SCCB数据传输格式三、SCCB写(与IIC完全一致)四、SCCB读五、SCCB和IIC的区别 前言 IIC接口有比较广泛的应用,而SCCB(Serial Camera Control Bus,串行摄像头控制总线)是由OV&…

发现一款免费WEB在线使用的AI对话+绘画

这是一个优秀的golang开发作者 免费开放给大家使用的 简单上手 注册就能使用 多个AI角色多模型自由选择 下面是使用效果 链接地址在文末链接地址:目前免费体验

基于51单片机无线温度报警控制器 NRF24L01 多路温度报警系统设计

一、系统方案 1、本设计默认采用STC89C52单片机,如需更换单片机请联系客服。 2、接收板LCD1602液晶实时显示当前检测的2点温度值以及对应的上下限报警值。发射板由DS18B20采集温度值,通过无线模块NRF24L01传给接收板。 3、按键可以设置温度上下限值&…

硬编码基础三(变长指令的查询方式)

硬编码基础三(变长指令的查询方式) intel指令的格式可以看作如下形式: 前缀操作码modrmsib偏移立即数 其中操作码决定了是否存在moderm modrm中的rm位决定了是否存在sib 这边举个例子, 在intel白皮书中的A附录中的A.3章节有一…

HCIP---企业网三层架构实验

实验要求 实验拓扑及IP规划 实验步骤 1. Eth-Trunk通道(将多个接口逻辑的整合成一个接口,实现带宽叠加的作用) SW1和SW2起eth-trunk,并划入接口 [sw1]interface Eth-Trunk 0 [sw1-Eth-Trunk0]int g0/0/3 [sw1-GigabitEthernet0…

第5天----单词替换(C++replace()函数)

当一句话中出现错误的单词时&#xff0c;你是否想快速将它替换为你想要的&#xff0c;接下来的这篇文章&#xff0c;将带你了解什么是单词替换。 一、基本知识&#xff1a; 1. string::replace()函数 C <string>库中的replace()函数是用于替换字符串中的特定字符或子字…

微信小程序canvas type=2d生成海报保存到相册、文字换行溢出显示...、文字删除线、分享面板

做个简单的生成二维码海报分享&#xff0c;我做的时候也找简单的方法看能不能实现页面直接截图那种生成图片&#xff0c;原生小程序不支持&#xff0c;不多介绍下面有全部代码有注释、参数自行替换运行看看&#xff0c;有问题可以咨询我&#xff0c;我写的已经上线 效果如图&a…

CTFhub-sql-整数注入

判断存在 sqli 注入 1 1 and 11 1 and 12 因为 11 为真&#xff0c;12 为假&#xff0c;且 11 与 1 显示的数据一样&#xff0c;那么就存在 sqli 注入 查询该数据表的字段数量 一、 2 3 1,2成功带出数据&#xff0c;3没有数据&#xff0c;所以有两个字段 二、 1 order by …

数据结构---串(赋值,求子串,比较,定位)

目录 一.初始化 顺序表中串的存储 串的链式存储 二.赋值操作&#xff1a;将str赋值给S 链式表 顺序表 三.复制操作&#xff1a;将chars复制到str中 链式表 顺序表 四.判空操作 链式表 顺序表 五.清空操作 六.串联结 链式表 顺序表 七.求子串 链式表 顺序表…

Vue 2.x 项目升级到 Vue 3详细指南【修改清单】

文章目录 前言0.迁移过程1. 安装 Vue 32. 逐一处理迁移中的警告3. 迁移全局和内部 API4. 迁移 Vue Router 和 Vuex5. 处理其他的不兼容变更 1. Vue3特性1. Composition API2. 更好的性能3. 更好的 TypeScript 支持4. 多个根元素5. Suspense 组件6. Teleport 组件7. 全局 API 的…

python 打印人口分布金字塔图

背景 今天介绍一个不使用 matplot&#xff0c;通过DebugInfo模块打印人口金字塔图的方法。 引入模块 pip install DebugInfo打印人口金字塔图 下面的代码构建了两个人口数据&#xff08;仅做功能演示&#xff0c;不承诺任何参考价值&#xff09;&#xff0c;男性人口和女性…

基础论文学习(4)——CLIP

《Learning Transferable Visual Models From Natural Language Supervision》 CLIP的英文全称是Contrastive Language-Image Pre-training&#xff0c;即一种基于对比文本-图像对的预训练模型。CLIP是一种基于对比学习的多模态模型&#xff0c;与CV中的一些对比学习方法如moc…

软考高级架构师下篇-12层次式架构设计理论与实践

目录 1. 考情分析2. 层次式体系结构概述3. 表现层框架设计4. 中间层框架设计5. 数据访问层设计6. 数据架构规划与设计7. 物联网层次架构设计7. 前文回顾1. 考情分析 根据考试大纲,层次式架构设计理论与实践知识点会涉及单选题型(约占2~5分)和案例题(25分),本小时内容偏重于方…

lesson9: C++多线程

1.线程库 1.1 thread类的简单介绍 C11 中引入了对 线程的支持 了&#xff0c;使得 C 在 并行编程时 不需要依赖第三方库 而且在原子操作中还引入了 原子类 的概念。要使用标准库中的线程&#xff0c;必须包含 < thread > 头文件 函数名 功能 thread() 构造一个线程对象…