MySQL之SQL结构化查询语言

预览

在这里插入图片描述

一、SQL的基本概念

1.什么是SQL?

Structured Query Language:结构化查询语言

是用于访问和处理数据库的标准的计算机语言。

是一种所有关系型数据库的查询规范,不同的数据库都支持。

通用的数据库操作语言,可以用在不同的数据库中。

每种数据库之间操作方式不一样的地方,称为“方言”。

2.SQL通用语法

1. SQL语句可以单行或多行书写,以分号结尾。

2. MySQL 数据库的 SQL 语句不区分大小写,关键字建议使用大写。
 
3. 3种注释
	 --空格  注释内容 
	 
	 # 注释内容<mysql特有>
	 
	 /* 注释 */ 多行注释

3.SQL分类

1.Data Definition Language (DDL 数据定义语言) 
	用来定义数据库对象:数据库,表,列等。关键字:create, drop,alter 等
	
2.Data Manipulation Language(DML 数据操纵语言)
	用来对数据库中表的数据进行增删改。关键字:insert, delete, update 等
					
3.Data Query Language(DQL 数据查询语言)
	用来查询数据库中表的记录(数据)。关键字:select, where 等
					
4.Data Control Language(DCL 数据控制语言)
	用来定义数据库的访问权限和安全级别,及创建用户。关键字:GRANT, REVOKE 等

二、DDL 数据定义语言

1.操作数据库

1.C(Create):创建

 创建数据库:
		 create database 数据库名称;
		 
创建数据库,判断不存在,再创建:
		 create database if not exists 数据库名称;
		 
 创建数据库,并指定字符集
		 create database 数据库名称 character set 字符集名;

 创建db数据库,判断是否存在,并制定字符集为gbk
		 create database if not exists db character set gbk

2.R(Retrieve):查询

 1. 查询所有数据库的名称
		 show databases;
					
2. 查询某个数据库的定义信息
		 show create database 数据库名称;

3.U(Update):修改

 修改数据库的字符集
		 alter database 数据库名称 character set 字符集名称;

4.D(Delete):删除

1.  删除数据库
		 drop database 数据库名称;
				
2.  判断数据库是否存在,存在再删除
		 drop database if exists 数据库名称;

5.使用数据库

1.  查询当前正在使用的数据库名称
		 select database();
		
 2. 使用数据库
		 use 数据库名称;

2. 操作表

1.语法:

create table 表名(
			列名1 数据类型1,
			列名2 数据类型2,
			....
			列名n 数据类型n
		);

		
常见数据库类型:
			1. 字符型
			char 固定长度存储数据 无论使用几个字符都占满全部
			varcahr 变长存储数据 使用几个字符就占用几个
					varchar(20) 20个字符  sql:3个字符  数据库:3个字符
			text 当存储大量的字符串时使用
			
			2.日期时间型
			time:表示时间类型
			date:表示日期类型,yyyy-MM-dd
			datetime:同时可以表示日期和时间类型	 yyyy-MM-dd HH:mm:ss

		3.浮点型
			float(m,n)  单精度浮点数,占 4 个字节
			double(m,n) 双精度浮点数,占 8 个字节
			decimal(m,n)	高精度 占m+2个字节,常用于money相关方面
			
			m是有效数字长度,n是小数点后的位数
			例:decimal(5,2) 是一个小数点前有 3 位数,小数点后有 2 位数的数字。
		 
		 4.整数型
			bigint 大整型:  超大整数型(占 64 位二进制) 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据
			int  整型:整数类型:  (占 32 位二进制) 从 -2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 的整型数据
			mediumint 中整型:中等长度的整数(占 24 位二进制) 从-2^23到2^24-1的整型数据
			smallint 小整型:小的整数(占 16 位二进制) 从 -2^15 (-32,768) 到 2^15 - 1 (32,767) 的整数数据
			tinyint  微整型:很小的整数(占 8 位二进制) 从 0 到 255 的整数数据
	
		5.大文本
			tinytext 长度 0~255 字节
			text 长度 0~65535 字节
			mediumtext 长度 0~167772150 字节
			longtext 长度 0~4294967295 字节

2.C(Create):创建

 创建表
		create table student(id int, name varchar(32), age int , score double(4,1), birthday date, insert_time timestamp);
	
 复制表:
		 create table 表名 like 被复制的表名;	

3.R(Retrieve):查询

 1. 查询某个数据库中所有的表名称
		 show tables;

2.  查询表结构
		 desc 表名;
		 
3. 查询表的创建语句		 
		show create table 表名;		 

4.U(Update):修改

1. 修改表名
		alter table 表名 rename to 新的表名;

2. 修改表的字符集
		alter table 表名 character set 字符集名称;

3. 添加一列
		alter table 表名 add 列名 数据类型;

4. 修改列名称 类型
		alter table 表名 change 列名 新列别 新数据类型;
		alter table 表名 modify 列名 新数据类型;

5. 删除列
		alter table 表名 drop 列名;

5.D(Delete):删除

 1.drop table 表名;
 	
 2.drop table  if exists 表名 ;
 如果表不存在,不删除,存在则删除

三、DML 数据操纵语言

1.添加数据:

语法:
		 insert into 表名(列名1,列名2,...列名n) values(值1,值2,值n);

蠕虫复制 : 将一张已经存在的表中的数据复制到另一张表中。

语法格式:
1.INSERT INTO 表名 1 SELECT * FROM 表名 2;
 2.INSERT INTO 表名 1(列 1, 列 2) SELECT  列 1,  列 2 FROM student;

 注意:
	1. 插入值 类型必须和 列类型匹配
	2. 值长度不能超过 列定义长度
	3. 插入空值 可以写 null
	4. 列名和值要一一对应。
	5. 如果表名后,不定义列名,则默认给所有列添加值
		insert into 表名 values(值1,值2,...值n);
	6. 除了数字类型,其他类型需要使用引号(单双都可以)引起来
	7.dos命令窗口操作数据乱码问题
			原因: 客户端是GBK编码 服务端编码是UTF-8	
			
			查看 MySQL 内部设置的编码 : show variables like 'character%';
			
			解决方法:修改 client、connection、results 的编码为 GBK,保证和 dos命令行编码保持一致即可(针对单次修改有效)
			
			1.单独设置: 
			set character_set_client=gbk; 修改客户端的字符集为 gbk
			set character_set_connection=gbk; 修改连接的字符集为 gbk
			set character_set_results=gbk; 修改查询的结果字符集为 gbk
			
			2.同时设置三项  set names gbk;

2.删除数据

语法:
	 delete from 表名 [where 条件]

注意:
	1. 如果不加条件,则删除表中所有记录。

	2. 如果要删除所有记录
		1. delete from 表名; -- 不推荐使用。有多少条记录就会执行多少次删除操作
		2. TRUNCATE TABLE 表名; -- 推荐使用,效率更高 先删除表,然后再创建一张一样的表。
		3. 没有添加数据的字段会使用 NULL

3.修改数据:

语法:
	 update 表名 set 列名1 = 值1, 列名2 = 值2,... [where 条件];

注意:
	 如果不加任何条件,则会将表中所有记录全部修改。

四、DQL 数据查询语言

1.语法

select * from 表名;

	select	字段列表 from 表名列表  where	条件列表	group by	分组字段	having	分组之后的条	order by	排序	limit	分页限定

2.基础查询

1. 多个字段的查询
	select 字段名1,字段名2... from 表名;
	 注意:
		如果查询所有字段,则可以使用*来替代字段列表。

2. 去除重复:
	 distinct

3. 计算列
	1.  使用四则运算计算一些列的值。(一般只会进行数值型的计算)
	2.  ifnull(表达式1,表达式2):null参与的运算,计算结果都为null
		表达式1:哪个字段需要判断是否为null
		如果该字段为null则使用表达式2的值进行替换值。

4. 起别名:
	SELECT name as uname  FROM student
	SELECT name uname  FROM student
	 as:as可以省略

3.条件查询

1. where子句后跟条件

2. 运算符
	1. > 、< 、<= 、>= 、= 、<>
		-- 查询年龄大于等于20 小于等于30
		SELECT * FROM student WHERE age >= 20 &&  age <=30;
		
		-- 查询年龄不等于22岁
		SELECT * FROM student WHERE age != 22;
		SELECT * FROM student WHERE age <> 22;
		
	2.  BETWEEN...AND  
		-- 查询年龄大于等于20 小于等于30
		SELECT * FROM student WHERE age BETWEEN 20 AND 30;
		
	3.  IN( 集合) 
		-- 查询年龄是10岁,20岁,20岁的学生信息
		SELECT * FROM student WHERE age IN (10,20,30);
		
	4.  LIKE:模糊查询
		
		-- 查询姓陈的有哪些?
		SELECT * FROM student WHERE NAME LIKE '陈%';
	
		 占位符:
			1.  _:单个任意字符
					-- 查询姓名第二个字是陈的人
					SELECT * FROM student WHERE NAME LIKE "_陈%";
					-- 查询姓名是3个字的人
					SELECT * FROM student WHERE NAME LIKE '___';
					
			2.  %:多个任意字符
					-- 查询姓名中包含陈的人
					SELECT * FROM student WHERE NAME LIKE '%陈%';
					
	5.  IS NULL  
		-- 查询学生地址为NULL
		SELECT * FROM student WHERE address IS NULL;
		
	6.  and  或 &&
		-- 查询年龄大于等于20 小于等于30
		SELECT * FROM student WHERE age >= 20 AND  age <=30;
		
	7. or  或 || 
		-- 查询年龄是10岁,20岁,20岁的学生信息
		SELECT * FROM student WHERE age = 10 OR age = 20 OR age = 30
		
	8. not  或 !
		-- 查询学生地址不为NULL
		SELECT * FROM student WHERE address IS  NOT NULL;

4.排序查询

1. 语法:order by 子句
	 order by 排序字段1 排序方式1,排序字段2 排序方式2...
	 
-- 查询所有数据,在年龄降序排序的基础上,如果年龄相同再以数学成绩升序排序
	select * from student order by age desc, score asc;

2. 排序方式:
	1. ASC:升序,默认的。
	2. DESC:降序。

3. 注意:
	如果有多个排序条件,则当前边的条件值一样时,才会判断第二条件。

5.聚合函数:

将一列数据作为一个整体,进行纵向的计算。

1. count:计算个数
	1. 一般选择非空的列:主键
	2. count(*)

2. max:计算最大值

3. min:计算最小值

4. sum:计算和

5. avg:计算平均值

6. 注意:聚合函数的计算,排除null值。
	解决方案:
		1. 选择不包含非空的列进行计算
		2. IFNULL函
			select count(ifnull(score,0)) from student;

6.分组查询:

1. 语法:group by 分组字段;

2. 注意:
	1. 分组之后查询的字段:分组字段、聚合函数

	2. where 和 having 的区别?

		1. where 在分组之前进行限定,如果不满足条件,则不参与分组。having在分组之后进行限定,如果不满足结果,则不会被查询出来
	
		2. where 后不可以跟聚合函数,having可以进行聚合函数的判断。
	
-- 以性别分组。分别查询男、女同学的平均分,人数
	SELECT sex , AVG(score),COUNT(id) FROM student GROUP BY sex;
	
--  以性别分组。分别查询男、女同学的平均分,人数 要求:分数低于70分的人,不参与分组,分组之后。人数要大于2个人
	SELECT sex , AVG(score),COUNT(id) 人数 FROM student WHERE score> 70 GROUP BY sex HAVING 人数 > 2;

7.分页查询

LIMIT 的作用就是限制查询记录的条数

1. 语法:limit 开始的索引,每页查询的条数;

2. 公式:开始的索引 = (当前的页码 - 1) * 每页显示的条数

	-- 每页显示5条记录 

	SELECT * FROM student LIMIT 0,5; -- 第1页
	
	SELECT * FROM student LIMIT 5,5; -- 第2页
	
	SELECT * FROM student LIMIT 10,5; -- 第3页
	
	-- 如果第一个参数是 0 可以省略写:
	select * from student limit 5;

3. limit 是MySQL的"方言"

五、DCL 数据控制语言

1.用户管理

1.创建用户

CREATE USER '用户名'@'ip' IDENTIFIED BY '密码';

本地登录:
create user 'test'@'localhost' identified by 'test';

远程登录:
create user 'test'@'%' identified by 'test';

2.修改密码

USE mysql;

UPDATE USER SET PASSWORD=PASSWORD(‘密码’) WHERE User=’用户名’ and Host=’IP’;
-- 刷新系统权限表
FLUSH PRIVILEGES;

-- 普通方式:
update user set password=password('test') where user='test' and host=’localhost’;
flush privileges;

-- 简化方式:
set password for '用户名'@'主机名' = password('新密码');

3.删除用户

DROP USER 用户名;

drop user test@localhost;

4.查询用户

	--  切换到mysql数据库
		USE myql;
		-- 查询user表
		SELECT * FROM USER;
		
		通配符: % 表示可以在任意主机使用用户登录数据库

2.用户权限管理

1.授权

GRANT 权限1, … , 权限n ON 数据库.* TO '用户名'@'主机名';

grant create,alter,drop,insert,update,delete,select on db.* to test@localhost;

-- 刷新系统权限表
flush privileges; 

2.撤权

REVOKE 权限1, … , 权限n ON 数据库.* FORM '用户名'@'主机名';

revoke create,select on db.* to test@localhost;

3.查权

SHOW GRANTS FOR '用户名'@'主机名';

show grants for test@localhost;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CodeDevMaster

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值