mysql - 语法复习与学习

时间:2021-09-16 05:57:09
//本月的第一天,最后一天
$start=date('Y-m-01', strtotime(date("Y-m-d")));
echo date('Y-m-d', strtotime("$start +1 month -1 day"));
//上一个月的第一天,最后一天
$start=date("Y-m-d",strtotime("2016-11-01"."-1 month"));
echo date('Y-m-d', strtotime("$start +1 month -1 day"));
//下一个月的第一天,最后一天
$start=date("Y-m-d",strtotime("2016-11-01"."+1 month"));
echo date('Y-m-d', strtotime("$start +1 month -1 day"));

一、当天或当日插入的数据:

1、传统对比判断:SELECT * FROM `t` WHERE DATE_FORMAT(addTime,'%Y-%m-%d') = date_format(now(),'%Y-%m-%d')");
2、第一点的简写:SELECT * FROM `t` WHERE addTime >= date_format(NOW(),'%Y-%m-%d');
3、利用函数判断:SELECT * FROM `t` WHERE DATEDIFF(addTime,NOW()) =0;//推荐此方法
4、利用时间戳判断:SELECT * FROM `t` WHERE addTime BETWEEN (UNIX_TIMESTAMP(now()-86440)) AND now();
注:返回当天时间的mysql函数有CURDATE()、CURRENT_DATE()、CURRENT_DATE、NOW()几种;其中NOW()获取的日期格式为0000-00-00 00:00:00的时间;CURDATE()、CURRENT_DATE()、CURRENT_DATE是获取日期格式为0000-00-00的时间,所以返回的时间无时分秒;

1、时间戳转日期,方法是select from_unixtime(1336542121);
2、日期转时间戳,方法是:select unix_timestamp('2013-04-08′);

mysql分区

使用 : select * from news_main PARTITION(news_main_a)

注意:当我们使用insert语句的时候,默认会分配到最后一个分区

注意:据说只有MyISAM类型才可以分区

#分区
alter table news_main PARTITION by range(id)
(
PARTITION news_main_a values less than(4),
PARTITION news_main_b values less than(6),
PARTITION news_main_c values less than(MAXVALUE)
); #显示Mysql的文件目录路径
show VARIABLES like '%datadir%'; #合并分区
alter table 表名 reorganize partition 分区名1,分区名2 into (partition 分区名 values less than (xx)); #取消分区(重新合并所有分区)
Alter table news_main remove partitioning; #删除分区(包含分区中的数据)
alter table 表名drop partition 分区名;(丢数据)

explain 性能检测(不会执行操作)

ALL    #(最差)全表扫描

index  # 排序查询,如order by id,id必须是索引或者主键,说明了哪怕默认是正排序,也得使用一下

range  # 范围查询,如where id > 20 、 id like '20%',id必须是索引或者主键

const  #(最优)索引查询,如where id = 1

时间类型字段通常用timestamp类型。默认公式为:CURRENT_TIMESTAMP

rand()随机获取1-50的整数

SELECT FLOOR(1 + (RAND() * 50));

获取guid

SELECT UUID();

@变量赋值与取值

SELECT user_name,user_pwd INTO @user_name,@user_pwd from user_table where user_id = '';

SELECT @user_name,@user_pwd;

SELECT + IF

select if(bid <> '',3,type) from statements

获取当前时间

SELECT CURDATE()  //2016-06-20

获取昨天的时间

SELECT UNIX_TIMESTAMP(DATE_SUB(CURDATE(), INTERVAL  DAY)) //2016-06-19

获取当前时间戳

SELECT UNIX_TIMESTAMP() 

转换时间戳

SELECT FROM_UNIXTIME(update_time, '%Y-%m-%d %H:%i:%S') FROM `user`

SELECT FROM_UNIXTIME( `happen_time` ) from statements 

获取当前时间

mysql> select now();

+---------------------+
| now() |
+---------------------+
| 2008-08-08 22:20:46 |
+---------------------+

时间相差(其中unit单位有如下几种,分别是:FRAC_SECOND (microseconds), SECOND, MINUTE, HOUR, DAY, WEEK, MONTH, QUARTER, or YEAR。)

SELECT TIMESTAMPDIFF(HOUR,'2016-05-13 20:50:54',now())

时间转化

DATE_FORMAT('2012-12-12 11:10:02','%Y-%m-%d')

定义变量以及赋值

SELECT @Q := question as Q FROM user WHERE openid = '' limit