如果日期列是日期型,用下面的sql语句
创新互联公司是专业的红花岗网站建设公司,红花岗接单;提供网站设计、成都网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行红花岗网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
select * from 表名 where 列名=date_sub(curdate(), interval 30 day);
如果日期列是字符串型,用下面的sql语句
select * from 表名 where 列名=date_format(date_sub(curdate(), interval 30 day), '%Y-%m-%d');
注意curdate()是获得当前日期函数
date_sub()是减少日期的函数
date_format()是日期型按格式转换成字符串型的函数
先把每个库的表结构导出到文件,然后比较这两个文件。
mysqldump --skip-comments --skip-extended-insert -u root -p database1file1.sql
mysqldump --skip-comments --skip-extended-insert -u root -p database2file2.sql
diff file1.sql file2.sql
其实还有一些比较工具,推荐一个
mysql-comparison-tools
查询2011的数据:select * from 表 where year(date)='2011';
查找月份为12的数据:select * from 表 where month(date)='12';
查找天数为本年第二天的数据:select * from 表 where dayofyear(date)='2';
我解释一下:
select * from 表 where 这是必须的
year,month,dayofyear是mysql的函数,分别是取得年,月,和当前时间在本年是第几天的3个函数
date就是你保存时间的字段
等号后面的当然条件啦。
可以用语句快速过滤select * from 人员表 where 姓名 not in (select 姓名 from 出勤表)
如何比较2个mysql数据库数据
sql语句:因为MySQL 没有full outer join,所以用left join union all right join来实现
select a.table_schema,
a.table_name,
a.column_name,
b.table_schema,
b.table_name,
b.column_name
from information_schema.columns a
left join information_schema.columns b on a.table_name = b.table_name and a.column_name =
b.column_name and b.table_schema = 'DBNAMe1'
where a.table_schema = 'DBNAME2' and
(b.table_name is null or
b.column_name is null)
union all
select a.table_schema,
a.table_name,
a.column_name,
b.table_schema,
b.table_name,
b.column_name
from information_schema.columns a
left join information_schema.columns b on a.table_name = b.table_name and a.column_name =
b.column_name and b.table_schema = 'DBNAME2'
where a.table_schema = 'DBNAME1' and
(b.table_name is null or
b.column_name is NULL) ;