1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > MySQL日期字符串转换成NULL值的异常处理

MySQL日期字符串转换成NULL值的异常处理

时间:2019-10-02 12:25:22

相关推荐

MySQL日期字符串转换成NULL值的异常处理

数据库|mysql教程

MySQL转换字符串,MySQL日期字符串转换成NULL值的

数据库-mysql教程

asp档案源码,ubuntu挂载镜像源,tomcat中间件信息泄漏,爬虫抓取数据api,php入门教程11天,seo真实视频lzw

1,YYYYmmdd格式日期转换为null 看如下记录,一个能取到值,一个取不到值** mysqlgt; SELECT DATE_FORMAT(STR_TO_DATE(lsquo;2

直播网站源码php,ibm连接vscode,ubuntu设定为全局代理,tomcat 源码 日志,sqlite内容导出txt,返回顶部js插件,聊天室前端框架,爬虫有的爬不到,php.ini 修改,四处一词seo,模拟申请网站源码下载,精易编程助手网页分析,crm后台管理界面模板,产品列表html5 css3页面,php 信息化管理系统,小程序拼车6.3.3lzw

厂房网站源码,vscode开发go的插件,ubuntu-17.10,启动免安装tomcat,爬虫python感想,php redmine,孝感百度seo技巧,wamp本地搭建网站,dzx3.3 安装 本地模板lzw

1,YYYYmmdd格式日期转换为null

看如下记录,一个能取到值,一个取不到值**

mysql> SELECT DATE_FORMAT(STR_TO_DATE(‘0922 13:01:01’, ‘%Y%m%d %H:%m:%s’),’%H:%m’);

+————————————————————————–+

| DATE_FORMAT(STR_TO_DATE(‘0922 13:01:01’, ‘%Y%m%d %H:%m:%s’),’%H:%m’) |

+————————————————————————–+

| 13:01 |

+————————————————————————–+

1 row in set (0.00 sec)

mysql> SELECT DATE_FORMAT(STR_TO_DATE(‘0922 12:55:00’, ‘%Y%m%d %H:%m:%s’),’%H:%m’);

+————————————————————————–+

| DATE_FORMAT(STR_TO_DATE(‘0922 12:55:00’, ‘%Y%m%d %H:%m:%s’),’%H:%m’) |

+————————————————————————–+

| NULL |

+————————————————————————–+

1 row in set, 1 warning (0.00 sec)

mysql>

2,查看报错信息:

mysql> show warnings;

+———+——+————————————————————————+

| Level | Code | Message |

+———+——+————————————————————————+

| Warning | 1411 | Incorrect datetime value: ‘0922 12:55:00’ for function str_to_date |

+———+——+————————————————————————+

1 row in set (0.00 sec)

mysql>

报警说是Incorrect datetime value: ‘0922 12:55:00’ for function str_to_date,不正确的日期格式,所以换成比较规范的日期格式

3,换成规范的%Y-%m-%d %H:%i:%s试试

mysql> select DATE_FORMAT(str_to_date(‘-09-22 13:00:01’, ‘%Y-%m-%d %H:%i:%s’),’%H:%i’);

+——————————————————————————+

| DATE_FORMAT(str_to_date(‘-09-22 13:00:01’, ‘%Y-%m-%d %H:%i:%s’),’%H:%i’) |

+——————————————————————————+

| 13:00 |

+——————————————————————————+

1 row in set (0.00 sec)

mysql> select DATE_FORMAT(str_to_date(‘-09-22 12:55:00’, ‘%Y-%m-%d %H:%i:%s’),’%H:%i’);

+——————————————————————————+

| DATE_FORMAT(str_to_date(‘-09-22 12:55:00’, ‘%Y-%m-%d %H:%i:%s’),’%H:%i’) |

+——————————————————————————+

| 12:55 |

+——————————————————————————+

1 row in set (0.00 sec)

mysql>

看到在规范的格式下,日期从字符串转换到日期格式,然后截取时分都是能取到值的。

参考官网地址:#function_str-to-date

4,再次确定缩小范围,是%h的问题,将时换成大写就搞定了

再看到一个案例,将格式变成-09-22 13:00:01表准备格式,可以仍然取不到时分值,如下所示:

mysql> select DATE_FORMAT(str_to_date(‘-09-22 13:00:01’, ‘%Y-%m-%d %h:%i:%s’),’%h:%i’);

+——————————————————————————+

| DATE_FORMAT(str_to_date(‘-09-22 13:00:01’, ‘%Y-%m-%d %h:%i:%s’),’%h:%i’) |

+——————————————————————————+

| NULL

|

+——————————————————————————+

1 row in set, 1 warning (0.00 sec)

mysql> select DATE_FORMAT(str_to_date(‘-09-22 12:55:00’, ‘%Y-%m-%d %h:%i:%s’),’%h:%i’);

+——————————————————————————+

| DATE_FORMAT(str_to_date(‘-09-22 12:55:00’, ‘%Y-%m-%d %h:%i:%s’),’%h:%i’) |

+——————————————————————————+

| 12:55

|

+——————————————————————————+

1 row in set (0.00 sec)

mysql>

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。