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

这篇具有很好参考价值的文章主要介绍了读SQL学习指南(第3版)笔记02_数据类型。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

1. 命令行工具

1.1. mysql -u root -p;

1.2. mysql> show databases;

1.3. mysql> use sakila;

Database changed文章来源地址https://www.toymoban.com/news/detail-663232.html

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. 如果存储的是历史日期,就需要注意了

到了这里,关于读SQL学习指南(第3版)笔记02_数据类型的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 读SQL学习指南(第3版)笔记01_背景知识

    2.1.3.1. 单根层次结构 2.1.5.1. Microsoft的Active Directory 2.1.5.2. 开源的Apache Directory Server 3.1.3.1. 大型共享数据银行的数据关系模型 3.2.2.1. 不用操心跟踪已分配的数字 3.2.4.1. 由两个或多于两个列组成的主键 4.4.1.1. 用于定义存储在数据库中的数据结构 4.4.1.2. 通过SQL模式语句所创

    2024年02月12日
    浏览(43)
  • 读SQL学习指南(第3版)笔记08_视图和索引

    3.1.3.1. Oracle Database用户另一种选择可以保护数据表的行列数据安全 3.1.3.2. VPD允许用户对数据表施加策略,服务器据此对用户的查询进行修改 5.10.4.1. sql 5.12.1.1. 平衡树索引(balanced-tree index) 5.12.1.1.1. B树索引(B-tree index) 5.12.1.2. MySQL、Oracle Database和SQL Server均默认采用B树

    2024年02月10日
    浏览(41)
  • 读SQL学习指南(第3版)笔记06_连接和集合

    1.1.2.1. 两个数据表的所有排列组合 1.1.3.1. 使用频率并不高 1.1.5.1. 涉及交叉连接、外连接、日期函数、分组、集合运算(union all)和聚合函数(count()) 1.1.5.2. sql 1.1.5.3. mysql 1.1.5.4. 如果生成{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}、{0, 10, 20, 30, 40, 50, 60, 70, 80, 90}和{0,100, 200, 300}这3个集合的

    2024年02月11日
    浏览(31)
  • 读SQL学习指南(第3版)笔记09_条件逻辑与事务

    1.3.1.1. Oracle的decode()函数 1.3.1.2. MySQL的if()函数 1.3.1.3. SQL Server的coalesce()函数 1.3.2.1. 在Oracle Database、SQL Server、MySQL、PostgreSQL、IBM UDB等数据库中实现 1.3.3.1. 用于select、insert、update和delete语句 1.3.4.1. sql 1.3.4.2. mysql 1.3.5.1. simple case expression 1.3.5.2. 类似于搜索型case表达式,但

    2024年02月10日
    浏览(39)
  • 读SQL学习指南(第3版)笔记12_时间函数和分析函数

    1.6.3.1. SQL Server的getutcdate() 1.6.3.2. MySQL的utc_timestamp() 1.8.2.1. 对于每个登录的用户可能有所不同 1.8.2.2. 改变当前会话的时区设置 1.8.2.3. mysql> SET time_zone = \\\'Europe/Zurich\\\'; 2.4.1.1. 年份,包括世纪 2.4.1.2. 1000--9999 2.4.2.1. 月份 2.4.2.2. 01 (1月)~12 (12月) 2.4.3.1. 日 2.4.3.2. 01~31 2.4.4.1

    2024年02月10日
    浏览(43)
  • 读SQL学习指南(第3版)笔记07_分组和子查询

    2.1.1.1. 查询返回的每个值都是由聚合函数生成的 2.1.1.2. 没有使用group by子句 2.1.1.3. 只有一个隐式分组 2.1.1.3.1. payment数据表中的所有行 2.2.1.1. 添加一个group by子句来指定聚合函数应该应用于哪个分组 2.6.2.1. 因为在评估where子句时,分组尚未生成,因而必须将分组过滤条件

    2024年02月11日
    浏览(39)
  • 读SQL学习指南(第3版)笔记11_字符串函数和数值函数

    2.5.3.1. SQL Server 2005还包括varchar(max)数据类型,并建议使用其代替text类型,text类型将在未来的某个版本中被删除 2.9.7.1. 如果使用的是MySQL,可以通过内建函数quote()来实现,该函数会将整个字符串放入引号内并对其中任意的引号/撇号进行转义 2.9.7.2. mysql 2.9.7.3. 在检索数据用

    2024年02月10日
    浏览(46)
  • Redis学习指南(2)-Redis与传统SQL数据库的差异

    在数据库领域,Redis和SQL数据库是两种不同的存储解决方案,各自具有一系列优势和劣势。本文将对Redis和SQL数据库进行对比分析,以帮助读者更好地了解它们的特点和适用场景。 1. 高性能 Redis以其出色的性能而闻名,主要因为它是一个基于内存的键值存储系统。这意味着数

    2024年01月21日
    浏览(53)
  • 机器学习终极指南:特征工程(02/2) — 第 -2 部分

    接上文:机器学习终极指南:特征工程(01/3)第一部分          处理不平衡的数据是机器学习的一个重要方面。不平衡数据是指目标变量的分布不均匀,并且与另一个类相比,一个类的代表性不足。这可能导致模型中偏向多数类,并且模型在少数类上的表现可能很差。

    2024年02月13日
    浏览(39)
  • 现代C++学习指南-类型系统

    在前一篇,我们提供了一个方向性的指南,但是学什么,怎么学却没有详细展开。本篇将在前文的基础上,着重介绍下怎样学习C++的类型系统。 在进入类型系统之前,我们应该先达成一项共识——尽可能使用C++的现代语法。众所周知,出于兼容性的考虑,C++中很多语法都是合

    2024年02月08日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包