mysql语句判断一天操作记录的个数

话说有一文章表article,存储文章的添加文章的时间是add_time字段,该字段为int(5)类型的,现需要查询今天添加的文章总数并且按照时间从大到小排序,则查询语句如下:
 
1    select * from `article` where date_format(from_UNIXTIME(`add_time`),‘%Y-%m-%d‘) = date_format(now(),‘%Y-%m-%d‘);
或者:
 
1    select * from `article` where to_days(date_format(from_UNIXTIME(`add_time`),‘%Y-%m-%d‘)) = to_days(now());
假设以上表的add_time字段的存储类型是DATETIME类型或者TIMESTAMP类型,则查询语句也可按如下写法:
 
查询今天的信息记录:
 
1    select * from `article` where to_days(`add_time`) = to_days(now());
查询昨天的信息记录:
 
1    select * from `article` where to_days(now()) – to_days(`add_time`) <= 1;
查询近7天的信息记录:
 
1    select * from `article` where date_sub(curdate(), INTERVAL 7 DAY) <= date(`add_time`);
查询近30天的信息记录:
 
1    select * from `article` where date_sub(curdate(), INTERVAL 30 DAY) <= date(`add_time`);
查询本月的信息记录:
 
1    select * from `article` where date_format(`add_time`, ‘%Y%m‘) = date_format(curdate() , ‘%Y%m‘);
查询上一月的信息记录:
 
1    select * from `article` where period_diff(date_format(now() , ‘%Y%m‘) , date_format(`add_time`, ‘%Y%m‘)) =1;
对上面的SQL语句中的几个函数做一下分析:
 
(1)to_days
 
就像它的名字一样,它是将具体的某一个日期或时间字符串转换到某一天所对应的unix时间戳,如:
 
01   mysql> select  to_days(‘2010-11-22 14:39:51‘);    
02    +--------------------------------+                                                      
03   | to_days(‘2010-11-22 14:39:51‘) |
04   +--------------------------------+
05   |                         734463 |
06   +--------------------------------+
07  
08   mysql> select  to_days(‘2010-11-23 14:39:51‘);
09   +--------------------------------+
10   | to_days(‘2010-11-23 14:39:51‘) |
11   +--------------------------------+
12   |                         734464 |
13   +--------------------------------+
可以看出22日与23日的差别就是,转换之后的数增加了1,这个粒度的查询是比较粗糙的,有时可能不能满足我们的查询要求,那么就需要使用细粒度的查询方法str_to_date函数了,下面将分析这个函数的用法。
 
提醒:
 
(1)to_days() 不用于阳历出现(1582)前的值,原因是当日历改变时,遗失的日期不会被考虑在内。因此对于1582 年之前的日期(或许在其它地区为下一年 ), 该函数的结果实不可靠的。
 
(2)MySQL"日期和时间类型"中的规则是将日期中的二位数年份值转化为四位。因此对于‘1997-10-07‘和‘97-10-07‘将被视为同样的日期:
 
1    mysql> select to_days(‘1997-10-07‘), to_days(‘97-10-07‘);
2   
3    -> 729669, 729669
(2)str_to_date
 
这个函数可以把字符串时间完全的翻译过来,如:
 
1    mysql> select str_to_date("2010-11-23 14:39:51",‘%Y-%m-%d %H:%i:%s‘);
2   
3    +--------------------------------------------------------+
4    | str_to_date("2010-11-23 14:39:51",‘%Y-%m-%d %H:%i:%s‘) |
5    +--------------------------------------------------------+
6    | 2010-11-23 14:39:51                                    |
7    +--------------------------------------------------------+
具体案例操作如下:
 
1    select str_to_date(article.`add_time`,‘%Y-%m-%d %H:%i:%s‘)
2    from article
3    where str_to_date(article.`add_time`,‘%Y-%m-%d %H:%i:%s‘)>=‘2012-06-28 08:00:00‘ and str_to_date(article.`add_time`,‘%Y-%m-%d %H:%i:%s‘)<=‘2012-06-28 09:59:59‘;

mysql语句判断一天操作记录的个数

时间: 2024-10-10 06:31:20

mysql语句判断一天操作记录的个数的相关文章

[转帖] mysql 用户 权限 密码等操作记录

前言 From :https://blog.csdn.net/yu12377/article/details/78214336 mysql5.7版本中用户管理与以前版本略有不同,在此记录,以备忘 登陆 [[email protected] ~]# mysql -h 127.0.0.1 -P 3316 -u root -p Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL conn

java连接mysql数据库增删改查操作记录

1. 连接数据库,得到数据库连接变量 注意连接数据库的时候 (1)打开DB Browser 新建一个Database Driver,注意添加Driver JARs的时候添加的包,我的是mysql-connector-java-5.0.3-bin.jar (2)要将数据库jar包拷贝到工程下的WEB-INF\lib下 import java.sql.Connection;//java包 public class DBConnection { private String dbDriver="com

MySQL MyISAM引擎转换为InnoDB操作记录

进入mysql命令行模式: # mysql -uroot -ppwd 1.查看mysql提供什么存储引擎: mysql> show engines; 2.查看mysql当前提供的默认存储引擎: mysql> show variables like '%storage_engine%'; 3.显示数据库列表: mysql> show databases; 4.进入需要修改的数据库 mysql> use freeswitch; 5.列出FreeSWITCH库的所有表 mysql>

Mysql 插入判断 不存在重复记录则插入

Mysql insert if no exist 由于Mysql没有noexists之类的东西,只能用having 来构造一个false的条件 insert into DRUG_NAME1 (id,name,drug_id) select 7777,'drugname',666 from DRUG_NAME1 t where t.id=7777 having count(id)=0;

寒假日记-第二天(MySQL语句)

mysql语句: DDL(操作数据库和表): 1.操作数据库 显示数据库show databases; #判断是否存在数据库wpj1105,有的话先删除drop database if exists wpj1105; #创建数据库create database wpj1105; #删除数据库drop database wpj1105; #使用该数据库use wpj1105; 2.操作数据表 #显示数据库中的表show tables; #先判断表是否存在,存在先删除drop table if ex

Mysql更换MyISAM存储引擎为Innodb的操作记录

一般情况下,mysql会默认提供多种存储引擎,可以通过下面的查看: 1)查看mysql是否安装了innodb插件.通过下面的命令结果可知,已经安装了innodb插件. mysql> show plugins; +------------+--------+----------------+---------+---------+ | Name | Status | Type | Library | License | +------------+--------+----------------

mysql中判断记录是否存在方法比较【转】

把数据写入到数据库的时,常常会碰到先要检测要插入的记录是否存在,然后决定是否要写入. 我这里总结了判断记录是否存在的常用方法: sql语句:select count(*) from tablename; 然后读取count(*)的值判断记录是否存在.对于这种方法性能上有些浪费,我们只是想判断记录记录是否存在,没有必要全部都查出来. 以下这个方法是我推荐的. sql语句:select 1 from tablename where col = col limit 1; 然后读取语句执行所影响的行数.

mysql表名等大小写敏感问题、字段类型timestamp、批量修改表名、oracle查询历史操作记录等

mysql表名等大小写敏感问题:http://blog.csdn.net/postnull/article/details/72455768: 1 MySQL在Linux下数据库名.表名.列名.别名大小写规则是这样的: 2 1.数据库名与表名是严格区分大小写的: 3 2.表的别名是严格区分大小写的: 4 3.列名与列的别名在所有的情况下均是忽略大小写的: 5 4.字段内容默认情况下是大小写不敏感的. ================================================

Mysql备份系列(4)--lvm-snapshot备份mysql数据(全量+增量)操作记录

Mysql最常用的三种备份工具分别是mysqldump.Xtrabackup(innobackupex工具).lvm-snapshot快照.前面分别介绍了:Mysql备份系列(1)--备份方案总结性梳理Mysql备份系列(2)--mysqldump备份(全量+增量)方案操作记录Mysql备份系列(3)--innobackupex备份mysql大数据(全量+增量)操作记录 废话不多说,下面即是使用lvm-snapshot快照方式备份mysql的操作记录,仅依据本人实验中使用而述. 操作记录:如下环