首頁  >  文章  >  資料庫  >  mysql datetime報錯怎麼辦

mysql datetime報錯怎麼辦

藏色散人
藏色散人原創
2023-02-15 10:12:272324瀏覽

mysql datetime報錯的解決方法:1、將datetime改成時間戳timestamp;2、將MySQL升級為高版本;3、執行「ALTER USER 'root'@'localhost' IDENTIFIED BY 'root1' PASSWORD EXPIRE NEVER;」命令即可。

mysql datetime報錯怎麼辦

本教學操作環境:Windows10系統、MySQL8.0版本、Dell G3電腦。

mysql datetime報錯怎麼辦?

MySQL建表時datetime報錯

在student資料庫中建立stu表,執行以下建表語句

CREATE TABLE stu (
  id int(12) NOT NULL AUTO_INCREMENT,
  name varchar(150) CHARACTER SET utf8 DEFAULT NULL,
  age int(20),
  createTime datetime DEFAULT CURRENT_TIMESTAMP,
  updateTime datetime DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (id)
) ENGINE=InnoDB AUTO_INCREMENT=16 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

報Invalid default value for 'createTime'錯,上網百度說是MySQL5.6之後才支援datetime設定預設值,然後把datetime改成時間戳timestamp。

再次執行時,報 Incorrect table definition; there can be only oneTIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATEclause錯,這個是因為為多個timestamp設定current_timestamp。

最好的解決方法是將MySQL升級到高版本,比如說5.7,8.0,我從官網下載MySQL8.0版後,安裝完成,使用Navicat連接MySQL報2059的錯。據說是因為8.0和之前版本的加密規則不一致所導致的。

使用命令列進入MySQL介面,輸入下面的指令可

#注意:root1是连接数据库的密码,可以更改为自己想用的密码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'root1' PASSWORD EXPIRE NEVER; #修改数据库的加密规则 
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root1'; #更新一下localhost的密码 
FLUSH PRIVILEGES; #刷新权限

 

推薦學習:《MySQL影片教學

以上是mysql datetime報錯怎麼辦的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn