MYSQL總結

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é)掰伸。

  1. 字符串類型

-- 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.

  1. 日期時間類型
    一般用整型保存時間戳靡馁,因為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

  2. 枚舉和集合

-- 枚舉(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ù)類型眉厨?锌奴?

  1. 功能滿足
  2. 存儲空間盡量小,處理效率更高
  3. 考慮兼容問題

列屬性(列約束)

  1. 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));
  2. UNIQUE 唯一索引(唯一約束)
    使得某字段的值也不能重復。
  3. NULL 約束
    null不是數(shù)據(jù)類型婉商,是列的一個屬性似忧。
    表示當前列是否可以為null渣叛,表示什么都沒有丈秩。
    null, 允許為空。默認淳衙。
    not null, 不允許為空蘑秽。
    insert into tab values (null, 'val');
    -- 此時表示將第一個字段的值設為null, 取決于該字段是否允許為null
  4. DEFAULT 默認值屬性
    當前字段的默認值。
    insert into tab values (default, 'val'); -- 此時表示強制使用默認值箫攀。
    create table tab ( add_time timestamp default current_timestamp );
    -- 表示將當前時間的時間戳設為默認值肠牲。
    current_date, current_time
  5. AUTO_INCREMENT 自動增長約束
    自動增長必須為索引(主鍵或unique)
    只能存在一個字段為自動增長。
    默認為1開始自動增長靴跛∽忽ǎ可以通過表屬性 auto_increment = x進行設置,或 alter table tbl auto_increment = x;
  6. COMMENT 注釋
    例:create table tab ( id int ) comment '注釋內(nèi)容';
  7. FOREIGN KEY 外鍵約束
    用于限制主表與從表數(shù)據(jù)完整性梢睛。
    alter table t1 add constraint t1_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:在刪除或更新時滨彻,有如下幾個操作可以選擇:
    1. cascade,級聯(lián)操作挪蹭。主表數(shù)據(jù)被更新(主鍵值更新)亭饵,從表也被更新(外鍵值更新)。主表記錄被刪除梁厉,從表相關記錄也被刪除辜羊。
    2. set null,設置為null词顾。主表數(shù)據(jù)被更新(主鍵值更新)八秃,從表的外鍵被設置為null。主表記錄被刪除肉盹,從表相關記錄外鍵被設置成null昔驱。但注意,要求該外鍵列上忍,沒有not null屬性約束骤肛。
    3. 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密碼重置

  1. 停止MySQL服務
  2. [Linux] /usr/local/mysql/bin/safe_mysqld --skip-grant-tables &
    [Windows] mysqld --skip-grant-tables
  3. use mysql;
  4. UPDATE user SET PASSWORD=PASSWORD("密碼") WHERE user = "root";
  5. 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 ON pms.* 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

  1. 導出一張表
      mysqldump -u用戶名 -p密碼 庫名 表名 > 文件名(D:/a.sql)
  2. 導出多張表
      mysqldump -u用戶名 -p密碼 庫名 表1 表2 表3 > 文件名(D:/a.sql)
  3. 導出所有表
      mysqldump -u用戶名 -p密碼 庫名 > 文件名(D:/a.sql)
  4. 導出一個庫
      mysqldump -u用戶名 -p密碼 --lock-all-tables --database 庫名 > 文件名(D:/a.sql)
    可以-w攜帶WHERE條件
    -- 導入
  5. 在登錄mysql的情況下:
      source 備份文件
  6. 在不登錄的情況下
      mysql -u用戶名 -p密碼 庫名 < 備份文件

其他 3. 注釋: 單行注釋 # 注釋內(nèi)容 多行注釋 /* 注釋內(nèi)容 */ 單行注釋 -- 注釋內(nèi)容 (標準SQL注釋風格,要求雙破折號后加一空格符(空格娄猫、TAB贱除、換行等))

  1. CMD命令行內(nèi)的語句結束符可以為 ";", "\G", "\g",僅影響顯示結果媳溺。其他地方還是用分號結束月幌。delimiter 可修改當前對話的語句結束符。
  2. SQL對大小寫不敏感
  3. 清除已有語句:\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()

總結一下:

1.創(chuàng)建連接

conn = pymysql.connect(參數(shù)....)

2.創(chuàng)建游標

cursor = conn.cursor()

3.寫SQL語句

sql = """

insert|delete|update|select|alter .......

"""

4.執(zhí)行

cursor.execute(sql,[參數(shù),參數(shù),....])

result = cursor.execute(sql,[參數(shù),參數(shù),....])

result:返回受影響的行

5.提交

conn.commit()

6.關閉

cursor.close() #關閉游標

conn.close() #關閉連接

注意:

假如我們要做的是查詢

cursor.fetchone() 獲取查詢的第一條結果

cursor.fetchall() 獲取查詢的所有結果

設置:

conn.cursor(cursor=pymysql.cursors.DictCursor)

設置pymysql.cursors.DictCursor將對應的行的數(shù)據(jù)以字典的形式返回录语,如果是多個直接放在一個列表中

cursor_handler.lastrowid 返回最后插入數(shù)據(jù)的id

?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市禾乘,隨后出現(xiàn)的幾起案子澎埠,更是在濱河造成了極大的恐慌,老刑警劉巖始藕,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蒲稳,死亡現(xiàn)場離奇詭異,居然都是意外死亡伍派,警方通過查閱死者的電腦和手機江耀,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诉植,“玉大人祥国,你說我怎么就攤上這事×狼唬” “怎么了舌稀?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長建车。 經(jīng)常有香客問我扩借,道長,這世上最難降的妖魔是什么缤至? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任潮罪,我火速辦了婚禮,結果婚禮上领斥,老公的妹妹穿的比我還像新娘嫉到。我一直安慰自己,他們只是感情好月洛,可當我...
    茶點故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布何恶。 她就那樣靜靜地躺著,像睡著了一般嚼黔。 火紅的嫁衣襯著肌膚如雪细层。 梳的紋絲不亂的頭發(fā)上惜辑,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天,我揣著相機與錄音疫赎,去河邊找鬼盛撑。 笑死,一個胖子當著我的面吹牛捧搞,可吹牛的內(nèi)容都是我干的抵卫。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼胎撇,長吁一口氣:“原來是場噩夢啊……” “哼介粘!你這毒婦竟也來了?” 一聲冷哼從身側響起晚树,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤姻采,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后题涨,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體偎谁,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年纲堵,在試婚紗的時候發(fā)現(xiàn)自己被綠了巡雨。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,018評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡席函,死狀恐怖铐望,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情茂附,我是刑警寧澤正蛙,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站营曼,受9級特大地震影響乒验,放射性物質發(fā)生泄漏。R本人自食惡果不足惜蒂阱,卻給世界環(huán)境...
    茶點故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一锻全、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧录煤,春花似錦鳄厌、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春歪泳,著一層夾襖步出監(jiān)牢的瞬間萝勤,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工夹囚, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留纵刘,地道東北人。 一個月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓荸哟,卻偏偏與公主長得像,于是被迫代替她去往敵國和親瞬捕。 傳聞我的和親對象是個殘疾皇子鞍历,可洞房花燭夜當晚...
    茶點故事閱讀 42,762評論 2 345