SQL 基础使用MySQL 是一种关系型数据库,说到关系,那么就离不开表与表之间的关系,而最能体现这种关系的其实就是我们接下来需要介绍的主角 下面我们就来一起学习一下这门非常重要的语言。 查询语言分类在了解 SQL 之前我们需要知道下面这几个概念
DDL 语句创建数据库下面就开始我们的 SQL 语句学习之旅,首先你需要启动 MySQL 服务,我这里是 mac 电脑,所以我直接可以启动 然后我们使用命令行的方式连接数据库,打开 MacBook:~ mr.l$ mysql -uroot -p MacBook:~ mr.l$ mysql -uroot -p 就可以连接到数据库了 在上面命令中, 欢迎界面主要描述了这些东西
然后需要做的事情是什么?我们最终想要学习 SQL 语句,SQL 语句肯定是要查询数据,通过数据来体现出来表的关联关系,所以我们需要数据,那么数据存在哪里呢?数据存储的位置被称为 所以我们首先要做的就是创建数据库,创建数据库可以直接使用指令 CREATE DATABASE dbname; CREATE DATABASE dbname; 进行创建,比如我们创建数据库 cxuandb create database cxuandb; create database cxuandb; 注意最后的 创建完成后,会提示 「Query OK, 1 row affected」,这段语句什么意思呢?Query OK 表示的就是查询完成,为什么会显示这个?因为所有的 DDL 和 DML 操作执行完成后都会提示这个, 也可以理解为操作成功。后面跟着的 **1 row affected ** 表示的是影响的行数, 上图我们成功创建了一个 cxuandb 的数据库,此时我们还想创建一个数据库,我们再执行相同的指令,结果提示 提示我们不能再创建数据库了,数据库已经存在。这时候我就有疑问了,我怎么知道都有哪些数据库呢?别我再想创建一个数据库又告诉我已经存在,这时候可以使用 show databases; show databases; 执行完成后的结果如下 因为数据库我之前已经使用过,这里就需要解释一下,除了刚刚新创建成功的 cxuandb 外,
其他所有的数据库都是作者自己创建的,可以忽略他们。 在创建完数据库之后,可以用如下命令选择要操作的数据库 use cxuandb use cxuandb 这样就成功切换为了 cxuandb 数据库,我们可以在此数据库下进行建表、查看基本信息等操作。 比如想要看康康我们新建的数据库里面有没有其他表 show tables; show tables; 果然,我们新建的数据库下面没有任何表,但是现在,我们还不进行建表操作,我们还是先来认识一下数据库层面的命令,也就是其他 DDL 指令 删除数据库如果一个数据库我们不想要了,那么该怎么办呢?直接删掉数据库不就好了吗?删表语句是 drop database dbname; drop database dbname; 比如 cxuandb 我们不想要他了,可以通过使用 drop database cxuandb; drop database cxuandb; 进行删除,这里我们就不进行演示了,因为 cxuandb 我们后面还会使用。 但是这里注意一点,你删除数据库成功后会出现 「0 rows affected」,这个可以不用理会,因为在 MySQL 中,drop 语句操作的结果都是 「0 rows affected」。 创建表下面我们就可以对表进行操作了,我们刚刚 show tables 发现还没有任何表,所以我们现在进行建表语句 CREATE TABLE 表名称 ( 列名称1 数据类型 约束, 列名称2 数据类型 约束, 列名称3 数据类型 约束, .... ) CREATE TABLE 表名称
(
列名称1 数据类型 约束,
列名称2 数据类型 约束,
列名称3 数据类型 约束,
....
) 这样就很清楚了吧,列名称就是列的名字,紧跟着列名后面就是数据类型,然后是约束,为什么要这么设计?举个例子你就清楚了,比如 cxuan 刚被生出来就被打印上了标签 比如我们创建一个表,里面有 5 个字段,姓名(name)、性别(sex)、年龄(age)、何时雇佣(hiredate)、薪资待遇(wage),建表语句如下 create table job(name varchar(20), sex varchar(2), age int(2), hiredate date, wage decimal(10,2)); create table job(name varchar(20), sex varchar(2), age int(2), hiredate date, wage decimal(10,2)); 事实证明这条建表语句还是没问题的,建表完成后可以使用
show create table job \G; show create table job \G; 可以看到,除了看到表定义之外,还看到了表的 删除表表的删除语句有两种,一种是 drop table job drop table job 一种是 truncate table job truncate table job 这两者的区别简单理解就是 drop 语句删除表之后,可以通过日志进行回复,而 truncate 删除表之后永远恢复不了,所以,一般不使用 truncate 进行表的删除。‘ 修改表对于已经创建好的表,尤其是有大量数据的表,如果需要对表做结构上的改变,可以将表删除然后重新创建表,但是这种效率会产生一些额外的工作,数据会重新加载近来,如果此时有服务正在访问的话,也会影响服务读取表中数据,所以此时,我们需要表的修改语句来对已经创建好的表的定义进行修改。 修改表结构一般使用 ALTER TABLE tb MODIFY [COLUMN] column_definition [FIRST | AFTER col_name]; ALTER TABLE tb MODIFY [COLUMN] column_definition [FIRST | AFTER col_name]; 比如我们想要将 job 表中的 name 由 alter table job modify name varchar(25); alter table job modify name varchar(25); 也可以对表结构进行修改,比如增加一个字段 alter table job add home varchar(30); alter table job add home varchar(30); 将新添加的表的字段进行删除 alter table job drop column home; alter table job drop column home; 可以对表中字段的名称进行修改,比如吧 wage 改为 salary alter table job change wage salary decimal(10,2); alter table job change wage salary decimal(10,2); 修改字段的排列顺序,我们前面介绍过修改语法涉及到一个顺序问题,都有一个可选项 first | after column_name,这个选项可以用来修改表中字段的位置,默认 ADD 是在添加为表中最后一个字段,而 「CHANGE/MODIFY」 不会改变字段位置。比如 alter table job add birthday after hiredate; alter table job add birthday after hiredate; 可以对表名进行修改,例如将 job 表改为 worker alter table job rename worker; alter table job rename worker; DML 语句有的地方把 DML 语句(增删改)和 DQL 语句(查询)统称为 DML 语句,有的地方分开,我们目前使用分开称呼的方式 插入表创建好之后,我们就可以向表里插入数据了,插入记录的基本语法如下 INSERT INTO tablename (field1,field2) VALUES(value1,value2); INSERT INTO tablename (field1,field2) VALUES(value1,value2); 例如,向中插入以下记录 insert into job(name,sex,age,hiredate,birthday,salary) values("cxuan","男",24,"2020-04-27","1995-08-22",8000); insert into job(name,sex,age,hiredate,birthday,salary) values("cxuan","男",24,"2020-04-27","1995-08-22",8000); 也可以不用指定要插入的字段,直接插入数据即可 insert into job values("cxuan02","男",25,"2020-06-01","1995-04-23",12000); insert into job values("cxuan02","男",25,"2020-06-01","1995-04-23",12000); 这里就有一个问题,如果插入的顺序不一致的话会怎么样呢? 对于含可空字段、非空但是含有默认值的字段、自增字段可以不用在 insert 后的字段列表出现,values 后面只需要写对应字段名称的 value 即可,没有写的字段可以自动的设置为 NULL、默认值或者自增的下一个值,这样可以缩短要插入 SQL 语句的长度和复杂性。 比如我们设置一下 hiredate、age 可以为 null,来试一下 insert into job(name,sex,birthday,salary) values("cxuan03","男","1992-08-23",15000); insert into job(name,sex,birthday,salary) values("cxuan03","男","1992-08-23",15000); 我们看一下实际插入的数据 我们可以看到有一行两个字段显示 NULL。在 MySQL 中,insert 语句还有一个很好的特性,就是一次可以插入多条记录 INSERT INTO tablename (field1,field2) VALUES(value1,value2),(value1,value2),(value1,value2),...; INSERT INTO tablename (field1,field2) VALUES(value1,value2),(value1,value2),(value1,value2),...; 可以看出,每条记录之间都用逗号进行分割,这个特性可以使得 MySQL 在插入大量记录时,节省很多的网络开销,大大提高插入效率。 更新记录对于表中已经存在的数据,可以通过 update 命令对其进行修改,语法如下 UPDATE tablename SET field1 = value1, field2 = value2 ; UPDATE tablename SET field1 = value1, field2 = value2 ; 例如,将 job 表中的 cxuan03 中 age 的 NULL 改为 26,SQL 语句如下 update job set age = 26 where name = 'cxuan03'; update job set age = 26 where name = 'cxuan03'; SQL 语句中出现了一个 where 条件,我们会在后面说到 where 条件,这里简单理解一下它的概念就是根据哪条记录进行更新,如果不写 where 的话,会对整个表进行更新 删除记录如果记录不再需要,可以使用 delete 命令进行删除 DELETE FROM tablename [WHERE CONDITION] DELETE FROM tablename [WHERE CONDITION] 例如,在 job 中删除名字是 cxuan03 的记录 delete from job where name = 'cxuan03'; delete from job where name = 'cxuan03'; 在 MySQL 中,删除语句也可以不指定 where 条件,直接使用 delete from job delete from job 这种删除方式相当于是清楚表的操作,表中所有的记录都会被清除。 DQL 语句下面我们一起来认识一下 DQL 语句,数据被插入到 MySQL 中,就可以使用 SELECT 查询语句可以说是最复杂的语句了,这里我们只介绍一下基本语法 一种最简单的方式就是从某个表中查询出所有的字段和数据,简单粗暴,直接使用 SELECT * FROM tablename; SELECT * FROM tablename; 例如我们将 job 表中的所有数据查出来 select * from job; select * from job; 其中 * 是查询出所有的数据,当然,你也可以查询出指定的数据项 select name,sex,age,hiredate,birthday,salary from job; select name,sex,age,hiredate,birthday,salary from job; 上面这条 SQL 语句和 上面我们介绍了基本的 SQL 查询语句,但是实际的使用场景会会比简单查询复杂太多,一般都会使用各种 SQL 的函数和查询条件等,下面我们就来一起认识一下。 去重使用非常广泛的场景之一就是 为了演示效果,我们先向数据库中插入批量数据,插入完成后的表结构如下 下面我们使用 distinct 来对 age 去重来看一下效果 你会发现只有两个不同的值,其他和 25 重复的值被过滤掉了,所以我们使用 distinct 来进行去重 条件查询我们之前的所有例子都是查询全部的记录,如果我们只想查询指定的记录呢?这里就会用到 select * from job where age = 24; select * from job where age = 24; where 条件语句后面会跟一个判断的运算符 select * from job where age >= 24; select * from job where age >= 24; 就会从 job 表中查询出 age 年龄大于或等于 24 的记录 除此之外,在 where 条件查询中还可以有多个并列的查询条件,比如我们可以查询年龄大于等于 24,并且薪资大雨 8000 的记录 select * from job where age >= 24 and salary > 8000; select * from job where age >= 24 and salary > 8000; 多个条件之间还可以使用 or、and 等逻辑运算符进行多条件联合查询,运算符会在以后章节中详细讲解。 排序我们会经常有这样的需求,按照某个字段进行排序,这就用到了数据库的排序功能,使用关键字 SELECT * FROM tablename [WHERE CONDITION] [ORDER BY field1 [DESC|ASC] , field2 [DESC|ASC],……fieldn [DESC|ASC]] SELECT * FROM tablename [WHERE CONDITION] [ORDER BY field1 [DESC|ASC] , field2 [DESC|ASC],……fieldn [DESC|ASC]] 其中 DESC 和 ASC 就是顺序排序的关键字,DESC 会按照字段进行降序排列,ASC 会按照字段进行升序排列,默认会使用升序排列,也就是说,你不写 为了演示功能,我们先把表中的 下面我们按照工资进行排序,SQL 语句如下 select * from job order by salary desc; select * from job order by salary desc; 语句执行完成后的结果如下 这是对一个字段进行排序的结果,也可以对多个字段进行排序,但是需要注意一点
限制对于排序后的字段,或者不排序的字段,如果只希望显示一部分的话,就会使用 select * from job limit 3; select * from job limit 3; 或者我们对排序后的字段取前三条记录 select * from job order by salary limit 3; select * from job order by salary limit 3; 上面这种 limit 是从表记录的第 0 条开始取,如果从指定记录开始取,比如从第二条开始取,取三条记录,SQL 如下 select * from job order by salary desc limit 2,3; select * from job order by salary desc limit 2,3; limit 一般经常和 order by 语法一起实现分页查询。
聚合下面我们来看一下对记录进行汇总的操作,这类操作主要有
可以对 job 表中员工薪水进行统计,选出总共的薪水、最大薪水、最小薪水 select sum(salary) from job; select sum(salary) from job; select max(salary),min(salary) from job; select max(salary),min(salary) from job; 比如我们要统计 job 表中人员的数量 select count(1) from job; select count(1) from job; 统计完成后的结果如下 我们可以按照 job 表中的年龄来进行对应的统计 select age,count(1) from job group by age; select age,count(1) from job group by age; 既要统计各年龄段的人数,又要统计总人数 select age,count(1) from job group by age with rollup; select age,count(1) from job group by age with rollup; 在此基础上进行分组,统计数量大于 1 的记录 select age,count(1) from job group by age with rollup having count(1) > 1; select age,count(1) from job group by age with rollup having count(1) > 1; 表连接表连接一直是笔者比较痛苦的地方,曾经因为一个表连接挂了面试,现在来认真撸一遍。 表连接一般体现在表之间的关系上。当需要同时显示多个表中的字段时,就可以用表连接来实现。 为了演示表连接的功能,我们为 job 表加一个 下面开始我们的演示 查询出 job 表中的 type 和 job_type 表中的 type 匹配的姓名和工作类型 select job.name,job_type.name from job,job_type where job.type = job_type.type; select job.name,job_type.name from job,job_type where job.type = job_type.type; 上面这种连接使用的是内连接,除此之外,还有外连接。那么它们之间的区别是啥呢?
外连接分为两种
为了演示效果我们在 job 表和 job_type 表中分别添加记录,添加完成后的两表如下 下面我们进行左外连接查询:查询出 job 表中的 type 和 job_type 表中的 type 匹配的姓名和工作类型 select job.name,job_type.name from job left join job_type on job.type = job_type.type; select job.name,job_type.name from job left join job_type on job.type = job_type.type; 查询出来的结果如下 可以看出 cxuan06 也被查询出来了,而 cxuan06 他没有具体的工作类型。 使用右外连接查询 select job.name,job_type.name from job right join job_type on job.type = job_type.type; select job.name,job_type.name from job right join job_type on job.type = job_type.type; 可以看出,job 表中并没有 waiter 和 manager 的角色,但是也被查询出来了。 子查询有一些情况,我们需要的查询条件是另一个 SQL 语句的查询结果,这种查询方式就是子查询,子查询有一些关键字比如 「in、not in、=、!=、exists、not exists」 等,例如我们可以通过子查询查询出每个人的工作类型 select job.* from job where type in (select type from job_type); select job.* from job where type in (select type from job_type); 如果子查询数量唯一的话,还可以用 select * from job where type = (select type from job_type); select * from job where type = (select type from job_type); 意思是自查询不唯一,我们使用 limit 限制一下返回的记录数 select * from job where type = (select type from job_type limit 1,1); select * from job where type = (select type from job_type limit 1,1); 在某些情况下,子查询可以转换为表连接 联合查询我们还经常会遇到这样的场景,将两个表的数据单独查询出来之后,将结果合并到一起进行显示,这个时候就需要 UNION 和 UNION ALL 这两个关键字来实现这样的功能,UNION 和 UNION ALL 的主要区别是 UNION ALL 是把结果集直接合并在一起,而 UNION 是将 UNION ALL 后的结果进行一次 比如 select type from job union all select type from job_type; select type from job union all select type from job_type; 它的结果如下 上述结果是查询 job 表中的 type 字段和 job_type 表中的 type 字段,并把它们进行汇总,可以看出 UNION ALL 只是把所有的结果都列出来了 使用 UNION 的 SQL 语句如下 select type from job union select type from job_type; select type from job union select type from job_type; 可以看出 UNION 是对 UNION ALL 使用了 DCL 语句DCL 语句主要是管理数据库权限的时候使用,这类操作一般是 DBA 使用的,开发人员不会使用 DCL 语句。 关于帮助文档的使用我们一般使用 MySQL 遇到不会的或者有疑问的东西经常要去查阅网上资料,甚至可能需要去查 MySQL 官发文档,这样会耗费大量的时间和精力。 下面教你一下在 MySQL 命令行就能直接查询资料的语句 按照层次查询可以使用 ? contents; ? contents; 我们输入 ? Account Management ? Account Management 可以查询具体关于权限管理的命令 比如我们想了解一下数据类型 ? Data Types ? Data Types 然后我们想了解一下 ? VARCHAR ? VARCHAR 可以看到有关于 VARCHAR 数据类型的详细信息,然后在最下面还有 MySQL 的官方文档,方便我们快速查阅。 快速查阅在实际应用过程中,如果要快速查询某个语法时,可以使用关键字进行快速查询,比如我们使用 ? show ? show 能够快速列出一些命令 比如我们想要查阅 database 的信息,使用 SHOW CREATE DATABASE cxuandb; SHOW CREATE DATABASE cxuandb; MySQL 数据类型MySQL 提供很多种数据类型来对不同的常量、变量进行区分,MySQL 中的数据类型主要是 「数值类型、日期和时间类型、字符串类型」 选择合适的数据类型进行数据的存储非常重要,在实际开发过程中,选择合适的数据类型也能够提高 SQL 性能,所以有必要认识一下这些数据类型。 数值类型MySQL 支持所有标准的 SQL 数据类型,这些数据类型包括严格数据类型的
还有经过扩展之后的数据类型,它们是
其中 INT 是 INTEGER 的缩写,DEC 是 DECIMAL 的缩写。 下面是所有数据类型的汇总 整数在整数类型中,按照取值范围和存储方式的不同,分为
五个数据类型,如果超出类型范围的操作,会发生错误提示,所以选择合适的数据类型非常重要。 还记得我们上面的建表语句么 我们一般会在 SQL 语句的数据类型后面加上指定长度来表示数据类型许可的范围,例如 int(7) int(7) 表示 int 类型的数据最大长度为 7,如果填充不满的话会自动填满,如果不指定 int 数据类型的长度的话,默认是 我们创建一张表来演示一下 create table test1(aId int, bId int(5)); /* 然后我们查看一下表结构 */ desc test1; create table test1(aId int, bId int(5));
/* 然后我们查看一下表结构 */
desc test1; 整数类型一般配合 分别修改 test1 表中的两个字段 alter table test1 modify aId int zerofill; alter table test1 modify bId int(5) zerofill; alter table test1 modify aId int zerofill;
alter table test1 modify bId int(5) zerofill; 然后插入两条数据,执行查询操作 如上图所示,使用 会发现 aId 已经超出了指定范围,那么我们对 aId 插入一个在其允许范围之内的数据 会发现,aId 已经插进去了,bId 也插进去了,为什么 bId 显示的是 int(5) 却能够插入 7 位长度的数值呢? 所有的整数都有一个可选属性 除此之外,整数还有一个类型就是 小数小数说的是啥?它其实有两种类型;一种是 浮点数有两种
定点数只有一种 浮点数和定点数都可以使用 下面通过示例来演示一下 首先建立一个 CREATE TABLE test2 (aId float(6,2) default NULL, bId double(6,2) default NULL,cId decimal(6,2) default NULL) CREATE TABLE test2 (aId float(6,2) default NULL, bId double(6,2) default NULL,cId decimal(6,2) default NULL) 然后向表中插入几条数据 insert into test2 values(1234.12,1234.12,1234.12); insert into test2 values(1234.12,1234.12,1234.12); 这个时候显示的数据就是 然后再向表中插入一些约束之外的数据 insert into test2 values(1234.123,1234.123,1234.123); insert into test2 values(1234.123,1234.123,1234.123); 发现插入完成后还显示的是 现在我们把 test2 表中的精度全部去掉,再次插入 alter table test2 modify aId float;alter table test2 modify bId double;alter table test2 modify cId decimal; alter table test2 modify aId float;alter table test2 modify bId double;alter table test2 modify cId decimal; 先查询一下,发现 cId 舍去了小数位。 然后再次插入 1.23,SQL 语句如下 insert into test2 values(1.23,1.23,1.23); insert into test2 values(1.23,1.23,1.23); 结果如下 这个时候可以验证
位类型对于位类型,用于存放字段值, 下面我们来掩饰一下位类型 新建一个 test3 表,表中只有一个位类型的字段 create table test3(id bit(1)); create table test3(id bit(1)); 然后随意插入一条数据 insert into test3 values(1); insert into test3 values(1); 发现无法查询出对应结果。 然后我们使用 发现能够查询出对应结果。 也就是说当数据插入 test3 时,会首先把数据转换成为二进制数,如果位数允许,则将成功插入;如果位数小于实际定义的位数,则插入失败。如果我们像表中插入数据 2 insert into test3 values(2); insert into test3 values(2); 那么会报错 因为 2 的二进制数表示是 那么我们将表字段修改一下 然后再进行插入,发现已经能够插入了 日期时间类型MySQL 中的日期与时间类型,主要包括:「YEAR、TIME、DATE、DATETIME、TIMESTAMP」,每个版本可能不同。下表中列出了这几种类型的属性。 下面分别来介绍一下 YEARYEAR 可以使用三种方式来表示
下面我们来演示一下 YEAR 的用法,创建一个 test4 表 create table test4(id year); create table test4(id year); 然后我们看一下 test4 的表结构 默认创建的 year 就是 4 位,下面我们向 test4 中插入数据 insert into test4 values(2020),('2020'); insert into test4 values(2020),('2020'); 然后进行查询,发现表示形式是一样的 使用两位字符串来表示 delete from test4; insert into test4 values ('0'),('00'),('11'),('88'),('20'),('21'); delete from test4;
insert into test4 values ('0'),('00'),('11'),('88'),('20'),('21'); 使用两位数字来表示 delete from test4; insert into test4 values (0),(00),(11),(88),(20),(21); delete from test4;
insert into test4 values (0),(00),(11),(88),(20),(21); 发现只有前两项不一样。 TIMETIME 所表示的范围和我们预想的不一样 我们把 test4 改为 TIME 类型,下面是 TIME 的示例 alter table test4 modify id TIME; insert into test4 values ('15:11:23'),('20:13'),('2 11:11'),('3 05'),('33'); alter table test4 modify id TIME;
insert into test4 values ('15:11:23'),('20:13'),('2 11:11'),('3 05'),('33'); 结果如下 DATEDATE 表示的类型有很多种,下面是 DATE 的几个示例 create table test5 (id date); create table test5 (id date); 查看一下 test5 表 然后插入部分数据 insert into test5 values ('2020-06-13'),('20200613'),(20200613); insert into test5 values ('2020-06-13'),('20200613'),(20200613); DATE 的表示一般很多种,如下所示 DATE 的所有形式
DATETIMEDATETIME 类型,包含日期和时间部分,可以使用引用字符串或者数字,年份可以是 4 位也可以是 2 位。 下面是 DATETIME 的示例 create table test6 (id datetime); insert into test4 values ('2020-06-13 11:11:11'),(20200613111111),('20200613111111'),(20200613080808); create table test6 (id datetime);
insert into test4 values ('2020-06-13 11:11:11'),(20200613111111),('20200613111111'),(20200613080808); TIMESTAMPTIMESTAMP 类型和 DATETIME 类型的格式相同,存储 4 个字节(比DATETIME少),取值范围比 DATETIME 小。 下面来说一下各个时间类型的使用场景
每种日期类型都有一个范围,如果超出这个范围,在默认的 下面来解释一下 MySQL 中有一个环境变量是 sql_mode ,sql_mode 支持了 MySQL 的语法、数据校验,我们可以通过下面这种方式来查看当前数据库使用的 sql_mode select @@sql_mode; select @@sql_mode; 一共有下面这几种模式 来源于 https://www.cnblogs.com/Zender/p/8270833.html 字符串类型MySQL 提供了很多种字符串类型,下面是字符串类型的汇总 下面我们对这些数据类型做一个详细的介绍 CHAR 和 VARCHAR 类型CHAR 和 VARCHAR 类型很相似,导致很多同学都会忽略他们之间的差别,首先他俩都是用来保存字符串的数据类型,他俩的主要区别在于存储方式不同。CHAR 类型的长度就是你定义多少显示多少。占用 M 字节,比如你声明一个 create table vctest1 (vc varchar(6),ch char(6));insert into vctest1 values("abc ","abc ");select length(vc),length(ch) from vctest1; create table vctest1 (vc varchar(6),ch char(6));insert into vctest1 values("abc ","abc ");select length(vc),length(ch) from vctest1; 结果如下 可以看到 vc 的字符串类型是 varchar ,长度是 5,ch 的字符串类型是 char,长度是 3。可以得出结论,varchar 会保留最后的空格,char 会去掉最后的空格。 BINARY 和 VARBINARY 类型BINARY 和 VARBINARY 与 CHAR 和 VARCHAR 非常类似,不同的是它们包含二进制字符串而不包含非二进制字符串。BINARY 与 VARBINARY 的最大长度和 CHAR 与 VARCHAR 是一样的,只不过他们是定义字节长度,而 CHAR 和 VARCHAR 对应的是字符长度。 BLOB 类型BLOB 是一个二进制大对象,可以容纳可变数量的数据。有 4 种 BLOB 类型:TINYBLOB、BLOB、MEDIUMBLOB 和 LONGBLOB。它们区别在于可容纳存储范围不同。 TEXT 类型有 4 种 TEXT 类型:TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT。对应的这 4 种 BLOB 类型,可存储的最大长度不同,可根据实际情况选择。 ENUM 类型ENUM 我们在 Java 中经常会用到,它表示的是枚举类型。它的范围需要在创建表时显示指定,对 1 – 255 的枚举需要 1 个字节存储;对于 255 – 65535 的枚举需要 2 个字节存储。ENUM 会忽略大小写,在存储时都会转换为大写。 SET 类型SET 类型和 ENUM 类型有两处不同
SET 对于每 0 – 8 个成员,分别占用 1 个字节,最大到 64 ,占用 8 个字节
MySQL 运算符MySQL 中有多种运算符,下面对 MySQL 运算符进行分类
下面那我们对各个运算符进行介绍 算术运算符MySQL 支持的算术运算符包括加、减、乘、除和取余,这类运算符的使用频率比较高 下面是运算符的分类
下面简单描述了这些运算符的使用方法
在除法和取余需要注意一点,如果除数是 0 ,将是非法除数,返回结果为 NULL。 比较运算符熟悉了运算符,下面来聊一聊比较运算符,使用 SELECT 语句进行查询时,MySQL 允许用户对表达式的两侧的操作数进行比较,比较结果为真,返回 1, 比较结果为假,返回 0 ,比较结果不确定返回 NULL。下面是所有的比较运算符
比较运算符可以用来比较数字、字符串或者表达式。数字作为浮点数进行比较,字符串以不区分大小写的方式进行比较。
select 'a' <= 'b'; /* 返回 1 *//*而*/select 'a' >= 'b'; /* 返回 0 呢*/ select 'a' <= 'b'; /* 返回 1 *//*而*/select 'a' >= 'b'; /* 返回 0 呢*/
当 like 后面跟的是
后面会详细介绍 regexp 的用法。 逻辑运算符逻辑运算符指的就是
下面分别来介绍一下
位运算符一听说位运算,就知道是和二进制有关的运算符了,位运算就是将给定的操作数转换为二进制后,对各个操作数的每一位都进行指定的逻辑运算,得到的二进制结果转换为十进制后就说是位运算的结果,下面是所有的位运算。
下面分别来演示一下这些例子
按位与是一个数值减小的操作
位或是一个数值增大的操作
为什么会有这种现象,因为在 MySQL 中,常量数字默认会以 8 个字节来显示,8 个字节就是 64 位,常量 1 的二进制表示 63 个
MySQL 常用函数下面我们来了解一下 MySQL 函数,MySQL 函数也是我们日常开发过程中经常使用的,选用合适的函数能够提高我们的开发效率,下面我们就来一起认识一下这些函数 字符串函数字符串函数是最常用的一种函数了,MySQL 也是支持很多种字符串函数,下面是 MySQL 支持的字符串函数表
下面通过具体的示例演示一下每个函数的用法
CONCAT(s1,s2 … sn) :把传入的参数拼接成一个字符串 上面把
数值函数MySQL 支持数值函数,这些函数能够处理很多数值运算。下面我们一起来学习一下 MySQL 中的数值函数,下面是所有的数值函数
下面我们还是以实践为主来聊一聊这些用法
日期和时间函数日期和时间函数也是 MySQL 中非常重要的一部分,下面我们就来一起认识一下这些函数
下面结合示例来讲解一下每个函数的使用
具体的日期格式可以参考这篇文章 https://blog.csdn.net/weixin_38703170/article/details/82177837 我们演示一下将当前日期显示为「年月日」的这种形式,使用的日期格式是 「%M %D %Y」。
interval 表示间隔类型的关键字,expr 是表达式,这个表达式对应后面的类型,type 是间隔类型,MySQL 提供了 13 种时间间隔类型
查看离 2021 – 01 – 01 还有多少天 流程函数流程函数也是很常用的一类函数,用户可以使用这类函数在 SQL 中实现条件选择。这样做能够提高查询效率。下表列出了这些流程函数
其他函数除了我们介绍过的字符串函数、日期和时间函数、流程函数,还有一些函数并不属于上面三类函数,它们是
下面来看一下具体的使用
原文出处:微信公众号【cxuan Java建设者】 原文链接:https://mp.weixin.qq.com/s/526wVLFy4QWudKOpoWezug 本文观点不代表Dotnet9立场,转载请联系原作者。 |
|
来自: abin30 > 《Power Query》