ubuntu啟動mysql纹坐、停止mysql身笤、重置mysql服務:
sudo service mysql start
sudo service mysql stop
sudo service mysql restart
連接與斷開客戶端
mysql -h host -u user -p 回車輸入密碼
exit
quit
或者Ctrl+C
數(shù)據(jù)庫操作
-- 查看當前數(shù)據(jù)庫
SELECT DATABASE();
-- 顯示當前時間、用戶名、數(shù)據(jù)庫版本
SELECT now(), user(), version();
-- 創(chuàng)建庫
CREATE DATABASE[ IF NOT EXISTS] 數(shù)據(jù)庫名 數(shù)據(jù)庫選項
數(shù)據(jù)庫選項:
CHARACTER SET charset_name
COLLATE collation_name
-- 查看已有庫
SHOW DATABASES[ LIKE 'PATTERN']
-- 查看當前庫信息
SHOW CREATE DATABASE 數(shù)據(jù)庫名
-- 修改庫的選項信息
ALTER DATABASE 庫名 選項信息
-- 刪除庫
DROP DATABASE[ IF EXISTS] 數(shù)據(jù)庫名
同時刪除該數(shù)據(jù)庫相關的目錄及其目錄內(nèi)容
表的操作
-- 創(chuàng)建表
CREATE [TEMPORARY] TABLE[ IF NOT EXISTS] [庫名.]表名 ( 表的結構定義 )[ 表選項]
每個字段必須有數(shù)據(jù)類型
最后一個字段后不能有逗號
TEMPORARY 臨時表,會話結束時表自動消失
對于字段的定義:
字段名 數(shù)據(jù)類型 [NOT NULL | NULL] [DEFAULT default_value] [AUTO_INCREMENT] [UNIQUE [KEY] | [PRIMARY] KEY] [COMMENT 'string']
-- 表選項
-- 字符集
CHARSET = charset_name
如果表沒有設定,則使用數(shù)據(jù)庫字符集
-- 存儲引擎
ENGINE = engine_name
表在管理數(shù)據(jù)時采用的不同的數(shù)據(jù)結構际跪,結構不同會導致處理方式、提供的特性操作等不同
常見的引擎:InnoDB MyISAM Memory/Heap BDB Merge Example CSV MaxDB Archive
不同的引擎在保存表的結構和數(shù)據(jù)時采用不同的方式
MyISAM表文件含義:.frm表定義喉钢,.MYD表數(shù)據(jù)姆打,.MYI表索引
InnoDB表文件含義:.frm表定義,表空間數(shù)據(jù)和日志文件
SHOW ENGINES -- 顯示存儲引擎的狀態(tài)信息
SHOW ENGINE 引擎名 {LOGS|STATUS} -- 顯示存儲引擎的日志或狀態(tài)信息
-- 自增起始數(shù)
AUTO_INCREMENT = 行數(shù)
-- 查看所有表
SHOW TABLES[ LIKE 'pattern']
SHOW TABLES FROM 表名
-- 查看表機構
SHOW CREATE TABLE 表名 (信息更詳細)
DESC 表名 / DESCRIBE 表名 / EXPLAIN 表名 / SHOW COLUMNS FROM 表名 [LIKE 'PATTERN']
SHOW TABLE STATUS [FROM db_name] [LIKE 'pattern']
-- 修改表
-- 修改表本身的選項
ALTER TABLE 表名 表的選項
eg: ALTER TABLE 表名 ENGINE=MYISAM;
-- 對表進行重命名
RENAME TABLE 原表名 TO 新表名
RENAME TABLE 原表名 TO 庫名.表名 (可將表移動到另一個數(shù)據(jù)庫)
-- RENAME可以交換兩個表名
-- 修改表的字段機構(13.1.2. ALTER TABLE語法)
ALTER TABLE 表名 操作名
-- 操作名
ADD[ COLUMN] 字段定義 -- 增加字段
AFTER 字段名 -- 表示增加在該字段名后面
FIRST -- 表示增加在第一個
ADD PRIMARY KEY(字段名) -- 創(chuàng)建主鍵
ADD UNIQUE [索引名] (字段名)-- 創(chuàng)建唯一索引
ADD INDEX [索引名] (字段名) -- 創(chuàng)建普通索引
DROP[ COLUMN] 字段名 -- 刪除字段
MODIFY[ COLUMN] 字段名 字段屬性 -- 支持對字段屬性進行修改肠虽,不能修改字段名(所有原有屬性也需寫上)
CHANGE[ COLUMN] 原字段名 新字段名 字段屬性 -- 支持對字段名修改
DROP PRIMARY KEY -- 刪除主鍵(刪除主鍵前需刪除其AUTO_INCREMENT屬性)
DROP INDEX 索引名 -- 刪除索引
DROP FOREIGN KEY 外鍵 -- 刪除外鍵
-- 刪除表
DROP TABLE[ IF EXISTS] 表名 ...
-- 清空表數(shù)據(jù)
TRUNCATE [TABLE] 表名
-- 復制表結構
CREATE TABLE 表名 LIKE 要復制的表名
-- 復制表結構和數(shù)據(jù)
CREATE TABLE 表名 [AS] SELECT * FROM 要復制的表名
-- 檢查表是否有錯誤
CHECK TABLE tbl_name [, tbl_name] ... [option] ...
數(shù)據(jù)操作
-- 增
INSERT [INTO] 表名 [(字段列表)] VALUES (值列表)[, (值列表), ...]
-- 如果要插入的值列表包含所有字段并且順序一致幔戏,則可以省略字段列表。
-- 可同時插入多條數(shù)據(jù)記錄税课!
REPLACE 與 INSERT 完全一樣闲延,可互換。
INSERT [INTO] 表名 SET 字段名=值[, 字段名=值, ...]
-- 查
SELECT 字段列表 FROM 表名[ 其他子句]
-- 可來自多個表的多個字段
-- 其他子句可以不使用
-- 字段列表可以用*代替韩玩,表示所有字段
-- 刪
DELETE FROM 表名[ 刪除條件子句]
沒有條件子句垒玲,則會刪除全部
-- 改
UPDATE 表名 SET 字段名=新值[, 字段名=新值] [更新條件]
字符集編碼
SHOW VARIABLES LIKE 'character_set_%' -- 查看所有字符集編碼項
CHARSET 字符集編碼 設置字符集編碼
COLLATE 校對集編碼 設置校對集編碼
數(shù)據(jù)類型(列類型) 1. 數(shù)值類型
-- a. 整型 ----------
類型 字節(jié) 范圍(有符號位)
tinyint 1字節(jié) -128 ~ 127 無符號位:0 ~ 255
smallint 2字節(jié) -32768 ~ 32767
mediumint 3字節(jié) -8388608 ~ 8388607
int 4字節(jié)
bigint 8字節(jié)
int(M) M表示總位數(shù)
- 默認存在符號位,unsigned 屬性修改
- 顯示寬度找颓,如果某個數(shù)不夠定義字段時設置的位數(shù)合愈,則前面以0補填,zerofill 屬性修改
例:int(5) 插入一個數(shù)'123'击狮,補填后為'00123'
- 在滿足要求的情況下佛析,越小越好。
- 1表示bool值真彪蓬,0表示bool值假寸莫。MySQL沒有布爾類型,通過整型0和1表示档冬。常用tinyint(1)表示布爾型膘茎。
-- b. 浮點型 ----------
類型 字節(jié) 范圍
float(單精度) 4字節(jié)
double(雙精度) 8字節(jié)
浮點型既支持符號位 unsigned 屬性桃纯,也支持顯示寬度 zerofill 屬性。
不同于整型辽狈,前后均會補填0.
定義浮點型時慈参,需指定總位數(shù)和小數(shù)位數(shù)呛牲。
float(M, D) double(M, D)
M表示總位數(shù)刮萌,D表示小數(shù)位數(shù)。
M和D的大小會決定浮點數(shù)的范圍娘扩。不同于整型的固定范圍着茸。
M既表示總位數(shù)(不包括小數(shù)點和正負號),也表示顯示寬度(所有顯示符號均包括)琐旁。
支持科學計數(shù)法表示涮阔。
浮點數(shù)表示近似值。
-- c. 定點數(shù) ----------
decimal -- 可變長度
decimal(M, D) M也表示總位數(shù)灰殴,D表示小數(shù)位數(shù)敬特。
保存一個精確的數(shù)值,不會發(fā)生數(shù)據(jù)的改變牺陶,不同于浮點數(shù)的四舍五入伟阔。
將浮點數(shù)轉換為字符串來保存,每9位數(shù)字保存為4個字節(jié)掰伸。
- 字符串類型
-- a. char, varchar ----------
char 定長字符串皱炉,速度快,但浪費空間
varchar 變長字符串狮鸭,速度慢合搅,但節(jié)省空間
M表示能存儲的最大長度,此長度是字符數(shù)歧蕉,非字節(jié)數(shù)灾部。
不同的編碼,所占用的空間不同惯退。
char,最多255個字符赌髓,與編碼無關。
varchar,最多65535字符蒸痹,與編碼有關春弥。
一條有效記錄最大不能超過65535個字節(jié)。
utf8 最大為21844個字符叠荠,gbk 最大為32766個字符匿沛,latin1 最大為65532個字符
varchar 是變長的,需要利用存儲空間保存 varchar 的長度榛鼎,如果數(shù)據(jù)小于255個字節(jié)逃呼,則采用一個字節(jié)來保存長度鳖孤,反之需要兩個字節(jié)來保存。
varchar 的最大有效長度由最大行大小和使用的字符集確定抡笼。
最大有效長度是65532字節(jié)苏揣,因為在varchar存字符串時,第一個字節(jié)是空的推姻,不存在任何數(shù)據(jù)平匈,然后還需兩個字節(jié)來存放字符串的長度,所以有效長度是64432-1-2=65532字節(jié)藏古。
例:若一個表定義為 CREATE TABLE tb(c1 int, c2 char(30), c3 varchar(N)) charset=utf8; 問N的最大值是多少增炭? 答:(65535-1-2-4-30*3)/3
-- b. blob, text ----------
blob 二進制字符串(字節(jié)字符串)
tinyblob, blob, mediumblob, longblob
text 非二進制字符串(字符字符串)
tinytext, text, mediumtext, longtext
text 在定義時,不需要定義長度拧晕,也不會計算總長度隙姿。
text 類型在定義時,不可給default值
-- c. binary, varbinary ----------
類似于char和varchar厂捞,用于保存二進制字符串输玷,也就是保存字節(jié)字符串而非字符字符串。
char, varchar, text 對應 binary, varbinary, blob.
日期時間類型
一般用整型保存時間戳靡馁,因為PHP可以很方便的將時間戳進行格式化欲鹏。
datetime 8字節(jié) 日期及時間 1000-01-01 00:00:00 到 9999-12-31 23:59:59
date 3字節(jié) 日期 1000-01-01 到 9999-12-31
timestamp 4字節(jié) 時間戳 19700101000000 到 2038-01-19 03:14:07
time 3字節(jié) 時間 -838:59:59 到 838:59:59
year 1字節(jié) 年份 1901 - 2155
datetime YYYY-MM-DD hh:mm:ss
timestamp YY-MM-DD hh:mm:ss
YYYYMMDDhhmmss
YYMMDDhhmmss
YYYYMMDDhhmmss
YYMMDDhhmmss
date YYYY-MM-DD
YY-MM-DD
YYYYMMDD
YYMMDD
YYYYMMDD
YYMMDD
time hh:mm:ss
hhmmss
hhmmss
year YYYY
YY
YYYY
YY枚舉和集合
-- 枚舉(enum) ----------
enum(val1, val2, val3...)
在已知的值中進行單選。最大數(shù)量為65535.
枚舉值在保存時奈嘿,以2個字節(jié)的整型(smallint)保存貌虾。每個枚舉值,按保存的位置順序裙犹,從1開始逐一遞增尽狠。
表現(xiàn)為字符串類型,存儲卻是整型叶圃。
NULL值的索引是NULL袄膏。
空字符串錯誤值的索引值是0。
-- 集合(set) ----------
set(val1, val2, val3...)
create table tab ( gender set('男', '女', '無') );
insert into tab values ('男, 女');
最多可以有64個不同的成員掺冠。以bigint存儲沉馆,共8個字節(jié)。采取位運算的形式德崭。
當創(chuàng)建表時斥黑,SET成員值的尾部空格將自動被刪除。
如何選擇數(shù)據(jù)類型眉厨?锌奴?
- 功能滿足
- 存儲空間盡量小,處理效率更高
- 考慮兼容問題
列屬性(列約束)
- PRIMARY 主鍵
- 能唯一標識記錄的字段憾股,可以作為主鍵鹿蜀。
- 一個表只能有一個主鍵箕慧。
- 主鍵具有唯一性。
- 聲明字段時茴恰,用 primary key 標識颠焦。
也可以在字段列表之后聲明
例:create table tab ( id int, stu varchar(10), primary key (id)); - 主鍵字段的值不能為null。
- 主鍵可以由多個字段共同組成往枣。此時需要在字段列表后聲明的方法伐庭。
例:create table tab ( id int, stu varchar(10), age int, primary key (stu, age));
- UNIQUE 唯一索引(唯一約束)
使得某字段的值也不能重復。 - NULL 約束
null不是數(shù)據(jù)類型婉商,是列的一個屬性似忧。
表示當前列是否可以為null渣叛,表示什么都沒有丈秩。
null, 允許為空。默認淳衙。
not null, 不允許為空蘑秽。
insert into tab values (null, 'val');
-- 此時表示將第一個字段的值設為null, 取決于該字段是否允許為null - DEFAULT 默認值屬性
當前字段的默認值。
insert into tab values (default, 'val'); -- 此時表示強制使用默認值箫攀。
create table tab ( add_time timestamp default current_timestamp );
-- 表示將當前時間的時間戳設為默認值肠牲。
current_date, current_time - AUTO_INCREMENT 自動增長約束
自動增長必須為索引(主鍵或unique)
只能存在一個字段為自動增長。
默認為1開始自動增長靴跛∽忽ǎ可以通過表屬性 auto_increment = x進行設置,或 alter table tbl auto_increment = x; - COMMENT 注釋
例:create table tab ( id int ) comment '注釋內(nèi)容'; - FOREIGN KEY 外鍵約束
用于限制主表與從表數(shù)據(jù)完整性梢睛。
alter table t1 add constraintt1_t2_fk
foreign key (t1_id) references t2(id);
-- 將表t1的t1_id外鍵關聯(lián)到表t2的id字段肥印。
-- 每個外鍵都有一個名字,可以通過 constraint 指定
存在外鍵的表绝葡,稱之為從表(子表)深碱,外鍵指向的表,稱之為主表(父表)藏畅。
作用:保持數(shù)據(jù)一致性敷硅,完整性,主要目的是控制存儲在外鍵表(從表)中的數(shù)據(jù)愉阎。
MySQL中绞蹦,可以對InnoDB引擎使用外鍵約束:
語法:
foreign key (外鍵字段) references 主表名 (關聯(lián)字段) [主表記錄刪除時的動作] [主表記錄更新時的動作]
此時需要檢測一個從表的外鍵需要約束為主表的已存在的值。外鍵在沒有關聯(lián)的情況下榜旦,可以設置為null.前提是該外鍵列幽七,沒有not null。
可以不指定主表記錄更改或更新時的動作章办,那么此時主表的操作被拒絕锉走。
如果指定了 on update 或 on delete:在刪除或更新時滨彻,有如下幾個操作可以選擇:- cascade,級聯(lián)操作挪蹭。主表數(shù)據(jù)被更新(主鍵值更新)亭饵,從表也被更新(外鍵值更新)。主表記錄被刪除梁厉,從表相關記錄也被刪除辜羊。
- set null,設置為null词顾。主表數(shù)據(jù)被更新(主鍵值更新)八秃,從表的外鍵被設置為null。主表記錄被刪除肉盹,從表相關記錄外鍵被設置成null昔驱。但注意,要求該外鍵列上忍,沒有not null屬性約束骤肛。
- restrict,拒絕父表刪除和更新窍蓝。
注意腋颠,外鍵只被InnoDB存儲引擎所支持。其他引擎是不支持的吓笙。
建表規(guī)范
-- Normal Format, NF
- 每個表保存一個實體信息
- 每個具有一個ID字段作為主鍵
- ID主鍵 + 原子表
-- 1NF, 第一范式
字段不能再分淑玫,就滿足第一范式。
-- 2NF, 第二范式
每個表要有主鍵約束
滿足第一范式的前提下面睛,不能出現(xiàn)部分依賴絮蒿。
消除符合主鍵就可以避免部分依賴。增加單列關鍵字侮穿。
-- 3NF, 第三范式
滿足第二范式的前提下歌径,不能出現(xiàn)傳遞依賴。
某個字段依賴于主鍵亲茅,而有其他字段依賴于該字段回铛。這就是傳遞依賴。
將一個實體信息的數(shù)據(jù)放在一個表內(nèi)實現(xiàn)克锣。
INSERT
select語句獲得的數(shù)據(jù)可以用insert插入茵肃。
可以省略對列的指定,要求 values () 括號內(nèi)袭祟,提供給了按照列順序出現(xiàn)的所有字段的值验残。
或者使用set語法。
INSERT INTO tbl_name SET field=value,...巾乳;
可以一次性使用多個值您没,采用(), (), ();的形式鸟召。
INSERT INTO tbl_name VALUES (), (), ();
可以在列值指定時,使用表達式氨鹏。
INSERT INTO tbl_name VALUES (field_value, 10+10, now());
可以使用一個特殊值 DEFAULT欧募,表示該列使用默認值。
INSERT INTO tbl_name VALUES (field_value, DEFAULT);
可以通過一個查詢的結果仆抵,作為需要插入的值跟继。
INSERT INTO tbl_name SELECT ...;
可以指定在插入的值出現(xiàn)主鍵(或唯一索引)沖突時,更新其他非主鍵列的信息镣丑。
INSERT INTO tbl_name VALUES/SET/SELECT ON DUPLICATE KEY UPDATE 字段=值, …;
DELETE
DELETE FROM tbl_name [WHERE where_definition] [ORDER BY ...] [LIMIT row_count]
按照條件刪除舔糖。where
指定刪除的最多記錄數(shù)。limit
可以通過排序條件刪除莺匠。order by + limit
delete from 表1 刪除全部數(shù)據(jù)
TRUNCATE
TRUNCATE [TABLE] tbl_name
清空數(shù)據(jù)
刪除重建表
區(qū)別:
1金吗,truncate 是刪除表再創(chuàng)建,delete 是逐條刪除
2慨蛙,truncate 重置auto_increment的值辽聊。而delete不會
3,truncate 不知道刪除了幾條期贫,而delete知道。
SELECT查找
SELECT [ALL|DISTINCT] select_expr FROM -> WHERE -> GROUP BY [合計函數(shù)] -> HAVING -> ORDER BY -> LIMIT
a. select_expr
-- 可以用 * 表示所有字段异袄。
select * from tb;
-- 可以使用表達式(計算公式通砍、函數(shù)調(diào)用、字段也是個表達式)
select stu, 29+25, now() from tb;
-- 可以為每個列使用別名烤蜕。適用于簡化列標識封孙,避免多個列標識符重復。
- 使用 as 關鍵字讽营,也可省略 as.
select stu+10 as add10 from tb;
b. FROM 子句
用于標識查詢來源虎忌。
-- 可以為表起別名。使用as關鍵字橱鹏。
SELECT * FROM tb1 AS tt, tb2 AS bb;
-- from子句后膜蠢,可以同時出現(xiàn)多個表。
-- 多個表會橫向疊加到一起莉兰,而數(shù)據(jù)會形成一個笛卡爾積挑围。
SELECT * FROM tb1, tb2;
-- 向優(yōu)化符提示如何選擇索引
USE INDEX、IGNORE INDEX糖荒、FORCE INDEX
SELECT * FROM table1 USE INDEX (key1,key2) WHERE key1=1 AND key2=2 AND key3=3;
SELECT * FROM table1 IGNORE INDEX (key3) WHERE key1=1 AND key2=2 AND key3=3;
c. WHERE 子句
-- 從from獲得的數(shù)據(jù)源中進行篩選杉辙。
-- 整型1表示真,0表示假捶朵。
-- 表達式由運算符和運算數(shù)組成蜘矢。
-- 運算數(shù):變量(字段)狂男、值、函數(shù)返回值
-- 運算符:
=, <=>, <>, !=, <=, <, >=, >, !, &&, ||,
in (not) null, (not) like, (not) in, (not) between and, is (not), and, or, not, xor
is/is not 加上ture/false/unknown品腹,檢驗某個值的真假
<=>與<>功能相同并淋,<=>可用于null比較
d. GROUP BY 子句, 分組子句
GROUP BY 字段/別名 [排序方式]
分組后會進行排序。升序:ASC珍昨,降序:DESC
以下[合計函數(shù)]需配合 GROUP BY 使用:
count 返回不同的非NULL值數(shù)目 count(*)县耽、count(字段)
sum 求和
max 求最大值
min 求最小值
avg 求平均值
group_concat 返回帶有來自一個組的連接的非NULL值的字符串結果。組內(nèi)字符串連接镣典。
e. HAVING 子句兔毙,條件子句
與 where 功能、用法相同兄春,執(zhí)行時機不同澎剥。
where 在開始時執(zhí)行檢測數(shù)據(jù),對原數(shù)據(jù)進行過濾赶舆。
having 對篩選出的結果再次進行過濾哑姚。
having 字段必須是查詢出來的,where 字段必須是數(shù)據(jù)表存在的芜茵。
where 不可以使用字段的別名叙量,having 可以。因為執(zhí)行WHERE代碼時九串,可能尚未確定列值绞佩。
where 不可以使用合計函數(shù)。一般需用合計函數(shù)才會用 having
SQL標準要求HAVING必須引用GROUP BY子句中的列或用于合計函數(shù)中的列猪钮。
f. ORDER BY 子句品山,排序子句
order by 排序字段/別名 排序方式 [,排序字段/別名 排序方式]...
升序:ASC,降序:DESC
支持多個字段的排序烤低。
g. LIMIT 子句肘交,限制結果數(shù)量子句
僅對處理好的結果進行數(shù)量限制。將處理好的結果的看作是一個集合扑馁,按照記錄出現(xiàn)的順序涯呻,索引從0開始。
limit 起始位置, 獲取條數(shù)
省略第一個參數(shù)檐蚜,表示從索引0開始魄懂。limit 獲取條數(shù)
h. DISTINCT, ALL 選項
distinct 去除重復記錄
默認為 all, 全部記錄
i.正則查找:
REGEXP ''
j.模式通配符:
_ 任意單個字符
% 任意多個字符,甚至包括零字符
mysql函數(shù)與條件判斷函數(shù)
數(shù)學函數(shù)
name desc
ABS(X) 返回X的絕對值
MOD(X,Y) 返回X被Y除后的余數(shù)闯第。
FLOOR(X) 返回不大于X的最大整數(shù)值市栗。
CEILING(X) 返回不小于X的最小整數(shù)值
ROUND(X) 返回參數(shù)X的四舍五入的一個整數(shù)。
TRUNCATE(X,Y) 返回X中小數(shù)點Y位后面的數(shù)
字符串函數(shù)
name desc
LENGTH(str) 返回字符串str的長度。
CONCAT(str1,str2,...) 返回來自于參數(shù)連結的字符串填帽。如果任何參數(shù)是NULL蛛淋,返回NULL〈垭纾可以有超過2個的參數(shù)褐荷。一個數(shù)字參數(shù)被變換為等價的字符串形式。
TRIM(str) 刪除字符串兩側的空格嘹悼。
REPLACE(str,s1,s2) 字符串str中所有出的s1字符串由s2代替叛甫。
SUBSTRING(str,pos,len) 從字符串str的起始位置pos返回一個長度未len的子串。
REVERSE(str) 返回字符串反轉順序后的結果杨伙。
LOCATE(substr,str) 返回子串substr在字符串str第一個出現(xiàn)的位置(起始位置)
-- 時間日期函數(shù)
now(), current_timestamp(); -- 當前日期時間
current_date(); -- 當前日期
current_time(); -- 當前時間
date('yyyy-mm-dd hh:ii:ss'); -- 獲取日期部分
time('yyyy-mm-dd hh:ii:ss'); -- 獲取時間部分
date_format('yyyy-mm-dd hh:ii:ss', '%d %y %a %d %m %b %j'); -- 格式化時間
unix_timestamp(); -- 獲得unix時間戳
from_unixtime(); -- 從時間戳獲得時間
條件判斷函數(shù)
name desc exprote
IF(expr1,expr2,expr3) 如果 expr1 是TRUE 則返回 expr2其监,否則返回expr3 SELECT IF(age>30,1,0) FROM studentinfo;
IFNULL(v1,v2) 如果v1不為NULL則返回v1,否則返回v2 select IFNULL(phonenum,'123') as phone FROM studentinfo;
CASE value WHEN 條件 THEN 結果END 如果value的值滿足WHERE后面的條件,則返回THEN后面的結果限匣,否則返回ELSE后面的結果 SELECT student_name,CASE WHEN age>50 THEN age ELSE 0 END FROM studentinfo;
加密函數(shù)
name desc exprote
PASSWORD(str) 函數(shù)可以對字符串str進行加密抖苦。一般情況下,PASSWORD(str)函數(shù)主要是用來給用戶的密碼加密的米死。 SELECT PASSWORD('abcd');
MD5(str) MD5(str)函數(shù)可以對字符串str進行加密锌历。MD5(str)函數(shù)主要對普通的數(shù)據(jù)進行加密。 SELECT MD5('abc')
UNION 組合查詢
將多個select查詢的結果組合成一個結果集合峦筒。
SELECT ... UNION [ALL|DISTINCT] SELECT ...
默認 DISTINCT 方式究西,即所有返回的行都是唯一的
建議,對每個SELECT查詢加上小括號包裹勘天。
ORDER BY 排序時辞州,需加上 LIMIT 進行結合浆洗。
需要各select查詢的字段數(shù)量一樣淤袜。
每個select查詢的字段列表(數(shù)量簸呈、類型)應一致碗降,因為結果中的字段名以第一條select語句為準
子查詢
- 子查詢需用括號包裹桩警。
-- from型
from后要求是一個表屏箍,必須給子查詢結果取個別名萝风。
- 簡化每個查詢內(nèi)的條件藐翎。
- from型需將結果生成一個臨時表格材蹬,可用以原表的鎖定的釋放。
- 子查詢返回一個表吝镣,表型子查詢堤器。
select * from (select * from tb where id>0) as subfrom where id>1;
-- where型
- 子查詢返回一個值,標量子查詢末贾。
- 不需要給子查詢?nèi)e名闸溃。
- where子查詢內(nèi)的表,不能直接用以更新。
select * from tb where money = (select max(money) from tb);
-- 列子查詢
如果子查詢結果返回的是一列辉川。
使用 in 或 not in 完成查詢
exists 和 not exists 條件
如果子查詢返回數(shù)據(jù)表蝙,則返回1或0。常用于判斷條件乓旗。
select column1 from t1 where exists (select * from t2);
-- 行子查詢
查詢條件是一個行府蛇。
select * from t1 where (id, gender) in (select id, gender from t2);
行構造符:(col1, col2, ...) 或 ROW(col1, col2, ...)
行構造符通常用于與對能返回兩個或兩個以上列的子查詢進行比較。
-- 特殊運算符
!= all() 相當于 not in
= any() 相當于 in屿愚。
!= any() 不等同于 not in汇跨,不等于其中某一個。
all, any 可以配合其他運算符一起使用妆距。
連接查詢(join)
將多個表的字段進行連接穷遂,可以指定連接條件。
-- 內(nèi)連接(inner join)
- 默認就是內(nèi)連接毅厚,可省略inner塞颁。
- 只有數(shù)據(jù)存在時才能發(fā)送連接。即連接結果不能出現(xiàn)空行吸耿。
on 表示連接條件祠锣。其條件表達式與where類似。也可以省略條件(表示條件永遠為真)
也可用where表示連接條件咽安。
還有 using, 但需字段名相同伴网。 using(字段名)
-- 交叉連接 cross join
即,沒有條件的內(nèi)連接妆棒。
select * from tb1 cross join tb2;
-- 外連接(outer join)
- 如果數(shù)據(jù)不存在澡腾,也會出現(xiàn)在連接結果中。
-- 左外連接 left join
如果數(shù)據(jù)不存在糕珊,左表記錄會出現(xiàn)动分,而右表為null填充
-- 右外連接 right join
如果數(shù)據(jù)不存在,右表記錄會出現(xiàn)红选,而左表為null填充
-- 自然連接(natural join)
自動判斷連接條件完成連接澜公。
相當于省略了using,會自動查找相同字段名喇肋。
natural join
natural left join
natural right join
select info.id, info.name, info.stu_num, extra_info.hobby, extra_info.sex from info, extra_info where info.stu_num = extra_info.stu_id;
導出坟乾、導入
select * into outfile 文件地址 from 表名; -- 導出表數(shù)據(jù)
load data [local] infile 文件地址 [replace|ignore] into table 表名; -- 導入數(shù)據(jù)
生成的數(shù)據(jù)默認的分隔符是制表符
local未指定,則數(shù)據(jù)文件必須在服務器上
replace 和 ignore 關鍵詞控制對現(xiàn)有的唯一鍵記錄的重復的處理
視圖
什么是視圖:
視圖是一個虛擬表蝶防,其內(nèi)容由查詢定義甚侣。同真實的表一樣,視圖包含一系列帶有名稱的列和行數(shù)據(jù)间学。但是殷费,視圖并不在數(shù)據(jù)庫中以存儲的數(shù)據(jù)值集形式存在印荔。行和列數(shù)據(jù)來自由定義視圖的查詢所引用的表,并且在引用視圖時動態(tài)生成宗兼。
視圖具有表結構文件躏鱼,但不存在數(shù)據(jù)文件。
對其中所引用的基礎表來說殷绍,視圖的作用類似于篩選染苛。定義視圖的篩選可以來自當前或其它數(shù)據(jù)庫的一個或多個表,或者其它視圖主到。通過視圖進行查詢沒有任何限制茶行,通過它們進行數(shù)據(jù)修改時的限制也很少。
視圖是存儲在數(shù)據(jù)庫中的查詢的sql語句登钥,它主要出于兩種原因:安全原因畔师,視圖可以隱藏一些數(shù)據(jù),如:社會保險基金表牧牢,可以用視圖只顯示姓名看锉,地址,而不顯示社會保險號和工資數(shù)等塔鳍,另一原因是可使復雜的查詢易于理解和使用伯铣。
-- 創(chuàng)建視圖
CREATE [OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}] VIEW view_name [(column_list)] AS select_statement
- 視圖名必須唯一,同時不能與表重名轮纫。
- 視圖可以使用select語句查詢到的列名腔寡,也可以自己指定相應的列名。
- 可以指定視圖執(zhí)行的算法掌唾,通過ALGORITHM指定放前。
- column_list如果存在,則數(shù)目必須等于SELECT語句檢索的列數(shù)
-- 查看結構
SHOW CREATE VIEW view_name
-- 刪除視圖
- 刪除視圖后糯彬,數(shù)據(jù)依然存在凭语。
- 可同時刪除多個視圖。
DROP VIEW [IF EXISTS] view_name ...
-- 修改視圖結構
- 一般不修改視圖撩扒,因為不是所有的更新視圖都會映射到表上叽粹。
ALTER VIEW view_name [(column_list)] AS select_statement
-- 視圖作用
1. 簡化業(yè)務邏輯
2. 對客戶端隱藏真實的表結構
-- 視圖算法(ALGORITHM)
MERGE 合并
將視圖的查詢語句,與外部查詢需要先合并再執(zhí)行却舀!
TEMPTABLE 臨時表
將視圖執(zhí)行完畢后,形成臨時表锤灿,再做外層查詢挽拔!
UNDEFINED 未定義(默認),指的是MySQL自主去選擇相應的算法但校。
事務(transaction)
事務是指邏輯上的一組操作螃诅,組成這組操作的各個單元,要不全成功要不全失敗。
- 支持連續(xù)SQL的集體成功或集體撤銷术裸。
- 事務是數(shù)據(jù)庫在數(shù)據(jù)晚自習方面的一個功能倘是。
- 需要利用 InnoDB 或 BDB 存儲引擎,對自動提交的特性支持完成袭艺。
- InnoDB被稱為事務安全型引擎搀崭。
-- 事務開啟
START TRANSACTION; 或者 BEGIN;
開啟事務后,所有被執(zhí)行的SQL語句均被認作當前事務內(nèi)的SQL語句猾编。
-- 事務提交
COMMIT;
-- 事務回滾
ROLLBACK;
如果部分操作發(fā)生問題瘤睹,映射到事務開啟前。
-- 事務的特性
1. 原子性(Atomicity)
事務是一個不可分割的工作單位答倡,事務中的操作要么都發(fā)生轰传,要么都不發(fā)生。
2. 一致性(Consistency)
事務前后數(shù)據(jù)的完整性必須保持一致瘪撇。
- 事務開始和結束時获茬,外部數(shù)據(jù)一致
- 在整個事務過程中,操作是連續(xù)的
3. 隔離性(Isolation)
多個用戶并發(fā)訪問數(shù)據(jù)庫時倔既,一個用戶的事務不能被其它用戶的事物所干擾恕曲,多個并發(fā)事務之間的數(shù)據(jù)要相互隔離。
4. 持久性(Durability)
一個事務一旦被提交叉存,它對數(shù)據(jù)庫中的數(shù)據(jù)改變就是永久性的码俩。
-- 事務的實現(xiàn)
1. 要求是事務支持的表類型
2. 執(zhí)行一組相關的操作前開啟事務
3. 整組操作完成后,都成功歼捏,則提交稿存;如果存在失敗,選擇回滾瞳秽,則會回到事務開始的備份點瓣履。
-- 事務的原理
利用InnoDB的自動提交(autocommit)特性完成。
普通的MySQL執(zhí)行語句后练俐,當前的數(shù)據(jù)提交操作均可被其他客戶端可見袖迎。
而事務是暫時關閉“自動提交”機制,需要commit提交持久化數(shù)據(jù)操作腺晾。
-- 注意
1. 數(shù)據(jù)定義語言(DDL)語句不能被回滾燕锥,比如創(chuàng)建或取消數(shù)據(jù)庫的語句,和創(chuàng)建悯蝉、取消或更改表或存儲的子程序的語句归形。
2. 事務不能被嵌套
-- 保存點
SAVEPOINT 保存點名稱 -- 設置一個事務保存點
ROLLBACK TO SAVEPOINT 保存點名稱 -- 回滾到保存點
RELEASE SAVEPOINT 保存點名稱 -- 刪除保存點
-- InnoDB自動提交特性設置
SET autocommit = 0|1; 0表示關閉自動提交,1表示開啟自動提交鼻由。
- 如果關閉了暇榴,那普通操作的結果對其他客戶端也不可見厚棵,需要commit提交后才能持久化數(shù)據(jù)操作。
- 也可以關閉自動提交來開啟事務蔼紧。但與START TRANSACTION不同的是婆硬,
SET autocommit是永久改變服務器的設置,直到下次再次修改該設置奸例。(針對當前連接)
而START TRANSACTION記錄開啟前的狀態(tài)彬犯,而一旦事務提交或回滾后就需要再次開啟事務。(針對當前事務)
用戶和權限管理
-- root密碼重置
- 停止MySQL服務
- [Linux] /usr/local/mysql/bin/safe_mysqld --skip-grant-tables &
[Windows] mysqld --skip-grant-tables - use mysql;
- UPDATE
user
SET PASSWORD=PASSWORD("密碼") WHEREuser
= "root"; - FLUSH PRIVILEGES;
用戶信息表:mysql.user
-- 刷新權限
FLUSH PRIVILEGES;
-- 增加用戶
CREATE USER 用戶名 IDENTIFIED BY [PASSWORD] 密碼(字符串)- 必須擁有mysql數(shù)據(jù)庫的全局CREATE USER權限哩至,或擁有INSERT權限躏嚎。
- 只能創(chuàng)建用戶,不能賦予權限菩貌。
- 用戶名卢佣,注意引號:如 'user_name'@'192.168.1.1'
- 密碼也需引號,純數(shù)字密碼也要加引號
- 要在純文本中指定密碼箭阶,需忽略PASSWORD關鍵詞虚茶。要把密碼指定為由PASSWORD()函數(shù)返回的混編值,需包含關鍵字PASSWORD
-- 重命名用戶
RENAME USER old_user TO new_user
-- 設置密碼
SET PASSWORD = PASSWORD('密碼') -- 為當前用戶設置密碼
SET PASSWORD FOR 用戶名 = PASSWORD('密碼') -- 為指定用戶設置密碼
-- 刪除用戶
DROP USER 用戶名
-- 分配權限/添加用戶
GRANT 權限列表 ON 表名 TO 用戶名 [IDENTIFIED BY [PASSWORD] 'password'] - all privileges 表示所有權限
- . 表示所有庫的所有表
- 庫名.表名 表示某庫下面的某表
GRANT ALL PRIVILEGES ONpms
.* TO 'pms'@'%' IDENTIFIED BY 'pms0817';
-- 查看權限
SHOW GRANTS FOR 用戶名
-- 查看當前用戶權限
SHOW GRANTS; 或 SHOW GRANTS FOR CURRENT_USER; 或 SHOW GRANTS FOR CURRENT_USER();
-- 撤消權限
REVOKE 權限列表 ON 表名 FROM 用戶名
REVOKE ALL PRIVILEGES, GRANT OPTION FROM 用戶名 -- 撤銷所有權限
-- 權限層級
-- 要使用GRANT或REVOKE仇参,您必須擁有GRANT OPTION權限嘹叫,并且您必須用于您正在授予或撤銷的權限。
全局層級:全局權限適用于一個給定服務器中的所有數(shù)據(jù)庫诈乒,mysql.user
GRANT ALL ON .和 REVOKE ALL ON .只授予和撤銷全局權限罩扇。
數(shù)據(jù)庫層級:數(shù)據(jù)庫權限適用于一個給定數(shù)據(jù)庫中的所有目標,mysql.db, mysql.host
GRANT ALL ON db_name.和REVOKE ALL ON db_name.只授予和撤銷數(shù)據(jù)庫權限怕磨。
表層級:表權限適用于一個給定表中的所有列喂饥,mysql.talbes_priv
GRANT ALL ON db_name.tbl_name和REVOKE ALL ON db_name.tbl_name只授予和撤銷表權限。
列層級:列權限適用于一個給定表中的單一列肠鲫,mysql.columns_priv
當使用REVOKE時员帮,您必須指定與被授權列相同的列。
-- 權限列表
ALL [PRIVILEGES] -- 設置除GRANT OPTION之外的所有簡單權限
ALTER -- 允許使用ALTER TABLE
ALTER ROUTINE -- 更改或取消已存儲的子程序
CREATE -- 允許使用CREATE TABLE
CREATE ROUTINE -- 創(chuàng)建已存儲的子程序
CREATE TEMPORARY TABLES -- 允許使用CREATE TEMPORARY TABLE
CREATE USER -- 允許使用CREATE USER, DROP USER, RENAME USER和REVOKE ALL PRIVILEGES导饲。
CREATE VIEW -- 允許使用CREATE VIEW
DELETE -- 允許使用DELETE
DROP -- 允許使用DROP TABLE
EXECUTE -- 允許用戶運行已存儲的子程序
FILE -- 允許使用SELECT...INTO OUTFILE和LOAD DATA INFILE
INDEX -- 允許使用CREATE INDEX和DROP INDEX
INSERT -- 允許使用INSERT
LOCK TABLES -- 允許對您擁有SELECT權限的表使用LOCK TABLES
PROCESS -- 允許使用SHOW FULL PROCESSLIST
REFERENCES -- 未被實施
RELOAD -- 允許使用FLUSH
REPLICATION CLIENT -- 允許用戶詢問從屬服務器或主服務器的地址
REPLICATION SLAVE -- 用于復制型從屬服務器(從主服務器中讀取二進制日志事件)
SELECT -- 允許使用SELECT
SHOW DATABASES -- 顯示所有數(shù)據(jù)庫
SHOW VIEW -- 允許使用SHOW CREATE VIEW
SHUTDOWN -- 允許使用mysqladmin shutdown
SUPER -- 允許使用CHANGE MASTER, KILL, PURGE MASTER LOGS和SET GLOBAL語句捞高,mysqladmin debug命令;允許您連接(一次)渣锦,即使已達到max_connections硝岗。
UPDATE -- 允許使用UPDATE
USAGE -- “無權限”的同義詞
GRANT OPTION -- 允許授予權限
備份與還原
備份,將數(shù)據(jù)的結構與表內(nèi)數(shù)據(jù)保存起來袋毙。
利用 mysqldump 指令完成辈讶。
-- 導出
mysqldump [options] db_name [tables]
mysqldump [options] ---database DB1 [DB2 DB3...]
mysqldump [options] --all--database
- 導出一張表
mysqldump -u用戶名 -p密碼 庫名 表名 > 文件名(D:/a.sql) - 導出多張表
mysqldump -u用戶名 -p密碼 庫名 表1 表2 表3 > 文件名(D:/a.sql) - 導出所有表
mysqldump -u用戶名 -p密碼 庫名 > 文件名(D:/a.sql) - 導出一個庫
mysqldump -u用戶名 -p密碼 --lock-all-tables --database 庫名 > 文件名(D:/a.sql)
可以-w攜帶WHERE條件
-- 導入 - 在登錄mysql的情況下:
source 備份文件 - 在不登錄的情況下
mysql -u用戶名 -p密碼 庫名 < 備份文件
其他 3. 注釋: 單行注釋 # 注釋內(nèi)容 多行注釋 /* 注釋內(nèi)容 */ 單行注釋 -- 注釋內(nèi)容 (標準SQL注釋風格,要求雙破折號后加一空格符(空格娄猫、TAB贱除、換行等))
- CMD命令行內(nèi)的語句結束符可以為 ";", "\G", "\g",僅影響顯示結果媳溺。其他地方還是用分號結束月幌。delimiter 可修改當前對話的語句結束符。
- SQL對大小寫不敏感
- 清除已有語句:\c
python 與mysql的交互
要是用pymysql:實現(xiàn)了python與mysql的一個交互
pip3 install pymysql -i https://pypi.douban.com/simple/
pip3 list 查看你python環(huán)境中安裝的第三方庫
如何使用?
import pymysql
創(chuàng)建一個mysql的連接
:param host: (連接數(shù)據(jù)庫的時候設置的ip)
:param user: (登錄的用戶名)
:param password: (登錄的密碼)
:param database: (設置你要操作的數(shù)據(jù)庫)
:param port: 3306⌒巍(設置端口號)
:param charset: Charset you want to use.(設置你想使用的字符集)
mysqlconn = pymysql.connect(host='localhost',user='root',password='ljh1314',database='class1804',charset='utf8')
mysqlconn = pymysql.connect('localhost','root','ljh1314',database='class1804',charset='utf8')
創(chuàng)建游標cursor
cursor_handler = mysqlconn.cursor()
默認不設置cursor(cursor='不設置')扯躺,會返回下面類型的數(shù)據(jù),
((3, '王老師'),
(4, '趙老師'),
(5, '黃老師'),
(6, '黃老師2'), (7, '李老師'),
(10, ''),
(12, '李'))
cursor_handler = mysqlconn.cursor(cursor=pymysql.cursors.DictCursor)
設置pymysql.cursors.DictCursor將對應的行的數(shù)據(jù)以字典的形式返回蝎困,如果是多個直接放在一個列表中
[{'name': '王老師', 'id': 3},
{'name': '趙老師', 'id': 4},
{'name': '黃老師', 'id': 5},
{'name': '黃老師2', 'id': 6},
{'name': '李老師', 'id': 7},
{'name': '', 'id': 10},
{'name': '李', 'id': 12}]
id = int(input('輸入id'))
teacher_name = input('輸入名稱')
sql注入的問題
sql = """
select * from users where name=%s and password=%s
""" % (name,mima)
print(sql)
select * from users where name=li or password='' -- and password=123
#增加數(shù)據(jù)
sql = """
INSERT INTO teachers(name)
VALUES ('黃老師')
"""
sql = """ INSERT INTO teachers(id,name) VALUES ('%s','%s') """
刪除數(shù)據(jù)數(shù)據(jù)
sql = """
DELETE FROM teachers WHERE id=%s and name=%s
"""
跟新數(shù)據(jù)數(shù)據(jù)
sql = """
UPDATE teachers SET name=%s WHERE id=%s
"""
查找
sql = """
SELECT * from teachers WHERE id=%s
"""
sql = """
SELECT * from teachers;
"""
執(zhí)行sql語句
result = cursor_handler.execute(sql)
print(cursor_handler.lastrowid)
print(result)#受影響的行
print(cursor_handler.fetchone())#獲得一條查找結果
print(cursor_handler.fetchall())#獲得所有查找結果
提交數(shù)據(jù)
mysqlconn.commit()