【数据库基础】MySQL增删改查基础操作命令

🌾第二章 数据库基础-SQL语言

🕊️2.1 概述

SQL:Structure Query Language(结构化查询语言),SQL被美国国家标准局(ANSI)确定为关系型数据库语言的美国标准,后来被国际化标准组织(ISO)采纳为关系数据库语言的国际标准。

  • 各数据库厂商都支持ISO的SQL标准,普通话

  • 各数据库厂商在标准的基础上做了自己的扩展,方言

SQL 是一种标准化的语言,它允许你在数据库上执行操作,如创建项目,查询内容,更新内容,

并删除条目等操作。

Create, Read, Update, and Delete 通常称为CRUD操作。

🕊️2.2 SQL语句分类

  • DDL(Data Defifinition Language):数据定义语言,用来定义数据库对象:库、表、列等。
  • DML(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据)增删改。
  • DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别。
  • DQL(Data Query Language):数据查询语言,用来查询记录(数据)查询。

注意:

  • sql语句以;结尾
  • mysql中的关键字不区分大小写

🕊️2.3 SQL常用数据类型:

数据类型解释
int整型
double浮点型,例如double(5,2)表示最多5位,其中必须有2位小数,即最大值为999.99;默认支持四舍五入
char固定长度字符串类型; char(10) 'aaa ’ 占10位
varchar可变长度字符串类型; varchar(10) ‘aaa’ 占3位
text字符串类型,比如小说信息;
blob字节类型,保存文件信息(视频,音频,图片);
date日期类型,格式为:yyyy-MM-dd;
time时间类型,格式为:hh:mm:ss
timestamp时间戳类型 yyyy-MM-dd hh:mm:ss 会自动赋值
datetime日期时间类型 yyyy-MM-dd hh:mm:ss

日期类型值的区别:

 date:yyyy-MM-dd (年月日)

 time:hh:mm:ss (时分秒)

 datetime:yyyy-MM-dd hh:mm:ss (年月日时分秒)

小结:

为空的条件:列名 is null or 列名=''

注:两个单引号表示空字符串

🕊️2.4 sql中的运算符

(1)算术运算符:+,-,*,/(除法),求余(%)

示例:

5/2

5%2

2/5

2%5

(2)赋值运算符:=

​ 注:赋值方向:从右往左赋值

​ 示例: name='张三

(3) 逻辑运算符:

and(并且),or(或者),not(取非)

作用:用于连接多个条件时使用

(4) 关系运算符:

\>,<,>=,<=,!=(不等于),=(等于),<>(不等于)
补充:查询所有数据:select * from 表名

🕊️2.5 DDL操作

🍵1、DDL-操作数据库

1 创建数据库

编码方式:gb2312,utf-8,gbk,iso-8859-1

排序规则:

  • gbk_chinese_ci :非二进制存储,不区分大小写
  • gbk_bin:以二进制形式进行存储,区分大小写
create database 数据库名

例如:

  1. 创建数据库+编码方式
create database mydb2 character set GBK;
  1. 创建数据库+编码方式+排序规则
create database mydb3 character set GBK collate gbk_chinese_ci;
2 删除数据库
drop database 数据库名

例如:

drop database mydb3;
3 修改数据库
  1. 修改数据库编码方式
alter database 数据库名 character set 编码方式

例如:

alter database mydb2 character set utf8;
4 查看数据库
  1. 查看当前数据库服务器中的所有数据库
show databases;
  1. 查看前面创建的mydb2数据库的定义信息
show create database mydb2;
5 其他语句
  1. 查看当前使用的数据库
select database();
  1. 切换数据库: use 数据库名
use mydb2;
  1. 获取当前系统时间:now()
select now();

🍵2、DDL-操作表

1 创建表和增加列
  1. 创建表

语法:

CREATE TABLE 表名(
列名1 数据类型 [约束],
列名2 数据类型 [约束],
列名n 数据类型 [约束]
);

说明:

表名,列名是自定义,多列之间使用逗号间隔,最后一列的逗号不能写, [约束] 表示可有可无

示例:

CREATE TABLE employee(
	id INT ,
	age INT ,
	first VARCHAR(255),
	last VARCHAR(255)
);
  1. 增加列
alter table 表名 add 新列名 新的数据类型

例如:在上面员工表的基本上增加一个image列。

alter table employee add image blob;
2 删除表
  1. 删除表
 drop table 表名;
  1. 删除列
alter table 表名 drop 列名

例如:删除image列,一次只能删一列。

alter table employee drop image;
3 修改表
  1. 修改表名
alter table 旧表名 rename 新表名;
  1. 修改列:列名+数据类型
alter table 表名 change 旧列名 新列名 新的数据类型

例如:修改job列,使其长度为60。

alter table employee modify job varchar(60);
alter table employee change job job varchar(60);
  1. 修改表的字符集为gbk
 alter table 表名 character set 编码方式
3 查看表
  1. 当前数据库中的所有表
 show tables;
  1. 查看表格的创建细节
show create table 表名;
  1. 查看表的字段信息
 desc 表名;
练习:
表名 card(会员卡表)
  列名    数据类型 
 cardid   int 
 cardnum  varchar(20)
 regDate  date

需求:
(1)创建该表
(2)将card表名修改为CardInfo
(3)添加delDate(注销时间) 列到表中
(4)将cardnum改为varchar(30)
(5)删除regDate列
(6)删除cardInfo表

🕊️2.6 DML操作

DML是对表中的数据进行增、删、改的操作。不要与DDL混淆了。主要包括:INSERTUPDATEDELETE
小知识:
mysql中,字符串类型和日期类型都要用单引号括起来。空值:null

1 插入操作

  1. 插入数据:INSERT
insert into 表名(列名) values(数据值);

注意:

  • 多列和多个列值之间使用逗号隔开
  • 列名要和列值一一对应
  • 非数值的列值两侧需要加单引号
  • 添加数据的时候可以将列名省略->当给所有列添加数据的时候

常见错误:

Data too long for column 'stusex' at row 1

同时添加多行

insert into 表名(列名) values(第一行数据),
(第二行数据),
(第三行数据),
(第四行数据);

例如:

insert into student(stuname,stuage,stusex,birthday)
values('张三3',18,'a','2000-1-1'),
('张三4',18,'a','2000-1-1'),
('张三5',18,'a','2000-1-1'),
('张三6',18,'a','2000-1-1'),
('张三7',18,'a','2000-1-1'),
('张三8',18,'a','2000-1-1');

注意:

  • 列名与列值的类型、个数、顺序要一一对应。
  • 参数值不要超出列定义的长度。
  • 如果插入空值,请使用null
  • 插入的日期和字符一样,都使用单引号括起来

2 删除

语法 :
delete from 表名 【WHERE 列名=值】
truncate from 表名
  • delete删除表中的数据,表结构还在;删除后的数据可以找回
  • truncate删除是把表直接drop掉,然后再创建一个同样的新表,相当于删除了所有数据。
  • 删除的数据不能找回。执行速度比delete

3 更新

语法:update 表名 set 列名1=列值1,列名2=列值2 ... WHERE 列名=值	

🕊️2.7 DQL数据查询(重要)

数据库执行DQL语句不会对数据进行改变,而是让数据库发送结果集给客户端。查询返回的结果集是一张虚拟表。

语法: select 列名 from 表名 【where --> group by-->having--> order by】

1 简单查询

查询所有列

select * from 表名;

查询指定列

select 列名1, 列名2, 列名3 from 表名;

2 条件查询

条件查询就是在查询时给出where子句,在where子句中可以使用如下运算符及关键字:
=、!=、<>、<、<=、>、>=; between…addandorin(set)notis null

(1)查询性别为女,并且年龄50以内的记录

SELECT * FROM stu WHERE gender='female' and age<50;

(2)查询学号为S_1001,或者姓名为liSi的记录

SELECT * FROM stu WHERE sid ='S_1001' OR sname='liSi';

(3)查询学号为S_1001,S_1002,S_1003的记录 列名 in (列值1,列值2)

SELECT * FROM stu WHERE sid IN ('S_1001','S_1002','S_1003');

(4)查询学号不是S_1001,S_1002,S_1003的记录

SELECT * FROM tab_student WHERE sid NOT IN('S1001','S1002','S_1003');

(5)查询年龄为null的记录

SELECT * FROM stu WHERE age IS NULL;

(6) 查询年龄在20到40之间的学生记录

SELECT * FROM stu WHERE age>=20 AND age<=40;

或者:列名 between 开始值 and 结束值;//注意:1.开始值<结束值 2.包含临界值的

SELECT * FROM stu WHERE age BETWEEN 20 AND 40;

(7) 查询性别非男的学生记录

SELECT * FROM stu WHERE gender!='male';

或者

SELECT * FROM stu WHERE gender<>'male';

或者

SELECT * FROM stu WHERE NOT gender='male';

(8) 查询姓名不为null的学生记录

SELECT * FROM stu WHERE NOT sname IS NULL;

或者

SELECT * FROM stu WHERE sname IS NOT NULL;

3 模糊查询

当想查询姓名中包含a字母的学生时就需要使用模糊查询了。模糊查询需要使用关键字LIKE

语法: 列名 like '表达式' //表达式必须是字符串

通配符:
_(下划线): 任意一个字符
%:任意0~n个字符,‘张%’

(1)查询姓名由3个字构成的学生记录

SELECT * FROM stu WHERE sname LIKE '___';

(2)查询姓名由5个字母构成,并且第5个字母为“i”的学生记录

SELECT * FROM stu WHERE sname LIKE '____i';

(3)查询姓名以“z”开头的学生记录

SELECT * FROM stu WHERE sname LIKE 'z%';

其中“%”匹配0~n个任何字母。

(4)查询姓名中第2个字母为“i”的学生记录

SELECT * FROM stu WHERE sname LIKE '_i%';

(5)查询姓名中包含“a”字母的学生记录

SELECT * FROM stu WHERE sname LIKE '%a%';

4 字段控制查询

操作练习数据:

create table emp(
id int primary key,
name varchar(100) not null,
gender varchar(10) not null,
birthday date, salary float(10,2),
entry_date date,
resume text
);
insert into emp(id,name,gender,birthday,salary,entry_date,resume) values(1,'zhangsan','female','1990-5-10',10000,'2015-5-5-','goodgirl');

insert into emp(id,name,gender,birthday,salary,entry_date,resume) values(2,'lisi','male','1995-5-10',10000,'2015-5-5','good boy');

insert into emp(id,name,gender,birthday,salary,entry_date,resume) VALUES(3,'你好','male','1995-5-10',10000,'2015-5-5','good boy');

(1)去除重复记录

select distinct gender from emp;

(2)查看雇员的月薪与佣金之和

select *,sal+comm from emp;

comm列有很多记录的值为NULL,因为任何东西与NULL相加结果还是NULL,所以结算结果可能会出

现NULL。下面使用了把NULL转换成数值0的函数IFNULL

select *,sal+ifnull(comm,0) from emp;

(3)给列名添加别名

SELECT *, sal+IFNULL(comm,0) AS total FROM emp;

给列起别名时,是可以省略AS关键字的:

SELECT *,sal+IFNULL(comm,0) total FROM emp;

5 排序:

语法:

 order by 列名 asc/desc
 
 //asc 升序 desc 降序 默认不写的话是升序

(1) 查询所有学生记录,按年龄升序排序

SELECT * FROM stu ORDER BY age ASC;

或者

SELECT * FROM stu ORDER BY age;

(2) 查询所有学生记录,按年龄降序排序

SELECT * FROM stu ORDER BY age DESC;

(3) 查询所有雇员,按月薪降序排序,如果月薪相同时,按编号升序排序

多列排序:当前面的列的值相同的时候,才会按照后面的列值进行排序

SELECT * FROM emp ORDER BY sal DESC,empno ASC;

6 聚合函数

聚合函数是用来做纵向运算的函数:

  • COUNT(列名):统计指定列不为NULL的记录行数;
  • SUM(列名):计算指定列的数值和,如果指定列类型不是数值类型,那么计算结果为0;
  • MAX(列名):计算指定列的最大值,如果指定列是字符串类型,那么使用字符串排序运算;
  • MIN(列名):计算指定列的最小值,如果指定列是字符串类型,那么使用字符串排序运算;
  • AVG(列名):计算指定列的平均值,如果指定列类型不是数值类型,那么计算结果为0;

(1) COUNT

当需要纵向统计时可以使用COUNT()。

查询emp表中记录数:

SELECT COUNT(*) AS cnt FROM emp;

查询emp表中有佣金的人数:

SELECT COUNT(comm) cnt FROM emp;

注意,因为count()函数中给出的是comm列,那么只统计comm列非NULL的行数。

l 查询emp表中月薪大于2500的人数:

SELECT COUNT(*) FROM emp WHERE sal > 2500; 

统计月薪与佣金之和大于2500元的人数:

SELECT COUNT(*) AS cnt FROM emp WHERE sal+IFNULL(comm,0) > 2500;

查询有佣金的人数,以及有领导的人数:

SELECT COUNT(comm), COUNT(mgr)FROM emp;

(2) SUM

当需要纵向求和时使用sum()函数。

查询所有雇员月薪和:

SELECT SUM(sal) FROM emp;

查询所有雇员月薪和,以及所有雇员佣金和:

SELECT SUM(sal), SUM(comm) FROM emp;

查询所有雇员月薪+佣金和:

SELECT SUM(sal+IFNULL(comm,0))FROM emp;

(3)MAX和MIN

查询最高工资和最低工资:

SELECT MAX(sal), MIN(sal) FROM emp;

(4)AVG

统计所有员工平均工资:

SELECT AVG(sal) FROM emp;

7 分组查询

当需要分组查询时需要使用GROUP BY子句,例如查询每个部门的工资和,这说明要使用部分来分组。

注意:如果查询语句中有分组操作,则select后面能添加的只能是聚合函数和被分组的列名

查询每个部门的部门编号和每个部门的工资和:

SELECT deptno, SUM(sal) FROM emp GROUP BY deptno;

查询每个部门的部门编号以及每个部门的人数:

SELECT deptno,COUNT(*) FROM emp GROUP BY deptno;

查询每个部门的部门编号以及每个部门工资大于1500的人数:

SELECT deptno,COUNT(*) FROM emp WHERE sal>1500 GROUP BY deptno;
HAVING子句

查询工资总和大于9000的部门编号以及工资和:

SELECT deptno, SUM(sal) FROM emp GROUP BY deptno HAVING SUM(sal) > 9000;
注:having与where的区别:

1.having是在分组后对数据进行过滤,where是在分组前对数据进行过滤

2.having后面可以使用分组函数(统计函数)

where后面不可以使用分组函数。\

WHERE是对分组前记录的条件,如果某行记录没有满足WHERE子句的条件,那么这行记录不会参加分

组;而HAVING是对分组后数据的约束。

补充: 多列分组

统计出stu表中每个班级的男女生各多少人

select gradename,gender ,count(*) from stu group by gradename,gender

8 LIMIT

LIMIT用来限定查询结果的起始行,以及总行数。

limit 开始下标,显示条数;//开始下标从0开始

limit 显示条数;//表示默认从0开始获取数据

1.查询5行记录,起始行从0开始

SELECT * FROM emp LIMIT 0, 5;

注意,起始行从0开始,即第一行开始!

2.查询10行记录,起始行从3开始

SELECT* FROM emp LIMIT 3, 10;

9 分页查询

如果一页记录为10条,希望查看第3页记录应该怎么查呢?

第一页记录起始行为0,一共查询10行; limit 0,10

第二页记录起始行为10,一共查询10行;limit 10,10

第三页记录起始行为20,一共查询10行; limit 20,10

pageIndex 页码值 pageSize 每页显示条数

limit (pageindex-1)*pagesize,pagesize;

查询语句书写顺序select – from- where- group by- having- order by-limit

查询语句执行顺序from - where -group by -having - select - order by-limit

🕊️2.8 DCL操作

定义:(Data Control Language):数据控制语言,用来定义访问权限和安全级别。

1、创建用户:

create user 用户名@指定ip identified by 密码;

create user test123@localhost identified  by 'test123'

create user 用户名@客户端ip identifified by 密码; 指定IP才能登陆

create user test456@10.4.10.18 identified by 'test456'

create user 用户名@‘% ’ identifified by 密码 任意IP均可登陆

create user test7@'%' IDENTIFIED by 'test7'

2、用户授权:

grant 权限1,权限2,…,权限n on

数据库名 .* to 用户名@IP; 给指定用户授予指定指定数据库指定权

grant select,insert,update,delete,create on chaoshi.* to 'test456'@'127.0.0.1';

grant all on . to 用户名@IP 给指定用户授予所有数据库所有权限

grant all on *.* to 'test456'@'127.0.0.1'

3、用户权限查询:

show grants for 用户名@IP;

show grants for 'root'@'%';

4、撤销用户权限:

revoke 权限1,权限2,…,权限n on 数据库名.* from 用户名@IP;

REVOKE SELECT ON *.* FROM 'root'@'%' ;

5、删除用户:

drop user 用户名@IP;

drop user test123@localhost;

在这里插入图片描述

【数据库基础】数据库介绍和三大范式

【数据库基础】MySQL增删改查基础操作命令

【数据库高级】数据完整性和多表查询

【数据库】事务

【数据库高级】Mysql窗口函数的使用和练习

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小满@

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

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

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

打赏作者

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

抵扣说明:

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

余额充值