mysql concat 亂碼問題排除
concat('金額小計:',CONVERT(amount,char))
concat('金額小計:',CONVERT(amount,char))
當你慣用了GUI的管理介面之後,你指令會忘的很快
以前在處理Mysql時多半都使用GUI管理介面,所以一些指令都忘的差不多了
在此記下來,以後如還有相同的任務,就可以快點進行啦!!
啟動mysql (指定參數檔)
停止mysql,有很多方式可以停,在此介紹幾個算是正規的停法
安裝成Windows 服務
移除服務如下:
mysqld remove
建立使用者(開放給本機的john 或是不限任何主機的may,連線密碼為123456)
權限設定(YOURDB內所有表單的權限開放給本機的root,連線密碼為123456)
更改密碼
也可以用這樣的方式更改密碼
mysql>set password for USER = password('YOUR NEW PASSWORD'); //更改user密碼
建立資料庫並指定編碼
顯示目前有多少資料庫
顯示目前資料庫有多少表格
切換使用中的資料庫
設定Client 溝通connection的編碼語系
還原資料庫
或是在console之中
mysql>SOURCE c:/backup-db.sql
備份資料庫
Insert Select 的語法,不太常用,但要使用時沒有作用就覺得很討厭,在一個蠻舊版的Mysql上,臨時有這個需求才發現顯示了原來這個語法在舊版本Mysql是不支援的。
在以下的連結有人就有說到在4.1.6後的版本就都可以用了….可惡!! 我的版本是4.0.16…無言!
http://dev.mysql.com/doc/refman/5.0/en/insert-select.html
This refers to mysql 4.1.6 and later versions for sure.
既然不能用,只好用土法練鋼法,當要新增大量資料時,可以使用EXCEL 來進行產生SQL檔(如果你有一些mysql 工具就不用這麼克難了,我是在執行的環境沒有才出此下策),怎麼產生呢?
利用excel 寫好insert 指令,把各值放到其它的欄位,這樣就可以整行COPY 過來產生SQL 語法,如下圖:
這邊要記住,在excel 的欄位如果字首要有單引號出現,就要輸入兩個單引號才會出現
好,當完成後就可以COPY 貼到文字檔,這時還要做一個動作,就是置換TAB
因為COPY 過來的insert 指令各欄位之間會用TAB符號區隔,這樣是不合用的
所以再把TAB符號換成空字串就完工了!!
備註: 9/20 update
後來經測試,好像4.0.16的版本是可以支援insert select 的,不過能支援的語法比較單純,就是只能
insert into newtable select * from oldtable;
不能指定欄位
如何下SQL指令從另一個TABLE取資料更新要更新的TABLE呢?
以下介紹三種指令都可以達到:
雖然很簡單,不過還是寫出來分享給大家~^^
最近在重裝MYSQL資料庫,用懶人法將舊的資料庫實體檔案搬過來用,重啟時發現雖然可以啟動但好像無法使用
並出現
後來上網查,得知會有這原因是因為現在的版本有做了相容性的偵測,所以要下指令進行升級才行
(怎麼5.1.31=>5.1.42就不能用啦@@),指令如下:
執行後記得要重新啟動MYSQL才能正常使用
後記,雖然有相容升級的修正程式,但有發現有參數(ex:default-time-zone= “UTC”)是用了舊版的資料庫是無法使用的,一用了就會無法啟動,所以還是不要偷吃步的好,還是先dump出來再import進去尤佳
參考資料:http://bbs.linuxtone.org/thread-5512-1-1.html
近期留言