欢迎来到Cefler的博客😁
🕌博客主页:折纸花满衣
🏠个人专栏:MySQL
目录
- 👉🏻常见的数据类型
- bit类型
- enum
- set
- 集合查询函数find_ in_ set
- 👉🏻浮点类型
- float类型
- decimal
- 👉🏻字符串类型
- char
- varchar
- 👉🏻日期和时间类型
👉🏻常见的数据类型
MySQL 中常见的数据类型包括:
- 整数类型:
TINYINT
:范围为 -128 到 127 (有符号)或 0 到 255 (无符号)的小整数,占1字节。SMALLINT
:范围为 -32768 到 32767 (有符号)或 0 到 65535 (无符号)的较小整数,占2字节。MEDIUMINT
:范围为 -8388608 到 8388607 (有符号)或 0 到 16777215 (无符号)的中等大小整数,占3字节。INT
:范围为 -2147483648 到 2147483647 (有符号)或 0 到 4294967295 (无符号)的标准整数。BIGINT
:范围为 -9223372036854775808 到 9223372036854775807 (有符号)或 0 到 18446744073709551615 (无符号)的大整数。占8字节
尽量不使用unsigned,对于int类型可能存放不下的数据,int unsigned同样可能存放不下,与其如此,还不如设计时,将int类型提升为bigint类型。
-
浮点数类型:
FLOAT
:单精度浮点数,精确到小数点后 7 位,占用空间4个字节。DOUBLE
:双精度浮点数,精确到小数点后 15 位。DECIMAL
:用于存储精确小数的数据类型,需要指定精度和小数位数。
-
字符串类型:
CHAR
:固定长度的字符串,最多可以存储 255 个字符。VARCHAR
:可变长度的字符串,最多可以存储 65535 个字符。TEXT
:用于存储大文本数据的类型,最多可以存储 65535 个字符。BLOB
:用于存储二进制大对象的类型,最多可以存储 65535 个字节。
-
日期与时间类型:
DATE
:用于存储日期,格式为 ‘YYYY-MM-DD’。TIME
:用于存储时间,格式为 ‘HH:MM:SS’。DATETIME
:用于存储日期和时间,格式为 ‘YYYY-MM-DD HH:MM:SS’。TIMESTAMP
:用于存储时间戳,格式为 ‘YYYY-MM-DD HH:MM:SS’,自动记录数据修改时间。
-
其他常见类型:
ENUM
:用于存储枚举值,可从预定义的值列表中选择。SET
:用于存储一个或多个值的集合,可从预定义的值列表中选择。
这些是 MySQL 中常见的数据类型,根据不同的需求和情况选择合适的数据类型能够更好地优化数据库的性能和存储效率。
在mysql 中若插入不合法的数据,mysql一般都直接拦截我们,不让我们做对应的操作
怎么声明无符号? 🤔
在 MySQL 中,你可以通过在数据类型后面添加 UNSIGNED
关键字来声明一个无符号数。这样的数据类型将只能存储非负值。
例如,如果你想要声明一个无符号的整数列,你可以这样做:
column_name INT UNSIGNED
这将创建一个无符号整数列,只能存储大于等于零的整数值。
bit类型
在 MySQL 中,BIT
类型用于存储位字段值,即一系列位的集合。BIT
类型可以存储多个位,最多可存储 64 个位。这个类型通常用于存储布尔值、标志或其他只有两种可能状态的信息。
以下是声明 BIT
类型的一般语法:
column_name BIT(length)
column_name
是列的名称。length
是位字段的长度,可以是 1 到 64 之间的整数。如果未指定长度,默认为 1(如果插入>1的整数则会报错,比如2的二进制表示是10)。
例如,要声明一个 BIT
类型的列,可以这样做:
flag BIT
这将创建一个只能存储单个位的 BIT
列。
要注意的是,BIT
类型的长度是以位(bit)为单位的,而不是以字节(byte)为单位的。因此,在使用 BIT
类型时,需要根据需要合理地选择长度。
需要注意,bit字段在显示时,是按照ASCII码对应的值显示。如果我们想看到其以10进制方式显示,可以这样
enum
在 SQL 中,ENUM(枚举)类型用于定义列可以具有的可能值的有限列表。它允许你在列中指定一组可能的值,并且只允许列中的值为这些指定的值之一。
使用 ENUM 类型可以确保列只包含预定义的值,从而提供数据的一致性和可控性。这在某些情况下非常有用,例如性别、状态、类型等具有固定值集合的情况。
下面是一个使用 ENUM 类型的示例:
CREATE TABLE students (
student_id INT,
first_name VARCHAR(50),
last_name VARCHAR(50),
gender ENUM('Male', 'Female')
);
在这个示例中,gender
列被定义为 ENUM 类型,并且只允许取 'Male'
或 'Female'
两个值之一。如果尝试插入其他值,将会引发错误。
使用 ENUM 类型的优点包括数据的一致性和可读性。它可以确保列中的值只能是预先定义的选项之一,避免了数据不一致或无效值的问题。另外,ENUM 类型的值在某些情况下也可以作为代码中的枚举类型使用,增强了可读性和可维护性。
但是,ENUM 类型也有一些缺点。例如,当需要频繁更改枚举值或枚举值过多时,维护起来可能会比较繁琐。此外,不同的数据库对 ENUM 类型的实现可能略有不同,因此在跨数据库使用时需要注意兼容性问题。
总的来说,ENUM 类型提供了一种简单而有效的方式来限制列中的值,并确保数据的一致性和可控性。
set
在 SQL 中,SET 类型是一种用于表示一组可能值的数据类型,类似于 ENUM 类型。然而,与 ENUM 类型不同的是,SET 类型允许列中的值是预定义的多个选项之一,而不仅限于单个选项。
SET 类型通常用于表示多选项的属性,例如用户的兴趣爱好、文章的标签等。每个 SET 类型的列可以包含零个或多个预定义的选项,这些选项在定义列时被指定。
以下是一个使用 SET 类型的示例:
CREATE TABLE articles (
article_id INT,
title VARCHAR(100),
content TEXT,
tags SET('Technology', 'Science', 'Business', 'Sports')
);
在这个示例中,tags
列被定义为 SET 类型,并且可以包含 'Technology'
、'Science'
、'Business'
和 'Sports'
中的一个或多个选项。
与 ENUM 类型类似,SET 类型也可以确保列中的值只能是预定义的选项之一,从而提供数据的一致性和可控性。但与 ENUM 类型不同的是,SET 类型允许列中包含多个选项,而不仅限于单个选项。
但是,与 ENUM 类型类似,使用 SET 类型也可能会面临一些缺点,例如需要频繁更改选项或选项过多时的维护问题,以及不同数据库之间的兼容性问题。
总的来说,SET 类型提供了一种方便的方式来表示多选项的属性,并确保数据的一致性和可控性。
集合查询函数find_ in_ set
FIND_IN_SET
函数是 MySQL 中用于在逗号分隔的字符串中查找指定子字符串的函数。它的语法如下:
FIND_IN_SET(search_string, string_list)
其中:
search_string
是要查找的子字符串。string_list
是一个以逗号分隔的字符串列表。
FIND_IN_SET
函数返回 search_string
在 string_list
中的位置。如果找到了,则返回其在列表中的位置(从 1 开始),如果未找到,则返回 0。
以下是一个示例:
SELECT FIND_IN_SET('apple', 'apple,banana,orange,mango');
在这个示例中,FIND_IN_SET
函数将在逗号分隔的字符串 'apple,banana,orange,mango'
中查找子字符串 'apple'
,并返回它在列表中的位置,结果是 1
。
FIND_IN_SET
函数通常用于查询具有类似标签或类别的数据,其中数据存储为逗号分隔的字符串列表。例如,在一个带有标签的文章表中,可以使用该函数来查找包含特定标签的文章。
需要注意的是,虽然 FIND_IN_SET
函数在某些情况下很方便,但在大型数据集上可能会影响性能。如果可能的话,最好将数据存储为关联表而不是逗号分隔的字符串列表。
它在查表中的使用可以这样。
查询爱好登山的人:
mysql> select * from votes where find_in_set('登山', hobby);
+----------+---------------+--------+
| username | hobby | gender |
+----------+---------------+--------+
| 雷锋 | 登山,武术 | 男 |
| Juse | 登山,武术 | 女 |
| LiLei | 登山 | 男 |
+----------+---------------+--------+
👉🏻浮点类型
float类型
Float 是一种用于存储浮点数的数据类型,在大多数数据库管理系统中都有支持。浮点数是一种带有小数点的数值,可以表示大范围的数值,包括小数和指数。
在 SQL 中,FLOAT
数据类型用于存储浮点数值。它通常具有固定的精度,表示小数点前后的位数。在创建表时,可以指定 FLOAT
列的精度,即小数点后的位数。
下面是一个在创建表时使用 FLOAT
类型的示例:
CREATE TABLE products (
product_id INT,
product_name VARCHAR(50),
price FLOAT(8,2)
);
在这个示例中,price
列被定义为 FLOAT(8,2)
,意味着它可以存储最多 8 位数字,其中包括 2 位小数。
需要注意的是,由于浮点数的特性,它可能会导致精度问题。在进行精确计算时,特别是涉及货币等敏感数据时,可能会遇到舍入误差。对于这些情况,通常建议使用 DECIMAL
或 NUMERIC
类型,因为它们提供了精确的十进制数值存储。
总之,FLOAT 类型用于存储浮点数值,在创建表时可以指定精度,但需要注意可能出现的精度问题。
decimal
Decimal 是一种用于存储精确数值的数据类型,在 SQL 中被广泛使用。与 Float 不同,Decimal 适用于需要精确表示的数字,如货币金额或其他需要确切值的情况。
在 SQL 中,DECIMAL 或 NUMERIC 数据类型用于表示固定精度和小数位数的数值。与 Float 不同,Decimal 不会产生舍入误差,因为它存储的是确切的数值。
下面是一个在创建表时使用 Decimal 类型的示例:
CREATE TABLE products (
product_id INT,
product_name VARCHAR(50),
price DECIMAL(10,2)
);
在这个示例中,price
列被定义为 DECIMAL(10,2)
,意味着它可以存储最多 10 位数字,其中包括 2 位小数。
相比之下,Float 类型存储的是近似值,而 Decimal 类型存储的是精确值。Float 类型对于存储需要大范围数字的情况可能更加适用,但在需要精确表示的情况下,如金融数据或计算精度要求较高的情况下,Decimal 类型更可靠。
在使用这两种类型时,需要考虑到数据的性质和应用场景,以选择最适合的类型来存储数据。
👉🏻字符串类型
char
语法;
char(L): 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255
Char 是一种用于存储固定长度字符串的数据类型,在 SQL 中被广泛使用。Char 类型在创建表时指定一个固定长度,存储的字符串会被自动填充到指定长度,不足部分会使用空格填充。
在 SQL 中,CHAR
数据类型用于表示固定长度的字符串。当你知道数据的长度是固定的或者有一个最大长度限制时,Char 类型是很有用的,因为它可以提供更好的性能和存储效率。
下面是一个在创建表时使用 Char 类型的示例:
CREATE TABLE employees (
employee_id INT,
first_name CHAR(50),
last_name CHAR(50)
);
在这个示例中,first_name
和 last_name
列被定义为 CHAR(50)
,意味着它们可以存储最多 50 个字符的字符串。如果存储的实际字符串长度不足 50 个字符,Char 类型会自动用空格填充到指定长度。
需要注意的是,由于 Char 类型存储的是固定长度的字符串,因此它可能会占用比实际字符串长度更多的存储空间。这意味着如果存储的字符串长度不够指定的长度,可能会浪费一些存储空间。
总之,Char 类型适用于存储固定长度的字符串,在创建表时需要指定固定的长度,对于知道数据长度固定或有最大长度限制的情况下非常实用。
varchar
VARCHAR 是一种用于存储可变长度字符串的数据类型,在 SQL 中被广泛使用。与 CHAR 类型不同,VARCHAR 类型可以存储可变长度的字符串,只占用实际字符串长度所需的存储空间,因此更加灵活和节省空间。
在 SQL 中,VARCHAR
数据类型用于表示可变长度的字符串。在创建表时,你需要指定一个最大长度,但存储的实际字符串长度可以在该最大长度内变化。
下面是一个在创建表时使用 VARCHAR 类型的示例:
CREATE TABLE customers (
customer_id INT,
first_name VARCHAR(50),
last_name VARCHAR(50)
);
在这个示例中,first_name
和 last_name
列被定义为 VARCHAR(50)
,意味着它们可以存储最多 50 个字符的可变长度字符串。
VARCHAR 类型的优点包括节省存储空间和更灵活地处理字符串长度变化。由于它只存储实际字符串长度所需的空间,因此在存储长度不确定或变化的数据时更为适用。
需要注意的是,虽然 VARCHAR 类型在存储空间上更为高效,但在某些操作(如索引和比较)可能会稍慢于 CHAR 类型,因为它需要额外的长度信息来存储字符串(即有1 - 3 个字节用于记录数据大小)。因此,在选择使用 VARCHAR 还是 CHAR 类型时,需要根据具体情况权衡存储效率和操作性能。
🍓关于varchar(len),len到底是多大,这个len值,和表的编码密切相关:
varchar长度可以指定为0到65535之间的值,但是有1 - 3 个字节用于记录数据大小,所以说有效字节数是65532。
- 当我们的表的编码是
utf8
时,varchar(n)的参数n最大值是65532/3=21844[因为utf中,一个字符占用3个字节], - 如果编码是
gbk
,varchar(n)的参数n最大是65532/2=32766(因为gbk中,一个字符占用2字节)。
👉🏻日期和时间类型
常用的日期有如下三个:
- date :日期 ‘
yyyy-mm-dd
’ ,占用三字节 - datetime 时间日期格式 ‘
yyyy-mm-dd HH:ii:ss
’ 表示范围从 1000 到 9999 ,占用八字节 - timestamp :时间戳,从1970年开始的
yyyy-mm-dd HH:ii:ss
格式和 datetime 完全一致,占用四字节(当对表进行插入或修改时,时间戳会自动更新)
下面是使用案例:
mysql> create table birthday (t1 date, t2 datetime, t3 timestamp);
Query OK, 0 rows affected (0.01 sec)
//插入数据:
mysql> insert into birthday(t1,t2) values('1997-7-1','2008-8-8 12:1:1'); --插入两
种时间
Query OK, 1 row affected (0.00 sec)
mysql> select * from birthday;
+------------+---------------------+---------------------+
| t1 | t2 | t3 |
+------------+---------------------+---------------------+
| 1997-07-01 | 2008-08-08 12:01:01 | 2017-11-12 18:28:55 | --添加数据时,时间戳自动补
上当前时间
+------------+---------------------+---------------------+
//更新数据:
mysql> update birthday set t1='2000-1-1';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> select * from birthday;
+------------+---------------------+---------------------+
| t1 | t2 | t3 |
+------------+---------------------+---------------------+
| 2000-01-01 | 2008-08-08 12:01:01 | 2017-11-12 18:32:09 | -- 更新数据,时间戳会更新
成当前时间
+------------+---------------------+---------------------+
如上便是本期的所有内容了,如果喜欢并觉得有帮助的话,希望可以博个点赞+收藏+关注🌹🌹🌹❤️ 🧡 💛,学海无涯苦作舟,愿与君一起共勉成长