天天看點

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

<a href="http://s3.51cto.com/wyfs02/M02/34/44/wKiom1OqxMrhXwjaAAEy_KJpCog724.jpg" target="_blank"></a>

清空重置表,Auto_increment也會重置。

&gt; truncate table tb9;

mysql内置函數

&gt; select last_insert_id();

使用between顯示tb9表中,年齡大于20小于40的使用者。

&gt; select name,age from tb9 where age between 20 and 40;

&gt; select name,age from tb9 where age&gt;=20 and age&lt;=40;

這兩條語句功能一樣

<a href="http://s3.51cto.com/wyfs02/M02/34/49/wKioL1Oq0u7yN9H2AAGdIeum3ss322.jpg" target="_blank"></a>

in表示在規定的集合内

使用in查詢age在10,20,30,40,50的使用者。

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

<a href="http://s3.51cto.com/wyfs02/M00/34/4B/wKiom1Oq1MzB7tGKAAExwnHkK1w999.jpg" target="_blank"></a>

is null;    表示值為空

is not null    表示值不為空

mysql聚合函數:

max()最大值,min()最小值,avg()平均值,count()統計值

<a href="http://s3.51cto.com/wyfs02/M00/34/4E/wKiom1Oq2zCikkZCAAFyNIPNS94545.jpg" target="_blank"></a>

查詢每個班有多少位學生,使用group對班級分組。

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

<a href="http://s3.51cto.com/wyfs02/M00/36/A4/wKioL1Ors7mjl_R7AACxUlpu2v4630.jpg" target="_blank"></a>

使用where過濾,沒有班級的學生将不予顯示。

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

<a href="http://s3.51cto.com/wyfs02/M02/36/A5/wKioL1Ors-vhbgiiAADKan2rCT0042.jpg" target="_blank"></a>

查找學生人數大于3的班級,這裡使用 as 将前面select 定義别名 counts,然後後使用group by 對ClassID做分組,最後使用了having子句做算數表達式過濾。

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

<a href="http://s3.51cto.com/wyfs02/M02/36/B1/wKiom1OrtdzTnJRcAADDRWD_nPU203.jpg" target="_blank"></a>

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

&gt; select Gender,count(Gender) from students group by Gender;

<a href="http://s3.51cto.com/wyfs02/M01/36/BE/wKioL1OrtzjC564SAACi8zy03Nk518.jpg" target="_blank"></a>

顯示男生與女生的平均年齡。

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

<a href="http://s3.51cto.com/wyfs02/M02/36/C9/wKiom1OruDnxjEvSAACf_kf48F0838.jpg" target="_blank"></a>

依照年齡進行排序(升序)

&gt; select Name,Age from students order by Age;

<a href="http://s3.51cto.com/wyfs02/M01/36/D0/wKioL1OruQSyP_OMAAGXE_JAYmk853.jpg" target="_blank"></a>

依照年齡進行排序(降序)

&gt; select Name,Age from students order by Age desc;

<a href="http://s3.51cto.com/wyfs02/M02/36/D7/wKioL1OruWWhTOJWAAGj9QIzKAI903.jpg" target="_blank"></a>

顯示年齡最大的5個。

&gt; select Name,Age from students order by Age desc limit 5;

使用distinct顯示有多少種類别。

&gt; select distinct Gender from students;

以性别分組,顯示各組年齡中的最大值;

&gt; select Gender,max(Age) from students group by Gender;

<a href="http://s3.51cto.com/wyfs02/M01/36/F0/wKioL1Oru-PQJEssAACYs8uhEVc108.jpg" target="_blank"></a>

以班級分組,顯示各組年齡中的最小值;隻顯示最小年齡小于20的班級,并排序。

&gt; select ClassID,min(Age) from students group by ClassID having min(Age)&lt;20 order by min(Age);

<a href="http://s3.51cto.com/wyfs02/M00/36/F1/wKiom1OrvfnDoPLbAADOyVliQek862.jpg" target="_blank"></a>

以性别分組,顯示各組年齡的年齡之和,要求将年齡之和逆序排列;

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

<a href="http://s3.51cto.com/wyfs02/M02/36/F1/wKioL1Orv2TRUfx3AACrbg2ojS0170.jpg" target="_blank"></a>

以年齡分組,顯示各組中的人數;

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

<a href="http://s3.51cto.com/wyfs02/M01/36/F2/wKiom1OrwMaiKlGPAADZ7vETwS8469.jpg" target="_blank"></a>

表聯接:

交叉聯接;

内聯接,讓兩張表當中對應的兩個字段的值建立等值聯接關系。

&gt; select * from students,classes where students.ClassID = classes.ClassID;

<a href="http://s3.51cto.com/wyfs02/M02/36/F1/wKioL1OrxZLA6PzFAAQMmgk83Io517.jpg" target="_blank"></a>

多表查詢,顯示每位學生的年齡,性别,屬于哪個門派的。

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

<a href="http://s3.51cto.com/wyfs02/M01/36/F3/wKiom1OryATAlYWyAALJd47USWY677.jpg" target="_blank"></a>

外聯接,以一張表中的每一行為标準跟另外一張表建立聯接關系,如果另外一張表沒有與之對應的值,則不顯示即可。

    左外聯接:

            left_table left join right_table on  conditon

以左表為基準顯示

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

<a href="http://s3.51cto.com/wyfs02/M00/36/F2/wKioL1Ory_3xTulPAAJN6xKdpHU812.jpg" target="_blank"></a>

    右外聯接:

              right_table left join table on  conditon

以右邊的表為标準,隻要右邊表中有的字段值全部顯示出來,沒有就留白,如果兩邊都沒有值都為空,稱為全外聯接。

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

<a href="http://s3.51cto.com/wyfs02/M02/36/F2/wKioL1OrzlvggATMAAJVAaBoTHg555.jpg" target="_blank"></a>

使用别名簡寫:

&gt; select Name,Class,Age,Gender from students as a right join classes as b on a.ClassID = b.ClassID;

多表查詢,聯接4個表顯示,每位學生姓名與對應課程。

&gt; select Name,Course from students,classes,coc,courses where students.ClassID = classes.ClassID and classes.ClassID = coc.ClassID and coc.CourseID = courses.CourseID;

子查詢

要求顯示學生年齡大于平均年齡的學生姓名。

&gt; select Name from students where Age &gt; (select avg(Age) from students);

<a href="http://s3.51cto.com/wyfs02/M02/36/F3/wKioL1Or2FugMKXsAAC_x304jWk021.jpg" target="_blank"></a>

要求顯示選了沒有課程号的班級,這裡也是使用子查詢。

&gt; select ClassID from coc where CourseID not in (Select CourseID from courses);

 要求顯示大于全校平均年齡的同學的總數

 &gt; select count(Name) from students where Age &gt; (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 &gt; hellodb.sql

用sed替換MyISAM為InnoDB引擎。

# sed -i 's/ENGINE=MyISAM/ENGINE=Innodb/g' hellodb.sql

導入資料庫

# mysql -uroot -p &lt; hellodb.sql

 控制事務自動送出的變量

&gt; show global variables like 'autocommit' ;

<a href="http://s3.51cto.com/wyfs02/M00/37/21/wKioL1OsJ2_wOpR7AACHRTrzbW4447.jpg" target="_blank"></a>

啟動事務

&gt; start transaction;

手動送出指令

commit

復原指令

rollback

記錄儲存點

&gt; savepoint pp1;

復原至儲存點

&gt; rollback to pp1;

RDBMS    事務的隔離級别;

 READ-UNCOMMITTED        讀未送出

 READ-COMMITTED              讀送出

 REPEATABLE-READ            重讀

 SERIALIZABLE                        串行

&gt; show session variables like 'tx_isolation';

<a href="http://s3.51cto.com/wyfs02/M00/37/23/wKiom1OsLTDzoGVuAACdK0MehB8882.jpg" target="_blank"></a>

本文轉自qw87112 51CTO部落格,原文連結:http://blog.51cto.com/tchuairen/1430924