DML:数据操作语言
插入数据1
> insert atb (name,age) values (tuchao,21),(tyz,25);
插入数据2
> insert atb set name='jerry',age=19;
插入数据3,可以把查询到的数据,插入表中。
> insert into atb(name) select user from mysql.user;
更新数据
> update atb set age=20 where name='root';
清除数据
> delete from atb where name='root';
清空重置表,Auto_increment也会重置。
> truncate table tb9;
mysql内置函数
> select last_insert_id();
使用between显示tb9表中,年龄大于20小于40的用户。
> select name,age from tb9 where age between 20 and 40;
> select name,age from tb9 where age>=20 and age<=40;
这两条语句功能一样
in表示在规定的集合内
使用in查询age在10,20,30,40,50的用户。
> select name,age from tb9 where age in (10,20,30,40,50);
is null; 表示值为空
is not null 表示值不为空
mysql聚合函数:
max()最大值,min()最小值,avg()平均值,count()统计值
查询每个班有多少位学生,使用group对班级分组。
> select ClassID,count(Name) from students group by ClassID;
使用where过滤,没有班级的学生将不予显示。
> select ClassID,count(Name) from students where ClassID is not null group by ClassID;
查找学生人数大于3的班级,这里使用 as 将前面select 定义别名 counts,然后后使用group by 对ClassID做分组,最后使用了having子句做算数表达式过滤。
> select ClassID,count(Name) as counts from students group by ClassID having counts>=3;
显示出有多少男生,多少女生。
> select Gender,count(Gender) from students group by Gender;
显示男生与女生的平均年龄。
> select Gender,avg(Age) from students group by Gender;
依照年龄进行排序(升序)
> select Name,Age from students order by Age;
依照年龄进行排序(降序)
> select Name,Age from students order by Age desc;
显示年龄最大的5个。
> select Name,Age from students order by Age desc limit 5;
使用distinct显示有多少种类别。
> select distinct Gender from students;
以性别分组,显示各组年龄中的最大值;
> select Gender,max(Age) from students group by Gender;
以班级分组,显示各组年龄中的最小值;只显示最小年龄小于20的班级,并排序。
> select ClassID,min(Age) from students group by ClassID having min(Age)<20 order by min(Age);
以性别分组,显示各组年龄的年龄之和,要求将年龄之和逆序排列;
> select Gender,sum(Age) from students group by Gender order by sum(Age) desc;
以年龄分组,显示各组中的人数;
> select Age,count(Name) from students group by Age;
表联接:
交叉联接;
内联接,让两张表当中对应的两个字段的值建立等值联接关系。
> select * from students,classes where students.ClassID = classes.ClassID;
多表查询,显示每位学生的年龄,性别,属于哪个门派的。
> select Name,Class,Age,Gender from students,classes where students.ClassID = classes.ClassID;
外联接,以一张表中的每一行为标准跟另外一张表建立联接关系,如果另外一张表没有与之对应的值,则不显示即可。
左外联接:
left_table left join right_table on conditon
以左表为基准显示
> select Name,Class from students left join classes on students.ClassID = classes.ClassID;
右外联接:
right_table left join table on conditon
以右边的表为标准,只要右边表中有的字段值全部显示出来,没有就留空,如果两边都没有值都为空,称为全外联接。
> select Name,Class from students right join classes on students.ClassID = classes.ClassID;
使用别名简写:
> select Name,Class,Age,Gender from students as a right join classes as b on a.ClassID = b.ClassID;
多表查询,联接4个表显示,每位学生姓名与对应课程。
> select Name,Course from students,classes,coc,courses where students.ClassID = classes.ClassID and classes.ClassID = coc.ClassID and coc.CourseID = courses.CourseID;
子查询
要求显示学生年龄大于平均年龄的学生姓名。
> select Name from students where Age > (select avg(Age) from students);
要求显示选了没有课程号的班级,这里也是使用子查询。
> select ClassID from coc where CourseID not in (Select CourseID from courses);
要求显示大于全校平均年龄的同学的总数
> select count(Name) from students where Age > (select avg(Age) from students);
锁机制
读锁 LOCK TABLES TABLE_name READ
写锁 LOCK TABLES TABLE_name WRITE
释放锁 UNLOCK TABLES
关闭所有表 FLUSH TABLES
导出数据库
# mysqldump -u root -p --databases hellodb > hellodb.sql
用sed替换MyISAM为InnoDB引擎。
# sed -i 's/ENGINE=MyISAM/ENGINE=Innodb/g' hellodb.sql
导入数据库
# mysql -uroot -p < hellodb.sql
控制事务自动提交的变量
> show global variables like 'autocommit' ;
启动事务
> start transaction;
手动提交命令
commit
回滚命令
rollback
记录保存点
> savepoint pp1;
回滚至保存点
> rollback to pp1;
RDBMS 事务的隔离级别;
READ-UNCOMMITTED 读未提交
READ-COMMITTED 读提交
REPEATABLE-READ 重读
SERIALIZABLE 串行
> show session variables like 'tx_isolation';
本文转自qw87112 51CTO博客,原文链接:http://blog.51cto.com/tchuairen/1430924

![MA{0``Q([]DNN)YSZ56S_NG.jpg wKioL1Oq0u7yN9H2AAGdIeum3ss322.jpg](https://ucc.alicdn.com/gtdqzn4uqwgsg/developer-article469639/20241018/2df400c522ac4b6498f2ae8c781aefef.jpeg?x-oss-process=image/resize,w_1400/format,webp)
![0)U9~]K~_B3GMVF`6_NPH6O.jpg wKiom1Oq1MzB7tGKAAExwnHkK1w999.jpg](https://ucc.alicdn.com/gtdqzn4uqwgsg/developer-article469639/20241018/4d1ad29bdeba432a86352a5027329f6c.jpeg?x-oss-process=image/resize,w_1400/format,webp)

![(7SQWJK__}ISWKE]G5DLFF5.jpg wKioL1Ors7mjl_R7AACxUlpu2v4630.jpg](https://ucc.alicdn.com/gtdqzn4uqwgsg/developer-article469639/20241018/b54ae7e25ff74786a87b049a81bd54ad.jpeg?x-oss-process=image/resize,w_1400/format,webp)



![SR(X5CIQ75}]2Y{Z4[$(D25.jpg wKiom1OruDnxjEvSAACf_kf48F0838.jpg](https://ucc.alicdn.com/gtdqzn4uqwgsg/developer-article469639/20241018/5c112f83860d43edafaf75d960dc3c55.jpeg?x-oss-process=image/resize,w_1400/format,webp)

![NASC~]Y{(UX8KZNTERU@VM4.jpg wKioL1OruWWhTOJWAAGj9QIzKAI903.jpg](https://ucc.alicdn.com/gtdqzn4uqwgsg/developer-article469639/20241018/eeabd8cbecab439d860006ee8ccd90fd.jpeg?x-oss-process=image/resize,w_1400/format,webp)




![E2QA_)@H~XC`$A7A1{3]6CC.jpg wKioL1OrxZLA6PzFAAQMmgk83Io517.jpg](https://ucc.alicdn.com/gtdqzn4uqwgsg/developer-article469639/20241018/bbe084d7d4bb44509808e606e005bf34.jpeg?x-oss-process=image/resize,w_1400/format,webp)
![P1J1_TA]$@IT5PJ)DPS@3{K.jpg wKiom1OryATAlYWyAALJd47USWY677.jpg](https://ucc.alicdn.com/gtdqzn4uqwgsg/developer-article469639/20241018/c1ea789c022e471e8a84510d9fa6a2db.jpeg?x-oss-process=image/resize,w_1400/format,webp)


![G%]ZR87`)`(Q2MQDQ{7RVVW.jpg wKioL1Or2FugMKXsAAC_x304jWk021.jpg](https://ucc.alicdn.com/gtdqzn4uqwgsg/developer-article469639/20241018/5671949730844195abc52230dd18c5e5.jpeg?x-oss-process=image/resize,w_1400/format,webp)

![9YW3O1]TGJLG9IBVJ`}O)AO.jpg wKiom1OsLTDzoGVuAACdK0MehB8882.jpg](https://ucc.alicdn.com/gtdqzn4uqwgsg/developer-article469639/20241018/ed7c7c098abe4d5c92aee19c5cb7ad82.jpeg?x-oss-process=image/resize,w_1400/format,webp)