MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

  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';

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

清空重置表,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;

这两条语句功能一样

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

in表示在规定的集合内

使用in查询age在10,20,30,40,50的用户。

> select name,age from tb9 where age in (10,20,30,40,50);

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

is null;    表示值为空

is not null    表示值不为空

mysql聚合函数:

max()最大值,min()最小值,avg()平均值,count()统计值

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

查询每个班有多少位学生,使用group对班级分组。

> select ClassID,count(Name) from students group by ClassID;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

使用where过滤,没有班级的学生将不予显示。

> select ClassID,count(Name) from students where ClassID is not null  group by ClassID;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

查找学生人数大于3的班级,这里使用 as 将前面select 定义别名 counts,然后后使用group by 对ClassID做分组,最后使用了having子句做算数表达式过滤。

> select ClassID,count(Name) as counts  from students group by ClassID having counts>=3;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

显示出有多少男生,多少女生。

> select Gender,count(Gender) from students group by Gender;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

显示男生与女生的平均年龄。

> select Gender,avg(Age) from students group by Gender;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

依照年龄进行排序(升序)

> select Name,Age from students order by Age;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

依照年龄进行排序(降序)

> select Name,Age from students order by Age desc;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

显示年龄最大的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;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

以班级分组,显示各组年龄中的最小值;只显示最小年龄小于20的班级,并排序。

> select ClassID,min(Age) from students group by ClassID having min(Age)<20 order by min(Age);

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

以性别分组,显示各组年龄的年龄之和,要求将年龄之和逆序排列;

> select Gender,sum(Age) from students group by Gender order by sum(Age)  desc;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

以年龄分组,显示各组中的人数;

> select Age,count(Name) from students group by Age;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

表联接:

交叉联接;

内联接,让两张表当中对应的两个字段的值建立等值联接关系。

> select * from students,classes where students.ClassID = classes.ClassID;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

多表查询,显示每位学生的年龄,性别,属于哪个门派的。

> select Name,Class,Age,Gender  from students,classes where students.ClassID = classes.ClassID;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

外联接,以一张表中的每一行为标准跟另外一张表建立联接关系,如果另外一张表没有与之对应的值,则不显示即可。

    左外联接:

            left_table left join right_table on  conditon

以左表为基准显示

> select Name,Class from students left join classes on students.ClassID = classes.ClassID;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

    右外联接:

              right_table left join table on  conditon

以右边的表为标准,只要右边表中有的字段值全部显示出来,没有就留空,如果两边都没有值都为空,称为全外联接。

> select Name,Class from students right join classes on students.ClassID = classes.ClassID;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

使用别名简写:

> 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);

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

要求显示选了没有课程号的班级,这里也是使用子查询。

> 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' ;

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。

启动事务

> start transaction;

手动提交命令

commit

回滚命令

rollback

记录保存点

> savepoint pp1;

回滚至保存点

> rollback to pp1;

RDBMS    事务的隔离级别;

 READ-UNCOMMITTED        读未提交
 READ-COMMITTED              读提交
 REPEATABLE-READ            重读
 SERIALIZABLE                        串行

> show session variables like 'tx_isolation';

MySQL子查询的使用,事务与事务隔离级别,以及DML数据控制语言的使用解析。



本文转自qw87112 51CTO博客,原文链接:http://blog.51cto.com/tchuairen/1430924


上一篇:android.support library找不到的解决方法


下一篇:Java技术周刊第5期:基于JVM的脚本语言开发、运用实践