MySQL函数总结

[TOC]

日期函数

MySQL对时间的格式无具体要求,只要格式是 YYYY-MM-DD HH:MM:SS 其中:可用其它特殊字符替换。

  • ADDDATE(d,INTERVAL n type) : 在起始日期d加上n的日期(n 默认单位天)
  SELECT ADDDATE("2019-04-10 11:11:11",10);  --  2019-04-20 11:11:11
  SELECT ADDDATE("2019-04-10 11:11:11",INTERVAL 5 HOUR);  --  2019-04-10 16:11:11

  • ADDTIME(t,n):在时间t加上秒数s(s可正可负,但在区间[60,99]和[-60,-99]结果会为null?)
  SELECT ADDTIME("2019-04-10 11:11:11",-59);  --  2019-04-10 11:10:12

  • DATE_ADD(d,INTERVAL n type):在起始时间d加上n的日期(n无默认单位)
  SELECT DATE_ADD('2019-04-15 11:11:11',INTERVAL 3 HOUR)  --  2019-04-15 14:11:11

  • SUBDATE(d,n):在起始日期d减去n天的日期
  SELECT SUBDATE("2019-04-15 11:11:11" , 5)  --  2019-04-10 11:11:11

  • SUBTIME(d,n):在起始日期d减去n秒的时间
  SELECT SUBTIME("2019-04-15 11:11:11" , 5)  --  2019-04-15 11:11:06

  • DATE_SUB(d,INTERVAL n type):在起始时间d减去n的日期(n无默认单位)
  SELECT DATE_SUB('2019-04-15 11:11:11',INTERVAL 3 HOUR)  --2019-04-15 08:11:11

  • CURRENT_TIME/CURTIME(): 返回当前时间
  SELECT CURRENT_TIME();  --  10:15:49
  SELECT CURTIME();  --  10:15:49

  • UTC_DATE()/UTC_TIME()/UTC_TIMESTAMP(): 国际标准日期/时间
  SELECT UTC_DATE();  --  2019-04-17     国际标准日期
  SELECT UTC_TIME() ;  --  03:37:19      国际标准时间
  SELECT UTC_TIMESTAMP();  --  2019-04-17 03:37:44      国际标准时间戳

  • SYSDATE():返回系统时间
  SELECT SYSDATE()  --  2019-04-15 09:01:20

  • CURDATE()/CURRENT_DATE():返回当前日期
  SELECT CURDATE();  --  2019-04-13
  SELECT CURRENT_DATE();  --  2019-04-13

  • CURRENT_TIMESTAMP()/SELECT NOW(): 返回当前时间戳
  SELECT CURRENT_TIMESTAMP();  --  2019-04-13 10:24:09
  SELECT NOW();  --  2019-04-13 10:24:09

  • DATE(d):提取d里面的日期格式为 YYYY-MM-DD;
  SELECT DATE("2019-11-13 11-11-11");  --  2019-11-13

  • DATEDIFF(d1,d2):计算 d1到d2间隔的天数,d1-d2
  SELECT DATEDIFF("2019-11-23","2019-11-13") ;  --  10

  • DATE_FORMAT(d,format):根据格式format显示日期d ,(format格式详见@2)
  SELECT DATE_FORMAT("2019-04-11 11:11:11",'%Y-%m-%d %r');  --  2019-04-11 11:11:11 AM

  • YEAR(d):返回日期值d的年份部分
  SELECT YEAR("2019-04-13 11:11:11")  --  2019

  • MONTH(d):返回日期值d的月份部分
  SELECT DAY("2019-04-13 11:11:11")  --  4

  • DAY(d):返回日期值d的日期部分
  SELECT DAY("2019-04-13 11:11:11")  --  13

  • HOUR(d):返回日期值d的小时部分
  SELECT DAY("2019-04-13 08:09:11")  --  08

  • MINUTE(d):返回日期值d的分钟部分
  SELECT MINUTE("2019-04-13 08:09:11")  --  09

  • SECOND(d):返回日期值d的秒数部分
  SELECT SECOND("2019-04-13 08:09:11")  --  11

  • MICROSECOND(d):返回日期d是的毫秒数
  SELECT MICROSECOND("2019-04-15 11:11:11.1234")  --  123400 

  • WEEK(d):返回日期值d的处于本年第几周
  SELECT WEEK("2019-04-13 08:09:11");  --  14

  • DAYNAME(d):返回日期值d处于星期几(如 Monday,Tuesday)
  SELECT DAYNAME("2019-04-13 11:21:11")  --  Saturday

  • DAYOFWEEK(d):日期 d 今天是星期几,1 星期日,2 星期一,以此类推
  SELECT DAYOFWEEK("2019-04-13 11:21:11");  --  6

  • DAYOFMONTH(d):计算日期 d 是本月的第几天
  SELECT DAYOFMONTH("2019-04-13 11:21:11");  --  13

  • DAYOFYEAR(d):计算日期 d 是本年的第几天
  SELECT DAYOFYEAR("2019-04-13 11:21:11");  --  103

  • QUARTER(d):计算日期d是本年的第几个季度
  SELECT QUARTER("2019-04-15 11:11:11")  --  2

  • LAST_DAY(d):返回给定日期的那一分月的最后一天
  SELECT LAST_DAY("2019-04-15 11:11:11")  --  2019-04-30

  • EXTRACT(type FROM d):从日期 d 中获取指定的值,type 指定返回的值。(type类型详见@1)
  SELECT EXTRACT(**MINUTE** FROM  "2019-04-13 08:21:11");  --  21

  • STR_TO_DATE(string,format_mask):将字符串转换为日期
  SELECT STR_TO_DATE("August 10 2017", "%M %d %Y");  --  2019-04-15

  • TO_DAYS(d):计算日期d距离0000年1月1日的天数
  SELECT TO_DAYS("0001-04-15")  --  105

@ 1 TYPE类型

  • MICROSECOND 毫秒
  • SECOND
  • MINUTE
  • HOUR
  • DAY
  • WEEK
  • MONTH
  • QUARTER
  • YEAR
  • SECOND_MICROSECOND
  • MINUTE_MICROSECOND
  • MINUTE_SECOND
  • HOUR_MICROSECOND
  • HOUR_SECOND
  • HOUR_MINUTE
  • DAY_MICROSECOND
  • DAY_SECOND
  • DAY_MINUTE
  • DAY_HOUR
  • YEAR_MONTH

@2 format格式

%a 缩写星期名
%b 缩写月名
%c 月,数值
%D 带有英文前缀的月中的天
%d 月的天,数值(00-31)
%e 月的天,数值(0-31)
%f 微秒
%H 小时(00-23)
%h 小时(01-12)
%I 小时(01-12)
%i 分钟,数值(00-59)
%j 年的天(001-366)
%k 小时(0-23)
%l 小时(1-12)
%M 月名
%m 月,数值(00-12)
%p AM 或 PM
%r 时间,12-小时(hh:mm:ss AM 或 PM)
%S 秒(00-59)
%s 秒(00-59)
%T 时间, 24-小时(hh:mm:ss)
%U 周(00-53)星期日是一周的第一天
%u 周(00-53)星期一是一周的第一天
%V 周(01-53)星期日是一周的第一天,与 %X 使用
%v 周(01-53)星期一是一周的第一天,与 %x 使用
%W 星期名
%w 周的天(0=星期日, 6=星期六)
%X 年,其中的星期日是周的第一天,4 位,与 %V 使用
%x 年,其中的星期一是周的第一天,4 位,与 %v 使用
%Y 年,4 位
%y 年,2 位

字符串函数

ps:MySQL下标从1开始计算

  • 返回字符c的ASCII编码 ASCII(c)
  SELECT ASCII('A');  --  65

  • 返回数字i的所对应的ASCII编码字符 CHAR(i)
    • SELECT CHAR(65); -- A
  • 返回字符串长度:CHAR_LENGTH(s)/CHARACTER_LENGTH(s)
  SELECT CHAR_LENGTH("HelloWorld");  --  10
  SELECT CHARACTER_LENGTH("HelloWorld");  --  10

  • 合并字符串s1,s2...sn为一个字符串:CONCAT(s1,s2...sn)
  SELECT CONCAT("Hello","World","!") ;  --  helloworld!

  • 合并字符串并添加分隔符x:CONCAT_WS(x,s1,s2...sn)
  SELECT CONCAT_WS("-","Hello","World","!") ;  --  hello-world-!

  • 返回字符串s在s1,s2...sn的位置(没找到返回0):FIELD(s,s1,s2...sn)
  SELECT FIELD("c","b","c","d") ;  --  2

  • 返回在字符串s2中与s1匹配的字符串的位置(没找到返回0):FIND_IN_SET(s1,s2)
  SELECT FIND_IN_SET("ac", "a,b,ac,d,e");  --  3

  • 返回字符串s1在字符s开始的位置 POSITION(s1 IN s)
  SELECT POSITION("o" in "helloworld");  --  5

  • 函数可以将数字 x 进行格式化 "#,###.##", 将 x 保留到小数点后 n 位,最后一位四舍五入:FORMAT(x,n)
  SELECT FORMAT(20190415.35581, 2);  --  20,190,415.36

  • 将字符串s2替换字符s中的字符串s1:REPLACE(s,s1,s2)
  SELECT REPLACE("helloworld","ell","MySQL");  --  hMySQLoworld

  • 字符串s2替换s1在x处的位置,替换长度为len:INSERT(s1,x,len,s2)
  SELECT INSERT("helloworld",6,4,"MySQL") ;  --  helloMySQLd

  • 在字符串s1处填充字符串s2,使其长度为len: LPAD(s1,len,s2)
  SELECT LPAD("helloworld",16,"MySQL");  --  MySQLMhelloworld

  • 在字符串s1结尾处填充字符串s2,使其长度为lenRPAD(s1,len,s2)
  SELECT RPAD("helloworld",16,"MySQL");  --  helloworldMySQLM

  • 从字符串s获取s1的位置:LOCATE(s1,s)
  SELECT LOCATE("ell","helloworld");  --  2

  • 将s中的字母全部转换为小写:LOWER(s)/LCASE(s)
  SELECT LOWER("HELLOWORLD");  --  helloworld
  SELECT LCASE("HELLOWORLD");  --  helloworld

  • 将s中的字母全部转换为大写:UPPER(s)/UCASE(s)
  SELECT UPPER("helloworld");  --  HELLOWORLD
  SELECT UCASE("helloworld");  --  HELLOWORLD

  • 去掉字符串s开始处的空格:LTRIM(s)
  SELECT LTRIM("      hello") ;  --  hellow

  • 去掉字符串s结尾处空格: RTRIM(s)
  SELECT RTRIM("hello     ");  --  hello

  • 去掉字符串s开始和结尾处的空格: TRIM(s)
  SELECT RTRIM("      hello     ");  --  hello

  • 返回n个空格: SPACE(n)
  SELECT SPACE(5);  --  

  • 从左开始截取字符串: left(str, length)
  SELECT LEFT("helloworld",7); --hellowo

  • 从右开始截取字符串: right(str, length)
  SELECT RIGHT("helloworld",7); --loworld 

  • 从字符串 s 的 start 位置截取长度为 length 的子字符串: MID(s,start ,len)/SUBSTRING(s,start ,len)
  SELECT MID("helloworld", 2, 3) ;  --  ell
  SELECT SUBSTRING("helloworld", 3, 5);  --  llowo

  • 将字符串s重复n次:REPEAT(s,n)
  SELECT REPEAT("hello",3);  --  hellohellohello

  • 反转字符串s:REVERSE(s)
  SELECT REVERSE("hello");  --  olleh

  • 返回字符串s后n个字符:RIGHT("helloworld",6)
  SELECT RIGHT("helloworld",6);  --  oworld

  • 比较字符串 s1 和 s2,如果 s1 与 s2 相等返回 0 ,如果 s1>s2 返回 1,如果 s1<s2 返回 -1:STRCMP(s1,s2)
  SELECT STRCMP("runoob", "runooa");  --  1
  SELECT STRCMP("runoob", "runoob");  --  0
  SELECT STRCMP("runoob", "runooc");  --  -1


数学函数

  • 取绝对值:ABS(x)
  SELECT ABS(-1);  --  1

  • 返回圆周率:PI()
  SELECT PI(); --3.141593

  • 返回0到1的伪随机数: RAND([seed])
    seed:种子值,相同的种子值会有相同的输出
  SELECT RAND(); --0.8503592115364589
  SELECT RAND(); --0.26865792299495816
  SELECT RAND(100); --0.17353134804734155  试几次都一样

  • 返回大于或等于x的最小整数: CEIL(x)/CEILING(x)
  SELECT CEIL(1.5);  --  2
  SELECT CEIL(-1.5);  --  -1

  • 返回小于或等于 x 的最大整数: FLOOR(x)

    • SELECT FLOOR(1.5); -- 1
    • SELECT FLOOR(1.5) -- -2
  • 返回离x最近的整数: ROUND(x)

  SELECT ROUND(1.1235);  --  1
  SELECT ROUND(-1.5235);  --  -2

  • 返回数值 x 保留到小数点后 y 位的值(与 ROUND 最大的区别是不会进行四舍五入):TRUNCATE(x,y)

    y:是n的舍入精度,如果y为整数,则n舍入到y指定的小数位数,如果y为负数,则n小数点左边舍入到y的指定位数

  SELECT TRUNCATE(1.1235,3);  --  1.123
  SELECT TRUNCATE(123.1235,-1);  --  120
  SELECT TRUNCATE(-1.5235,3);  --  -1.523

  • n 除 m: n DIV m

    • SELECT 5 DIV 2 ; -- 2
  • 返回n除以m以后的余数: MOD(n,m)

  SELECT MOD(5,2);  --  1

  • 返回x的y次方 POW(x,y)/POWER(x,y)

    • SELECT POW(2,3); -- 8
  • 返回x的平方根:SQRT(x)

  SELECT SQRT(0.25);  --  0.5

  • 返回x的符号,x是负数返回-1,正数返回1,0返回0 SIGN(x)
  SELECT SIGN(0.25);  --  1
  SELECT SIGN(0);  --  0
  SELECT SIGN(-0.25);  --  -1


聚合函数

  • 返回一个表达式的平均值,expression 是一个字段: AVG(expression)
  SELECT AVG(FSL) FROM table-- 取table表FSL字段的平均值

  • 返回查询的总记录数,expression 是一个字段或号:* COUNT(expression)
  SELECT COUNT(*) form table  --  取table表的总记录数

  • 返回字段expression的总和:SUM(expression)
  SELECT SUM(FSL)  --  返回table表字段FSL的总和

  • 返回字段expression的最大值: MAX(expression)
  SELECT MAX(FSL) FROM table; --返回table表FSL字段的最大值

  • 返回字段expression的最小值: MIN(expression)
  SELECT MIN(FSL) FROM table; --返回table表FSL字段的最小值

  • HAVING子句仅用于带有GROUP BY子句的查询语句中,WHERE子句用于每一行(在变成一个组的某一部分之前),而HAVING子句用于分组的聚合值。 HAVING
  • 分组合并字符串:GROUP_CONCAT()
    • 根据名字分组,求出该名字的所有id值
      mysql>SELECT SNAME,GROUP_CONCAT(SNO) as ids from student GROUP BY SNAME
      | SNAME | ids |
      | ----- | ----------- |
      | 匡明 | 105 |
      | 曾华 | 108 |
      | 李军 | 101,110,111 |
      | 王丽 | 107,112 |
      | 王芳 | 109 |
      | 陆君 | 103 |

    • 根据名字分组,求出该名字的所有id值,并根据id的值从大到小排序,使用分隔符-隔开
      mysql>SELECT SNAME,GROUP_CONCAT(SNO ORDER BY SNO DESC SEPARATOR '-') as ids from student GROUP BY SNAME

SNAME ids
匡明 105
曾华 108
李军 111-110-101
王丽 112-107
王芳 109
陆君 103

数据类型转换函数

把x转换成type类型:CAST(x AS type)/CONVERT(x,type)

  • 字符串转数字
    SELECT CONVERT("123",SIGNED);  --  123
    SELECT CAST("123",SIGNED);  --  123
    SELECT CONVERT("1a123",SIGNED);  --  返回1;从左往右匹配遇到非数字返回,如果开头没数字返回0
    SELECT CAST("sa123" as SIGNED) ;  --  返回 0
    SELECT '123'+0;  --  返回数字类型 123

  • 数字转字符串
  SELECT CONCAT(123) ; --返回字符串 "123"
  SELECT CAST(123 AS CHAR);  --  返回"123"

  • 字符串转日期
  SELECT CONVERT("20190415",DATE)  --  2019-04-15
  SELECT CAST("20190415",DATE);  --  2019-04-15

type类型:

​ 二进制,同带binary前缀的效果 : BINARY

​ 字符型,可带参数 : CHAR()

​ 日期 : DATE

​ 时间: TIME

​ 日期时间型 : DATETIME

​ 浮点数 : DECIMAL

​ 整数 : SIGNED

​ 无符号整数 : UNSIGNED


排序函数

自定义排序, field(value,str1,str2,str3,str4)

mysql> select * from student order by field(Sname,'李军','王丽','曾华');

SNO SNAME SSEX SBIRTHDAY CLASS
105 匡明 1975-10-02 00:00:00 95031
109 王芳 1975-02-10 00:00:00 95031
103 陆君 1974-06-03 00:00:00 95031
101 李军 1976-02-20 00:00:00 95033
110 李军 1974-06-03 00:00:00 95031
111 李军 1974-06-03 00:00:00 95031
107 王丽 1976-01-23 00:00:00 95033
112 王丽 1976-02-20 00:00:00 95033
108 曾华 1977-09-01 00:00:00 95033

没有排序的字段放在最前面,排序字段根据field里的顺序来进行排序;

mysql> SELECT * from student ORDER BY FIELD(SNAME,'李军','王丽','曾华') DESC;

SNO SNAME SSEX SBIRTHDAY CLASS
108 曾华 1977-09-01 00:00:00 95033
107 王丽 1976-01-23 00:00:00 95033
112 王丽 1976-02-20 00:00:00 95033
101 李军 1976-02-20 00:00:00 95033
110 李军 1974-06-03 00:00:00 95031
111 李军 1974-06-03 00:00:00 95031
105 匡明 1975-10-02 00:00:00 95031
109 王芳 1975-02-10 00:00:00 95031
103 陆君 1974-06-03 00:00:00 95031

当加上DESC后,先filed()参数从后往前,再是未经field()排序的字段。

系统函数

  • 查看版本信息:VERSION()
  SELECT VERSION();  --  5.5.28

  • 查看服务器的连接数:CONNECTION_ID()
  SELECT CONNECTION_ID();  --  27

  • 查看当前用户的名字: CURRENT_USER()/SYSTEM_USER()/USER()/SESSION_USER()
  SELECT CURRENT_USER();  --root@localhost

  • 查看当前数据库的名字 DATABASE()/SCHEMA()
  SELECT DATABASE(); --ycz_test

其它函数

  • 从N1开始,比较N和N1的值,如果N>Ni返回i的下标(从N1开始从0计算),如果N最大返回0,如果N为null返回-1:INTERVAL(N,N1,N2,N3,N4...Ni)
  SELECT INTERVAL(1,2,3,4);  --  0
  SELECT INTERVAL(5,2,3,4,5,6,7,8);  --  4
  SELECT INTERVAL(null,2,3,4);  --  -1

  • 返回x的二进制编码:BIN(x)
  SELECT BIN(14);  --  110

  • 返回x的八进制编码:OCT(x)
  SELECT OCT(14);  --  16

  • 返回x的十六进制编码:HEX(x)
  SELECT HEX(14);  --  E

  • 将x从f1进制数变成f2进制数:CONV(x,f1,f2)
  SELECT CONV(14,10,2);--1110

  • 如果表达式expr成立,返回r1,否则返回r2: IF(expr,r1,r2)
  SELECT IF(1>2,"正确","错误");  --  错误

  • 如果 v1 的值不为 NULL,则返回 v1,否则返回 v2。 IFNULL(r1,r2)
  SELECT IFNULL(null,"helloworld");  --  helloworld
  SELECT IFNULL("hello","helloworld");  --  hello

  • 比较两个字符串,如果相等返回null,否则返回r1: NULLIF(r1,r2)
  SELECT NULLIF("hello","helloworld");  --  hello
  SELECT NULLIF("helloworld","helloworld") ;  --

  • IP地址与数字相互转换的函数
    把数字转换为ip地址:INET_ATON(IP)

    把ip地址转换为数字:INET_NTOA(n)
  SELECT INET_ATON('192.168.3.126') ;  --  3232236414
  SELECT INET_NTOA(3232236414);  --  192.168.3.126

  • 返回列表的最大值: GREATEST(expr1, expr2, expr3, ...)
  SELECT GREATEST(34, 12, 26, 8, 55, 47);  --  55
  SELECT LEAST("baidu", "alibaba", "tencent");  --  alibaba

  • 返回列表中的最小值: LEAST(expr1, expr2, expr3, ...)
  SELECT GREATEST(34, 12, 26, 8, 55, 47);  --  8
  SELECT LEAST("baidu", "alibaba", "tencent");  --  tencent

加密函数

  • 返回MD5加密后的字符串s MD5(s)
  SELECT MD5("hello"); --5d41402abc4b2a76b9719d911017c592 

  • 对字符串s进行加密,一般用来给用户密码做加密的。PASSWORD(s)
  SELECT PASSWORD("hello"); --*6B4F89A54E2D27ECD7E8DA05B4AB8FD9D1D8B119

  • 使用字符串pswd_str作为密匙来加密字符串str。加密的结果是一个二进制数,必须使用BLOB类型的字段来保存它。ENCODE(str,pswd_str)

  • 使用密匙pswd_str对二进制函数crypt_str进行解密,和ENCODE()配对使用。DECODE(crypt_str,pswd_str)

    • 使用ENCODE()加密,并使用DECODE()进行解密。加密字符串为hello,密匙为world
  SELECT DECODE(ENCODE("hello","world"),"world");  --  hello

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容