mysql - 语法复习与学习
//本月的第一天,最后一天
$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
mysql - 语法复习与学习的更多相关文章
- 学习mysql语法--基础篇(一)
前 言 mysql mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分: 一.创建用户,创建数据库,给 ...
- 学习mysql语法--基础篇(二)
前 言 mysql mysql语法--本篇学习都是通过使用Navicat Premium(数据库管理工具),连接mysql数据. 本篇学习主要有两个部分: [SQL语句的组成] DML ...
- mysql语法之case when then与列转行
mysql语法中case when then与列转行的使用场景非常丰富. case语句类似java中条件分支语句的作用,可以类比java中的switch语句或者if语句来学习. 其语法如下: case ...
- MySQL实战45讲学习笔记:第十五讲
一.引子 在今天这篇答疑文章更新前,MySQL 实战这个专栏已经更新了 14 篇.在这些文章中,大家在评论区留下了很多高质量的留言.现在,每篇文章的评论区都有热心的同学帮忙总结文章知识点,也有不少同学 ...
- mysql 5.0存储过程学习总结
mysql存储过程的创建,删除,调用及其他常用命令 本人qq群也有许多的技术文档,希望可以为你提供一些帮助(非技术的勿加). QQ群: 281442983 (点击链接加入群:http://jq.q ...
- 多IDC数据分布--MySQL多机房部署 - 学习笔记 - 51CTO技术博客
多IDC数据分布--MySQL多机房部署 - 学习笔记 - 51CTO技术博客 多IDC数据分布--MySQL多机房部署
- MYSQL 语法大全自己总结的
mysql语法大全 --------数据链接---------------------数据库服务启动net start mysql --关闭服务net stop mysql --登录 -u,-p后面不 ...
- 语法分析器初步学习——LISP语法分析
语法分析器初步学习——LISP语法分析 本文参考自vczh的<如何手写语法分析器>. LISP的表达式是按照前缀的形式写的,比如(1+2)*(3+4)在LISP中会写成(*(+ 1 2)( ...
- MySQL事务控制语句(学习笔记)
MySQL事务控制语句(学习笔记) MySQL事务控制语句 在mysql命令行的默认下,事务都是自动提交的,sql语句提交后马上会执行commit操作.因此开启一个事务必须使用begi ...
随机推荐
- GO语言基础之reflect反射
反射reflection 1. 反射可以大大的提高程序的灵活性,使得 interface{} 有更大的发挥余地 2. 反射使用 TypeOf 和 ValueOf 函数从接口中获取目标对象信息 3. 反 ...
- 使用 Shell 脚本自动化 Linux 系统维护任务
如果一个系统管理员花费大量的时间解决问题以及做重复的工作,你就应该怀疑他这么做是否正确.一个高效的系统管理员应该制定一个计划使得其尽量花费少的时间去做重复的工作.因此尽管看起来他没有做很多的工作,但那 ...
- Discuz常见大问题-如何允许用户插入视频-如何自己在页面中插入视频
从视频的下面分享中获取html代码 然后粘贴到你创建页面的指定位置(注意从优酷复制的视频宽度和高度可能比较小,你可以自己调整,或者占据100%) 最终的实现效果
- Silverlight 之 新建项目解析
新建一个silverlight项目(项目名称为SilverlightTest)后,若在" 新建Silverlight应用程序窗口 " 勾选 " 在新网站中承载Silver ...
- PHP 表单 - 4(验证邮件和URL)
PHP 表单 - 验证邮件和URL 本章节我们将介绍如何验证 names(名称), e-mails(邮件), 和 URLs. PHP - 验证名称 以下代码将通过简单的方式来检测 name 字段是否包 ...
- innodb_file_per_table
MySQL InnoDB引擎 默认会将所有的数据库InnoDB引擎的表数据存储在一个共享空间中:ibdata1,当增删数据库的时候,ibdata1文件不会自动收缩,单个数据库的备份也将成为问题.通常只 ...
- 分布式协议之两阶段提交协议(2PC)和改进三阶段提交协议(3PC)
一. 事务的ACID 事务是保证数据库从一个一致性的状态永久地变成另外一个一致性状态的根本,当中,ACID是事务的基本特性. A是Atomicity,原子性.一个事务往往涉及到很多的子操作,原子性则保 ...
- Android 如何将Canvas上绘制的内容保存成本地图片(转)
效果如下图所示 保存在sd卡上的文件为 手机上显示效果为: 1>>在Manifest文件中增加相应权限 <!-- 在SDCard中创建与删除文件权限 --> <uses- ...
- 【转】SQL2008的sa账户被禁用,其他账户无法连接的解决方法
或者你还有其它的sysadmin权限的账号,你可以用此账号登录,重置SA密码. 但是在以下情况下,怎么办呢? 1. SA密码丢失或者SA账号被禁用. 2. 你进行了一些安全操作,把BuiltinAdm ...
- javascript实现掉落弹出层------Day29
顾名思义.所谓"掉落弹出层".就是出现一个弹出层,而出现的位置是从上方向下掉落.掉落到指定的位置停止,这样分析起来.和"右下角弹出提醒对话框"比起来,确有异曲同 ...