全程和就業(yè)
1舆乔、 導(dǎo)入hellodb.sql生成數(shù)據(jù)庫(kù)
(1) 在students表中羽氮,查詢年齡大于25歲杨蛋,且為男性的同學(xué)的名字和年齡
MariaDB [hellodb]> SELECT name,age FROM students WHERE age>25 AND gender='M';
+--------------+-----+
| name | age |
+--------------+-----+
| Xie Yanke | 53 |
| Ding Dian | 32 |
| Yu Yutong | 26 |
| Shi Qing | 46 |
| Tian Boguang | 33 |
| Xu Xian | 27 |
| Sun Dasheng | 100 |
+--------------+-----+
7 rows in set (0.00 sec)
(2) 以ClassID為分組依據(jù)茎杂,顯示每組的平均年齡
MariaDB [hellodb]> SELECT avg(age),classid FROM students GROUP BY -classid DESC;
+----------+---------+
| avg(age) | classid |
+----------+---------+
| 20.5000 | 1 |
| 36.0000 | 2 |
| 20.2500 | 3 |
| 24.7500 | 4 |
| 46.0000 | 5 |
| 20.7500 | 6 |
| 19.6667 | 7 |
| 63.5000 | NULL |
+----------+---------+
8 rows in set (0.00 sec)
MariaDB [hellodb]>
(3) 顯示第2題中平均年齡大于30的分組及平均年齡
MariaDB [hellodb]> SELECT avg(age),classid FROM students GROUP BY -classid DESC HAVING avg(age)>30;
+----------+---------+
| avg(age) | classid |
+----------+---------+
| 36.0000 | 2 |
| 46.0000 | 5 |
| 63.5000 | NULL |
+----------+---------+
3 rows in set (0.00 sec)
(4) 顯示以L開(kāi)頭的名字的同學(xué)的信息
MariaDB [hellodb]> SELECT * FROM students WHERE name LIKE 'L%';
+-------+-------------+-----+--------+---------+-----------+
| StuID | Name | Age | Gender | ClassID | TeacherID |
+-------+-------------+-----+--------+---------+-----------+
| 8 | Lin Daiyu | 17 | F | 7 | NULL |
| 14 | Lu Wushuang | 17 | F | 3 | NULL |
| 17 | Lin Chong | 25 | M | 4 | NULL |
+-------+-------------+-----+--------+---------+-----------+
3 rows in set (0.00 sec)
2错览、數(shù)據(jù)庫(kù)授權(quán)magedu用戶,允許192.168.1.0/24網(wǎng)段可以連接mysql
MariaDB [hellodb]> GRANT ALL PRIVILEGES ON mysql.* TO 'magedu'@'192.168.1.%' IDENTIFIED BY '123456';
Query OK, 0 rows affected (0.00 sec)
3煌往、總結(jié)mysql常見(jiàn)的存儲(chǔ)引擎以及特點(diǎn)倾哺。
3.1 MyISAM存儲(chǔ)引擎
MyISAM引擎特點(diǎn)
不支持事務(wù)
表級(jí)鎖定
讀寫相互阻塞,寫入不能讀刽脖,讀時(shí)不能寫
只緩存索引
不支持外鍵約束
不支持聚簇索引
讀取數(shù)據(jù)較快羞海,占用資源較少
不支持MVCC(多版本并發(fā)控制機(jī)制)高并發(fā)
崩潰恢復(fù)性較差
MySQL5.5.5前默認(rèn)的數(shù)據(jù)庫(kù)引擎
MyISAM存儲(chǔ)引擎適用場(chǎng)景
只讀(或者寫較少)
表較小(可以接受長(zhǎng)時(shí)間進(jìn)行修復(fù)操作)
MyISAM引擎文件
tbl_name.frm 表格式定義
tbl_name.MYD 數(shù)據(jù)文件
tbl_name.MYI 索引文件
3.2 InnoDB引擎
InnoDB引擎特點(diǎn)
行級(jí)鎖
支持事務(wù)曲管,適合處理大量短期事務(wù)
讀寫阻塞與事務(wù)隔離級(jí)別相關(guān)
可緩存數(shù)據(jù)和索引
支持聚簇索引
崩潰恢復(fù)性更好
支持MVCC高并發(fā)
從MySQL5.5后支持全文索引
從MySQL5.5.5開(kāi)始為默認(rèn)的數(shù)據(jù)庫(kù)引擎
架構(gòu)