INTERVAL 1 MONTH
尝试过用这个 但没搞出来。
查询当前月的sql
SELECT * FROM 表名 WHERE DATE_FORMAT( 时间字段名, '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' )
查询指定月的sql
SELECT * FROM 表名 WHERE DATE_FORMAT( 时间字段名, '%Y%m' ) =#{date时间}
前台输入了2022年4月,你用它拼接成两个时间,一个2022-04-01,一个2022-04-30,不就可以去数据库里筛了吗
select * from a where year(date)='2022' and month(date)='04'
你前台传给后台的值是什么?"202204"还是 "2022-04" 还是"2022-04-01".....?
如果你前台已经固定了传值,那么根据不同的格式,你可以在数据库里,通过格式化函数以及日期加减函数,把这个字符串转换成 2022-04-01 和 2022-04-30 两个日期,然后拼到sql里去用between and 作为条件;
如果你前台可以改,那么请参考 楼上 @於黾 的答案。
其他几位的回答其实也能用,但是查询效率会低,因为使用了函数来对字段进行处理,走不到索引了,需要对表里的每行数据进行格式化才能进行数据过滤,因此建议在某个阶段获取到两个日期,使用between and进行处理
获取输入的年月,然后调用工具类,然后查询时传入开始日期和结束日期,代码如下,望采纳。如果想要更多日期工具类的处理函数,可以去我的资源下载
日期工具类:https://download.csdn.net/download/qq_34279303/84812651
/**
* 获取指定年月的第一天
* @param year
* @param month
* @return
*/
public static String getFirstDayOfMonth(int year, int month) {
Calendar cal = Calendar.getInstance();
//设置年份
cal.set(Calendar.YEAR, year);
//设置月份
cal.set(Calendar.MONTH, month-1);
//获取某月最小天数
int firstDay = cal.getMinimum(Calendar.DATE);
//设置日历中月份的最小天数
cal.set(Calendar.DAY_OF_MONTH,firstDay);
//格式化日期
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
return sdf.format(cal.getTime());
}
/**
* 获取指定年月的最后一天
* @param year
* @param month
* @return
*/
public static String getLastDayOfMonth(int year, int month) {
Calendar cal = Calendar.getInstance();
//设置年份
cal.set(Calendar.YEAR, year);
//设置月份
cal.set(Calendar.MONTH, month-1);
//获取某月最大天数
int lastDay = cal.getActualMaximum(Calendar.DATE);
//设置日历中月份的最大天数
cal.set(Calendar.DAY_OF_MONTH, lastDay);
//格式化日期
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
return sdf.format(cal.getTime());
}
自己看一下mysql的Date函数