SQL ②-库操作 | 数据类型

这里是Themberfue


SQL语法

数据库术语

  • DATABASE:数据库,保存有组织的数据的容器(通常是一个文件或一组文件)。
  • TABLE:表,某种特定类型数据的结构化清单。
  • SCHEMA:模式,关于数据库和表的布局及特性的信息。模式定义了数据在表中如何存储,包含存储什么样的数据,数据如何分解,各部分信息如何命名等信息。数据库和表都有模式。
  • COLUMN:列,表中的一个字段。所有表都是由一个或多个列组成的。
  • ROW:行,表中的一个记录,就是一行数据。
  • PRIMARY KEY:主键,一列(或一组列),其值能够唯一标识表中每一行。

建库

  • SQL(Structured Query Language),标准 SQL 由 ANSI 标准委员会管理,从而称为 ANSI SQL。各个 DBMS 都有自己的实现,如 PL/SQL、Transact-SQL 等。
  • SQL 语句不区分大小写 ,但是数据库表名、列名和值是否区分,依赖于具体的 DBMS 以及配置。例如:SELECTselectSelect 是相同的。
  • 多条 SQL 语句必须以分号(;)分隔
  • 处理 SQL 语句时,所有空格都被忽略

SQL注释

sql 复制代码
## 注释1
-- 注释2
/* 注释3 */

我们从创建数据库开始:

sql 复制代码
CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name [create_option] ...

create_option: [DEFAULT] {
     CHARACTER SET [=] charset_name
 |   COLLATE [=] collation_name
 |   ENCRYPTION [=] {'Y' | 'N'}
}
  • 大写的表示是关键字

  • {} 里的是必须要填写的

  • [] 里的则是选择性填写

  • | 表示选一个即可

  • db_name 表示数据库名

  • CHARACTERSET 表示指定数据库采⽤的字符集编码

  • COLLATE 表示指定数据库字符集的校验规则

  • ENCRYPTION 表示数据库是否加密,MySQL8.0.16中引入的新选项

使用该 SQL 语句可以查看当前创建的所有数据库:

sql 复制代码
SHOW databases;
sql 复制代码
show charset; # 查看数据库⽀持的字符集编码
show collation; # 查看数据库⽀持的排序规则
show warnings; # 查看警告信息
show variables like '%character%'; # 查看系统默认字符集和排序规则

修改数据库:

sql 复制代码
ALTER {DATABASE | SCHEMA} [db_name] alter_option ...

 alter_option: {
       [DEFAULT] CHARACTER SET [=] charset_name
   |   [DEFAULT] COLLATE [=] collation_name
   |   [DEFAULT] ENCRYPTION [=] {'Y' | 'N'}
   |   READ ONLY [=] {DEFAULT | 0 | 1}
 }

删除数据库:

sql 复制代码
 DROP {DATABASE | SCHEMA} [IF EXISTS] db_name

数据类型

在进入对表的操作的讲解之前,我们先来说说 SQL 中的数据类型

类型 分类 数据类型 说明 存储大小
整数类型 数值 TINYINT 8位整数(-128 ~ 127 / 0 ~ 255) 1 字节
SMALLINT 16位整数(-32,768 ~ 32,767) 2 字节
MEDIUMINT 24位整数(-8,388,608 ~ 8,388,607) 3 字节
INT / INTEGER 32位整数(-2^31 ~ 2^31-1) 4 字节
BIGINT 64位整数(-2^63 ~ 2^63-1) 8 字节
浮点数类型 数值 FLOAT(M, D) 单精度浮点数(近似值存储) 4 字节
DOUBLE / REAL 双精度浮点数(近似值存储) 8 字节
DECIMAL(M, D) / NUMERIC(M, D) 定点数,精确存储(适用于财务计算) 变长
字符类型 字符串 CHAR(N) 固定长度字符串(最多 255 个字符) N 字节
VARCHAR(N) 可变长度字符串(最多 65535 个字符) 实际长度 + 1字节
TEXT / TINYTEXT 存储文本数据(最多 255 / 65535 字符) 1~4 字节指针+实际内容
BLOB 存储二进制数据(图片、文件等) 1~4 字节指针+实际内容
日期时间类型 日期/时间 DATE 仅存储日期(YYYY-MM-DD) 3 字节
TIME 仅存储时间(HH:MM:SS) 3 字节
DATETIME 日期+时间(YYYY-MM-DD HH:MM:SS) 8 字节
TIMESTAMP 1970-01-01 开始的时间戳 4 字节
布尔类型 逻辑值 BOOLEAN 仅支持 TRUE / FALSE(本质上是 TINYINT(1) 1 字节
JSON / XML 复杂数据 JSON 存储 JSON 格式数据 变长
XML 存储 XML 格式数据 变长
特殊类型 其他 ENUM 枚举类型(单选值) 1~2 字节
SET 多选集合类型 1~8 字节

CHAR与VARCHAR的区别

  • CHAR 固定长度的字符串, N 表示以字符为单位的列⻓度,取值范围 0 ~ 255 ,省略则长度为 1 ,在存储时总是用空格向右填充到指定的长度,获取列的值时会从尾部删除空格。允许定义 CHAR(0),此时列的值只能为 NULL 或 空字符串,主要的目的是为了旧系统兼容,比如类中必须有这个属性,但不使用这个属性的值,也就是说值并没有意义,但列又不能没有。
  • VARCHAR 可变长度字符串。 N 表示以字符为单位的最大列长度,取值范围 0 ~ 65,535 (在所有列中共享),有效长度取决于实际字符数和使用的字符集,并且用额外的⼀或两个字节记录实际使用的字节数,当实际字节数不超过255个字节用⼀个字节记录长度,超过255个字节时,使⽤两个字节记录⻓度,获取列的值时不会从尾部删除空格,插入数据时会删除超出长度的空格。

如何选择CHAR和VARCHAR

  • 如果数据确定长度都⼀样,就使用定长 CHAR 类型,比如:身份证,md5,学号,邮编。
  • 如果数据长度有变化,就使用变长 VARCHAR,比如:名字,地址,但要规划好长度,保证最长的字符串能存的进去。
  • 定长 CHAR 类型比较浪费磁盘空间,但是效率高,且会直接开辟好对应的存储空间。
  • 变长 VARCHAR 类型比较节省磁盘空间,但是效率低,在不超过定义长度范围的情况下⽤多少则开辟多少存储空间。

VARCHAR与TEXT的区别

  • 容量大小:VARCHAR 最大支持 65535 个字节;TEXT 最大支持 65535 个字节,在指定 TEXT 长度时,当超过 65535 时自动转换为 MEDIUMTEXT 类型,当超过 16,777,215 时自动转换为 LONGTEXT 类型。
  • 存储位置:VARCHAR 类型的列实际内容小于 768 个字节时存在当前行,⼤于 768 时存在溢出页, 当前行保存溢出页的地址; TEXT 类型的列整体保存在溢出页,当前行只保存溢出页地址。
  • 查询性能:对于频繁查询的 VARCHAR 列可以创建索引,提升查询性能;TEXT 类型的列无法直接创建普通索引,但可以使用 FULLTEXT 索引,由于索引的支持和存储位置的不同,VARCHAR 列的性能高于 TEXT 类型的列。
  • 适用场景:如果存储的数据长度较小且需要创建索引进行检索,可以选择 VARCHAR 类型,比如姓名,用户,邮箱等;如果存储的数据长度较大且不需要频繁以该列为条件进行检索可以选择 TEXT 类型,比如文章内容等。

  • 毕竟不知后事如何,且听下回分解
  • ❤️❤️❤️❤️❤️❤️❤️
相关推荐
Lris-KK3 分钟前
【Leetcode】高频SQL基础题--1341.电影评分
sql·leetcode
树谷-胡老师26 分钟前
公元前3400年至公元2024年全球国家地理边界演变数据集
数据库·arcgis·信息可视化
疯狂的Alex28 分钟前
2010-2022 同等学力申硕国考:软件工程简答题真题汇总
数据库·oracle·软件工程
Qlittleboy33 分钟前
tp5的tbmember表闭包查询 openid=‘abc‘ 并且(wx_unionid=null或者wx_unionid=‘‘)
数据库·sql·php
markfeng81 小时前
一文搞懂MySQL字符集
sql·mysql
躲在云朵里`1 小时前
Spring Scheduler定时任务实战:从零掌握任务调度
java·数据库·mybatis
小白不想白a1 小时前
【MySQL】常用SQL语句
数据库·sql·mysql
RestCloud1 小时前
从MySQL到StarRocks:全量与增量同步的最佳实践
数据库·mysql·api
Databend1 小时前
Databend 八月月报:向量检索重磅上线,性能飞跃几十倍
数据库
毕设源码纪师姐2 小时前
计算机毕设 java 高校机房综合管控系统 基于 SSM+Vue 的高校机房管理平台 Java+MySQL 的设备与预约全流程系统
java·mysql·课程设计