有个问题,在写项目做查询的时候,碰到了查询时间,后台现在接收的是一个时间的字符串,例如2023-01-01,如何分别在oracle和mysql中判断出是同一天的记录行,两个数据库存储时间的都是带时分秒的!
2条回答 默认 最新
- 程序员星辰 2023-01-31 19:53关注
在 Oracle 中可以使用 to_date() 函数来转换字符串为日期,然后再使用 trunc() 函数截取到天即可进行比较:
SELECT * FROM table_name WHERE trunc(to_date(column_name,'YYYY-MM-DD')) = to_date('2023-01-01', 'YYYY-MM-DD');
在 MySQL 中可以使用 STR_TO_DATE() 函数来转换字符串为日期,然后再使用 DATE() 函数截取到天即可进行比较:
SELECT * FROM table_name WHERE DATE(STR_TO_DATE(column_name, '%Y-%m-%d')) = '2023-01-01';
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥60 求直线方程 使平面上n个点在直线同侧并且距离总和最小
- ¥50 java算法,给定试题的难度数量(简单,普通,困难),和试题类型数量(单选,多选,判断),以及题库中各种类型的题有多少道,求能否随机抽题。
- ¥50 rk3588板端推理
- ¥250 opencv怎么去掉 数字0中间的斜杠。
- ¥15 这种情况的伯德图和奈奎斯特曲线怎么分析?
- ¥250 paddleocr带斜线的0很容易识别成9
- ¥15 电子档案元素采集(tiff及PDF扫描图片)
- ¥15 flink-sql-connector-rabbitmq使用
- ¥15 zynq7015,PCIE读写延时偏大
- ¥15 使用spss做psm(倾向性评分匹配)遇到问题