亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MySQL中日期比較時遇到的編碼問題解決辦法

2024-07-24 13:06:02
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了MySQL中日期比較時遇到的字符集問題解決辦法,本文遇到的問題是date_format函數和timediff函數之間比較時,編碼問題導致出錯,本文使用convert()函數解決了這個問題,需要的朋友可以參考下
 
 

今天幫同事處理一個SQL(簡化過后的)執行報錯:

復制代碼代碼如下:

se/mysql/' target='_blank'>mysql> select date_format('2013-11-19','Y-m-d') > timediff('2013-11-19', '2013-11-20');                                        

 

ERROR 1267 (HY000): Illegal mix of collations (utf8_general_ci,COERCIBLE) and (latin1_swedish_ci,NUMERIC) for operation '>'


乍一看挺莫名其妙的,查了下手冊,發現有這么一段:
復制代碼代碼如下:

The language used for day and month names and abbreviations is controlled by the value of the lc_time_names system variable (Section 9.7, “MySQL Server Locale Support”).

 

The DATE_FORMAT() returns a string with a character set and collation given by character_set_connection and collation_connection so that it can return month and weekday names containing non-ASCII characters.


也就是說,DATE_FORMATE() 函數返回的結果是帶有字符集/校驗集屬性的,而 TIMEDIFF() 函數則沒有字符集/校驗集屬性,我們來驗證一下:
復制代碼代碼如下:

mysql> set names utf8;
mysql> select charset(date_format('2013-11-19','Y-m-d')), charset(timediff('2013-11-19', '2013-11-20'));
+--------------------------------------------+-----------------------------------------------+
| charset(date_format('2013-11-19','Y-m-d')) | charset(timediff('2013-11-19', '2013-11-20')) |
+--------------------------------------------+-----------------------------------------------+
| utf8                                       | binary                                        |
+--------------------------------------------+-----------------------------------------------+

 

mysql> set names gb2312;
mysql> select charset(date_format('2013-11-19','Y-m-d')), charset(timediff('2013-11-19', '2013-11-20'));
+--------------------------------------------+-----------------------------------------------+
| charset(date_format('2013-11-19','Y-m-d')) | charset(timediff('2013-11-19', '2013-11-20')) |
+--------------------------------------------+-----------------------------------------------+
| gb2312                                     | binary                                        |
+--------------------------------------------+-----------------------------------------------+


可以看到,隨著通過 SET NAMES 修改 character_set_connection、collation_connection  值,DATE_FORMAT() 函數返回結果的字符集也跟著不一樣。在這種情況下,想要正常工作,就需要將結果進行一次字符集轉換,例如:
復制代碼代碼如下:

mysql> select date_format('2013-11-19','Y-m-d') > convert(timediff('2013-11-19', '2013-11-20') using utf8);
+----------------------------------------------------------------------------------------------+
| date_format('2013-11-19','Y-m-d') > convert(timediff('2013-11-19', '2013-11-20') using utf8) |
+----------------------------------------------------------------------------------------------+
|                                                                                            1 |
+----------------------------------------------------------------------------------------------+

就可以了

 

P.S,MySQL的版本:5.5.20-55-log Percona Server (GPL), Release rel24.1, Revision 217


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情在线观看视频| 日韩禁在线播放| 77777少妇光屁股久久一区| 日本道色综合久久影院| 日韩视频免费在线| 国内外成人免费激情在线视频| 亚洲国产日韩欧美在线图片| 亚洲人成欧美中文字幕| 欧美日韩国产综合视频在线观看中文| 亚洲激情自拍图| 久久91亚洲精品中文字幕| 精品国产一区久久久| 国产精品亚洲第一区| 日韩最新av在线| 亚洲free性xxxx护士白浆| 亚洲精品欧美日韩专区| 国产成人精品电影久久久| 国产精品极品美女在线观看免费| 69精品小视频| 欧美亚洲在线观看| 欧美在线视频a| 欧美日韩在线观看视频| 国产精品美女久久| 国产综合久久久久久| 久久不射电影网| 欧美疯狂xxxx大交乱88av| 国产伊人精品在线| 日韩免费观看视频| 国产精品亚洲一区二区三区| 亚洲国产精彩中文乱码av| 欧美黄色性视频| 2018中文字幕一区二区三区| 亚洲香蕉av在线一区二区三区| 日韩av三级在线观看| 色偷偷av一区二区三区| 亚洲国产精品专区久久| 亚洲精品wwwww| 久久久精品亚洲| 亚洲人成网站999久久久综合| 欧美日韩国产色| 久国内精品在线| 欧美一区在线直播| 国产综合在线观看视频| 日韩av电影中文字幕| 不卡av电影在线观看| 欧美一级视频一区二区| 欧美激情高清视频| 日韩一区二区三区在线播放| 亚洲第一区中文字幕| 国外视频精品毛片| 日韩在线观看网站| 国产亚洲欧洲黄色| 亚洲午夜未满十八勿入免费观看全集| 国内揄拍国内精品少妇国语| 久久久久成人网| 日韩av电影在线播放| 裸体女人亚洲精品一区| 国内精品久久久久久| 青草青草久热精品视频在线网站| 精品久久久久久中文字幕一区奶水| 国产精品私拍pans大尺度在线| 亚洲精品成人久久| 亚洲美女自拍视频| 欧美一区二区三区免费观看| 国产有码在线一区二区视频| 久久久日本电影| 欧美精品在线网站| 欧美日韩国产精品一区二区三区四区| 日韩成人在线免费观看| 国产精品第七十二页| 日韩美女主播视频| 欧美日韩在线看| 国产z一区二区三区| 国产精品欧美一区二区| 成人午夜在线观看| 亚洲永久免费观看| 日产精品久久久一区二区福利| 992tv成人免费影院| 国产精品入口免费视| 日韩国产高清视频在线| 这里只有视频精品| 欧美多人乱p欧美4p久久| 欧美亚洲日本黄色| 在线视频欧美日韩| 亚洲欧洲一区二区三区在线观看| 国产精品欧美日韩久久| 亚州精品天堂中文字幕| 深夜福利亚洲导航| 国产精品亚洲综合天堂夜夜| 欧美日韩在线看| 久久精品国产精品亚洲| 久久久久久久久久婷婷| 日韩免费在线电影| 91在线精品播放| 亚洲人成网站777色婷婷| 国产欧美在线视频| 97精品一区二区视频在线观看| 九九九久久久久久| 亚洲淫片在线视频| 91精品久久久久久久久久另类| 久久亚洲欧美日韩精品专区| 亚洲最新在线视频| 亚洲一区二区三区在线免费观看| 伊人久久免费视频| 国产精品爽黄69天堂a| www.久久草.com| 欧美大胆在线视频| 久久精品这里热有精品| 夜夜嗨av一区二区三区四区| 欧美成人性色生活仑片| 在线免费看av不卡| 亚洲第一色中文字幕| 97香蕉久久超级碰碰高清版| 亚洲欧美日韩中文视频| 亚洲娇小xxxx欧美娇小| 国产日韩欧美在线视频观看| 成人www视频在线观看| 亚洲新声在线观看| 国产欧美日韩精品专区| 成人午夜激情免费视频| 日韩亚洲欧美中文高清在线| 国产97在线视频| 91tv亚洲精品香蕉国产一区7ujn| 91老司机精品视频| 国产精品午夜国产小视频| 成人午夜一级二级三级| 亚洲精品自产拍| 亚洲精品美女免费| 欧美激情极品视频| 亚洲视频日韩精品| 国产精品精品一区二区三区午夜版| 高清欧美性猛交xxxx黑人猛交| 久久99亚洲热视| 久久精品91久久久久久再现| 中文字幕精品影院| 欧美激情伊人电影| 久久伊人精品天天| 亚洲国产精品人久久电影| 国产精品入口尤物| 成人h视频在线观看播放| 国产精品入口夜色视频大尺度| 国产视频久久久久| 亚洲视频精品在线| 欧美午夜精品在线| 成人午夜在线观看| 日韩精品免费在线观看| 国产精品欧美日韩一区二区| 911国产网站尤物在线观看| 亚洲精品免费网站| 国产99视频精品免视看7| 国产成人涩涩涩视频在线观看| 国产一区二区美女视频| 亚洲天堂成人在线视频| 日韩精品免费综合视频在线播放| 国产成人短视频| 欧美激情中文字幕乱码免费| 日本免费一区二区三区视频观看| 亚洲免费伊人电影在线观看av| 91免费电影网站| 国产成人综合精品在线| 日韩乱码在线视频| 91日本在线观看| 狠狠躁天天躁日日躁欧美| 456亚洲影院|