[精讚] [會員登入]
12643

[MYSQL] 設定字串欄位的預設值

新增表格的時候,字串欄位給予預設空值;數字欄位給預設數值;日期欄位給空值。

分享此文連結 //n.sfs.tw/10265

分享連結 [MYSQL] 設定字串欄位的預設值@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2019-10-25 11:32:05 最後編修
2016-11-21 13:01:02 By 張○○
 

自動目錄

可能是這近更新Mysql的關係,發現原本預設是not null的字串欄位,開始不能不給值寫入了。雖然not null寫入一定要有值這很合理,但是要改的程式很多,所以我反而想尋找比較懶的解決方法。

解決方法只要在新增表格的時候,字串欄位給予預設空值;數字欄位給預設數值;日期欄位給空值:

CREATE TABLE IF NOT EXISTS `table1` (
  `sn` int(11) NOT NULL auto_increment,
  `title` varchar(100) collate utf8_bin NOT NULL default '',
  `display` tinyint(4) NOT NULL default '1',
  `uDT` timestamp NOT NULL default '0000-00-00 00:00:00'
);

如果是現有表格,使用SQL修改語法:

字串欄位
ALTER TABLE `table1` CHANGE `col1` `col1` VARCHAR(6) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL DEFAULT '';

數字欄位
ALTER TABLE `hwList` CHANGE `num1` `num1` MEDIUMINT( 9 ) NOT NULL DEFAULT '0';
 
日期欄位
ALTER
TABLE `hwList` CHANGE `DT1` `DT1` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00';
 
此操作字串欄位不能用mysqladmin 2版來幫忙,因為那個預設值的欄位無法填入空字串,不過3版以後可以:

改完以後,就能夠新增資料,但不必給not null欄位值。這和設定成null但不給值的差異在於,如果設定成null但不給值新增的話,該欄位會變成NULL,未來作select就要很小心:

select * from table1 where col1='' 會取不到 col1=NULL的資料。
select * from table1 where isnull(col1) 會取不到 col1=''的資料。

最後說phpMyadm已經出到4版了,是該升級了。

參考資料

[1] http://stackoverflow.com/questions/3357953/default-a-column-with-empty-string

END

你可能感興趣的文章

兩次使用InnoDB的慘痛經驗 Mysql 的Innodb引擎雖然好用,但是我得說說我兩次的慘痛經驗,這讓我考慮以後可能不會再使用innodb了

[Mysql/MariaDB] 使用Memory引擎修改及設定最大值的方法 Mysql/MariaDB 使用Memory引擎預設是16MB,修改及設定最大值的方法。

[MySQL] FIND_IN_SET函數,把多筆條件判斷弄成字串 SQL 我們如果要查找某個欄位是否為某個值的時候,如果要判斷的條件很多,可以用這個函數

[MySQL] console mode 的亂碼處理 使用MySQL的console mode如果出現亂碼 在,要怎麼處理?

[Mysql/MariaDB] 加解密函數 Mysql/MariaDB上的加解密函數

[phpmyadmin] 登錄超時 (1440 秒未操作),請重新登錄 phpmyadmin登錄超時 (1440 秒未操作),請重新登錄的問題,該如何解決?

隨機好文

TFTP Server 安裝及使用 讓設備的網路設定檔或是韌體經由TFTP拷備出來,操作的方法

UTF-8的網頁但IE8一片空白 UTF8編碼的網頁在Firefox 正常顯示、但IE8 就是空白,IE8編碼設定是「自動偵測」可是自動偵測到的是 big5...

好用的3+2碼郵遞區號查詢系統推薦 網路上找到用地址輸入判斷3+2碼郵遞區號的辨識率不高,除了這個網站…

最值得學的電腦技能 什麼是最值得學的電腦技能?程式設計?美工繪圖?系統網路?還是…? 都不是!個人覺得一個最值得學的電腦技能就

維修海棉拖把頭 這類型的海棉拖把很好用,可是這近發現海棉頭越來越不耐用,也許是錯覺,以往都能用個三四個月,現在二個月就差不多掉下來。 這