mysql日期類型默認值’0000-00-00’ 報錯
問題描述
如題,本來是 從另一個數據庫中導出的sql文件,在我電腦上導入報這個錯誤,不知道是不是mysql 版本問題。多方搜索無果,所以上來求助。
DROP TABLE IF EXISTS `workreport_member`;CREATE TABLE `workreport_member` ( `uid` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT ’用戶ID’, `nickname` char(16) NOT NULL DEFAULT ’’ COMMENT ’昵稱’, `sex` tinyint(3) unsigned NOT NULL DEFAULT ’0’ COMMENT ’性別’, `birthday` date NOT NULL DEFAULT ’0000-00-00’ COMMENT ’生日’, `qq` char(10) NOT NULL DEFAULT ’’ COMMENT ’qq號’, `score` mediumint(8) NOT NULL DEFAULT ’0’ COMMENT ’用戶積分’, `login` int(10) unsigned NOT NULL DEFAULT ’0’ COMMENT ’登錄次數’, `reg_ip` bigint(20) NOT NULL DEFAULT ’0’ COMMENT ’注冊IP’, `reg_time` int(10) unsigned NOT NULL DEFAULT ’0’ COMMENT ’注冊時間’, `last_login_ip` bigint(20) NOT NULL DEFAULT ’0’ COMMENT ’最后登錄IP’, `last_login_time` int(10) unsigned NOT NULL DEFAULT ’0’ COMMENT ’最后登錄時間’, `status` tinyint(4) NOT NULL DEFAULT ’0’ COMMENT ’會員狀態’, PRIMARY KEY (`uid`), KEY `status` (`status`)) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 COMMENT=’會員表’;
下面這是在Sequel Pro 導入時報的錯誤
不知道我說清楚了沒……
剛才又嘗試了一下,我把值改成
`birthday` date NOT NULL DEFAULT ’0001-01-01’ COMMENT ’生日’, 貌似就可以了,有點迷惑,之前的sql 是從windows的navcat導出來的, 導入是在MAC 的Sequel Pro 導入的。
問題解答
回答1:MySQL 5.7 以上版本默認禁止 0000-00-00 的日期。在 MySQL 的配置文件 [mysqld] 區域添加
sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_pISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'
然后重啟 MySQL
回答2:hyrijk用戶已經提出解決方案,http://www.07net01.com/2016/04/1479450.html對sql_mode有此許補充說明
相關文章:
1. javascript - 下面的這段算法代碼求解釋2. javascript - 在top.jsp點擊退出按鈕后,right.jsp進行頁面跳轉,跳轉到login.jsp3. javascript - js 有什么優雅的辦法實現在同時打開的兩個標簽頁間相互通信?4. android - 哪位大神知道java后臺的api接口的對象傳到前端后輸入日期報錯,是什么情況?求大神指點5. css3 - 在sublime text里, 如何讓emmet生成的帶前綴css屬性垂直對齊?6. mac連接阿里云docker集群,已經卡了2天了,求問?7. javascript - 回調函數和閉包的關系8. java - spring-data Jpa 不需要執行save 語句,Set字段就可以自動執行保存的方法?求解9. [前端求職必看]前端開發面試題與答案精選_擴展問題10. 想找個php大神仿個網站。
