1.MySQL基本数据类型
数值类型
MySQL 支持所有标准 SQL 数值数据类型。
这些类型包括严格数值数据类型(INTEGER、SMALLINT、DECIMAL 和 NUMERIC),以及近似数值数据类型(FLOAT、REAL 和 DOUBLE PRECISION)。
关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词。
BIT数据类型保存位字段值,并且支持 MyISAM、MEMORY、InnoDB 和 BDB表。
作为 SQL 标准的扩展,MySQL 也支持整数类型 TINYINT、MEDIUMINT 和 BIGINT。下面的表显示了需要的每个整数类型的存储和范围。
类型 | 大小 | 范围(有符号) | 范围(无符号) | 用途 |
---|---|---|---|---|
TINYINT | 1 Bytes | (-128,127) | (0,255) | 小整数值 |
SMALLINT | 2 Bytes | (-32 768,32 767) | (0,65 535) | 大整数值 |
MEDIUMINT | 3 Bytes | (-8 388 608,8 388 607) | (0,16 777 215) | 大整数值 |
INT或INTEGER | 4 Bytes | (-2 147 483 648,2 147 483 647) | (0,4 294 967 295) | 大整数值 |
BIGINT | 8 Bytes | (-9,223,372,036,854,775,808,9 223 372 036 854 775 807) | (0,18 446 744 073 709 551 615) | 极大整数值 |
FLOAT | 4 Bytes | (-3.402 823 466 E+38,-1.175 494 351 E-38),0,(1.175 494 351 E-38,3.402 823 466 351 E+38) | 0,(1.175 494 351 E-38,3.402 823 466 E+38) | 单精度 浮点数值 |
DOUBLE | 8 Bytes | (-1.797 693 134 862 315 7 E+308,-2.225 073 858 507 201 4 E-308),0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) | 0,(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308) | 双精度 浮点数值 |
DECIMAL | 对DECIMAL(M,D) ,如果M>D,为M+2否则为D+2 | 依赖于M和D的值 | 依赖于M和D的值 | 小数值 |
日期和时间类型
表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。
每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。
TIMESTAMP类型有专有的自动更新特性,将在后面描述。
类型 | 大小 ( bytes) | 范围 | 格式 | 用途 |
---|---|---|---|---|
DATE | 3 | 1000-01-01/9999-12-31 | YYYY-MM-DD | 日期值 |
TIME | 3 | '-838:59:59'/'838:59:59' | HH:MM:SS | 时间值或持续时间 |
YEAR | 1 | 1901/2155 | YYYY | 年份值 |
DATETIME | 8 | 1000-01-01 00:00:00/9999-12-31 23:59:59 | YYYY-MM-DD HH:MM:SS | 混合日期和时间值 |
TIMESTAMP | 4 | 1970-01-01 00:00:00/2038结束时间是第 2147483647 秒,北京时间 2038-1-19 11:14:07,格林尼治时间 2038年1月19日 凌晨 03:14:07 | YYYYMMDD HHMMSS | 混合日期和时间值,时间戳 |
字符串类型
字符串类型指CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。该节描述了这些类型如何工作以及如何在查询中使用这些类型。
类型 | 大小 | 用途 |
---|---|---|
CHAR | 0-255 bytes | 定长字符串 |
VARCHAR | 0-65535 bytes | 变长字符串 |
TINYBLOB | 0-255 bytes | 不超过 255 个字符的二进制字符串 |
TINYTEXT | 0-255 bytes | 短文本字符串 |
BLOB | 0-65 535 bytes | 二进制形式的长文本数据 |
TEXT | 0-65 535 bytes | 长文本数据 |
MEDIUMBLOB | 0-16 777 215 bytes | 二进制形式的中等长度文本数据 |
MEDIUMTEXT | 0-16 777 215 bytes | 中等长度文本数据 |
LONGBLOB | 0-4 294 967 295 bytes | 二进制形式的极大文本数据 |
LONGTEXT | 0-4 294 967 295 bytes | 极大文本数据 |
注意:char(n) 和 varchar(n) 中括号中 n 代表字符的个数,并不代表字节个数,比如 CHAR(30) 就可以存储 30 个字符。
CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。
BINARY 和 VARBINARY 类似于 CHAR 和 VARCHAR,不同的是它们包含二进制字符串而不要非二进制字符串。也就是说,它们包含字节字符串而不是字符字符串。这说明它们没有字符集,并且排序和比较基于列值字节的数值值。
BLOB 是一个二进制大对象,可以容纳可变数量的数据。有 4 种 BLOB 类型:TINYBLOB、BLOB、MEDIUMBLOB 和 LONGBLOB。它们区别在于可容纳存储范围不同。
有 4 种 TEXT 类型:TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT。对应的这 4 种 BLOB 类型,可存储的最大长度不同,可根据实际情况选择。
2.MySQL基本操作
一、操作数据库
1.创建数据库
CREATE DATABASE 数据库名;
示例:create database test0820;
2.删除数据库
drop database 数据库名;
示例: drop database test0820;
3.选择数据库
use <数据库名>;
示例: use test0820;
二、操作用户
1. 创建用户
create user 名字 identified by 密码;
示例:create user myuser identified by '123456';
2.修改用户
alter user 名字 identified by 密码;
示例:alter user myuser identified by '1234';
3.删除用户
drop user 名字 identified by 密码;
示例:drop user myuser;
三、操作表
1.创建表
CREATE TABLE table_name (column_name column_type);
示例:
create table student(
num int primary key auto_increment,#主键约束 在表中只有一个 不允许重复和为空
name varchar(45) unique , #唯一约束 不允许重复但可以为空
sex enum('男','女') ,#枚举类型
age datetime default now() #默认约束
);
2.修改表
alter table table_name add column column_name column_type; //增加列 示例:alter table student add column tt int; alter table table_name modify column column_name column_type; //修改列属性 示例:alter table student modify tt varchar(45); alter table table_name drop column column_name; //删除列 示例:alter table student drop column tt;
3.删除表
DROP TABLE table_name ;
示例:drop table student;
四、授权
#临时授权 grant 权限 on 数据库对象 to 用户 #grant select/insert/update/delete on 数据库.表 to 用户; 示例:grant select on 0814test.new_table to myuser; #收回权限 revoke 权限 on 数据库对象 from 用户 //收回授权 #revoke select/insert/update/delete on 数据库.表 from 用户; 示例:revoke select on 0814test.new_table from myuser;
五、操作表中的数据
1.插入数据
INSERT INTO table_name ( field1, field2,...fieldN ) VALUES ( value1, value2,...valueN ); //插入数据 示例: insert into student values(1,'test1','男','2023-4-3'); insert into student(name,sex) values('abc','女');
2.修改数据
UPDATE table_name SET field1=new-value1, field2=new-value2 [WHERE Clause]
示例:update student set sex = '女';
3.查询数据
SELECT column_name,column_name FROM table_name [WHERE Clause] [LIMIT N][ OFFSET M]
示例:
select num,name,sex from student;
select * from student;
4.删除数据
DELETE FROM table_name [WHERE Clause]
示例:
delete from student;
六、数据库表的约束
数据库中对表的约束有五种:
1.主键约束(Primary Key constraint):主键列数据唯一,并且不允许为空。
语法:Constraint 主键约束名 Primary Key [ Clustered | Nonclustered ] ( 列名1,[ 列名2,……,列名n ] ) 主键是表中的一列或一组列,它们的值可以唯一地标识表中的每一行。
2.唯一约束(Unique constraint):该列数据唯一,允许为空,但只能出现一个空值(不重复性)。
语法:Constraint 约束名 Unique [ Clustered | Nonclustered ] ( 列名1,[ 列名2,…… 列名n] ) 唯一性约束保证了除主键外的其他一个或一组列的数据具有唯一性,以防止在列中输入重复的值。(一个表只可以有一个主键约束,如果其它列也不希望有重复就可以使用唯一性约束。)
3.检查约束(Check constraint):范围限制、格式限制
语法:Constraint 约束名 Check [ Not For Replication ] ( 逻辑表达式 ) 检查约束使指定表中一列或一组列可以接受的数据值或格式。
4.默认约束(Default constraint):
语法:Constraint 约束名 Default 约束表达式 [ For 列名 ] 为指定列定义一个默认值。在输入数据时,如果没有输入该列的值,则将该列的值设置为默认值。
5.外键约束(Foreign Key constraint):表间约束,确保数据的参照完整性
语法:Constraint 约束名 Foreign Key ( 列名1,[ 列名2,……列名n ] ) References 关联表 ( 关联列名1,[ 关联列名2,……关联列名n ] ) 将当前表中的某一列或一组列关联到另一个表的主键列,可创建两个表之间的连接。当前表中的列就成为外键。外键涉及到两个表,一个主表,一个从表 ,主表中的外键是从表中的主键
七、关键字
where 子句
以下是 SELECT 语句使用 WHERE 子句从数据表中读取数据的通用语法:
SELECT field1, field2,...fieldN FROM table_name1, table_name2... [WHERE condition1 [AND [OR]] condition2.....
-
查询语句中你可以使用一个或者多个表,表之间使用逗号, 分割,并使用WHERE语句来设定查询条件。
-
你可以在 WHERE 子句中指定任何条件。
-
你可以使用 AND 或者 OR 指定一个或多个条件。
-
WHERE 子句也可以运用于 SQL 的 DELETE 或者 UPDATE 命令。
-
WHERE 子句类似于程序语言中的 if 条件,根据 MySQL 表中的字段值来读取指定的数据。
示例:
select * from student where num = 5;
select * from student where num != 5;
select * from student where num <> 5;
select * from student where num = 5 or num = 6;
select * from student where num >=5 and num <=7;
select * from student where num between 5 and 7;
select * from student where num in(3,5,8);
select * from student where num not in(3,5,8);
like 子句
SELECT field1,field2,... from table_name1 where field1 like '%xx';
-
%:表示任意 0 个或多个字符。可匹配任意类型和长度的字符,有些情况下若是中文,请使用两个百分号(%%)表示。
-
_:表示任意单个字符。匹配单个任意字符,它常用来限制表达式的字符长度语句。
示例:
select * from student where name like 't%';
select * from student where name like '%1';
select * from student where name like '_b%';
order by 子句
order by field1 desc //降序 order by field1 asc //升序 SELECT * from xx ORDER BY xx ASC; //例子
group by 语法
使用示例:
SELECT column_name, function(column_name) FROM table_name WHERE column_name operator value GROUP BY column_name;