1:問題故障描述 因為在linux下開發,所以修改mysql字段的時,用的phpmyadmin來直接修改生成修改后的sql,然后復制進word(libreoffice)后提交到項目管理系統, 同事發到項目管理系統后不能運行.于是有了這篇文章. 2:首先新建表 1.CREATE TABLE IF NOT EXISTS `nns_
1:問題故障描述
因為在linux下開發,所以修改mysql字段的時,用的phpmyadmin來直接修改生成修改后的sql,然后復制進word(libreoffice)后提交到項目管理系統,
同事發到項目管理系統后不能運行.于是有了這篇文章.
2:首先新建表
1.CREATE TABLE IF NOT EXISTS `nns_ad_log_count` (?
2.? `nns_id` char(32) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL COMMENT ‘廣告ID’,? 3.? `nns_access_type` tinyint(4) NOT NULL COMMENT ‘0:5m 1:1h 2:24h=1d’,? 4.? `nns_access_day` date NOT NULL COMMENT ‘哪一天的’,? 5.? `nns_access_index` int(11) NOT NULL COMMENT ‘間隔數,5m 1h 1d=24h’,? 6.? `nns_access_count` int(11) NOT NULL? 7.) ENGINE=InnoDb DEFAULT CHARSET=utf8;?
這步是OK的.
接著因為項目擴展,增加了1個字段,同時需要修改一個表的字段名和另外幾個表的default 默認值和類型
1.ALTER TABLE `nns_ad_log_count` CHANGE `nns_id` `nns_ad_id` CHAR( 32 ) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL COMMENT ‘廣告ID’;?
上面這步,是用的phpmyadmin添加的字段后生成的一句sql, 看上去是沒問題的,復制到word里面,再拿到mysql里面執行一下
報錯了.百思不得其解,
為什么會這樣子呢?
3: 錯誤分析.
生成的sql,是干凈的, 途中同事只粘貼進了word.
于是手寫了一遍這個sql,并且在mysql里面運行 (為了測試,我復制了上面的表結構,并且新建了一個測試的表`nns_ad_log_count1`)
運行正常
同事只復制了一次,粘貼到了word (libreoffice)
我重復一下他的動作
“1. 先用瀏覽器打開phpmyadmin,在phpmyadmin里面直接修改一次,產生sql語句”
“2. 在phpmyadmin 里面,復制生成的sql到系統的剪貼板緩存”
“3. 粘貼進word”
“4. 重復其他的修改操作,重復1,2,3步”
“5. 把整個word發送給我”
“6. 我把word里面的sql拷貝出來,運行 “
“7. 報錯”
打開word,發現sql的語句的空格在word里面高亮了
但是在mysql里面直接執行并沒能看見這個東西,在phpmyadmin里面執行上面的sql
空格顯示出來了,原來是這個?
自此問題已經明了.sql語句在復制到word后給污染了. 但是為什么會這樣子污染呢? 發現只有word粘貼進去后,會把utf8下的空格換成?
這個應該是linux下的office工具的問題, 這里就不再陳述了
4: 后記, 在linux下做開發提交的sql語句,
建議復制到vim里面查看詳細的格式,
或者更簡單的,復制出來后,在瀏覽器地址欄粘貼一次再復制進word來提交文檔.以免sql變臟出錯