數據庫是MS SQLServer2000,要把SQLServer2000里的一張表的數據導入MySQL5,其中SQLServer2000表的字段以簡體中文命名(強烈建議不要以中文做為字段名)。其實操作就是對SQLServer查詢記錄,插入到MySQL里。選擇 " /> 2012中文字幕手机在线,少女开女包www,麻豆COMCN

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

php mssql擴展SQL查詢中文字段名解決方法

一、問題:

數據庫是MS SQLServer2000,要把SQLServer2000里的一張表的數據導入MySQL5,其中SQLServer2000表的字段以簡體中文命名(強烈建議不要以中文做為字段名)。其實操作就是對SQLServer查詢記錄,插入到MySQL里。選擇的腳本語言是phpphp打開MSSQL和MySQL擴展,對這兩個數據庫操作都是很容易的問題。
問題就出現在SQLServer中表的字段名是中文,寫好的查詢語句在SQLServe里測試是通過有記錄返回,用php的MSSQL擴展查詢就是報錯。
上網查了資料,網上相關的信息不太多,很多網友都認為是php的MSSQL擴展不支持SQL語句中有中文。查了一下資料,php的MSSQL是支持SQL中有中文的語句。出現報錯問題大多是因為編碼的問題,編碼數據庫和編碼與查詢語句編碼不統一,查詢語句到SQLServer里中文部分就成了亂碼,造成查詢失敗。

二、解決方法:

知道了原因,接下來分析解決,確認是編碼不統一的問題。解決分以下幾步:
1、確認SQLServer 數據庫的編碼,我的數據編碼是GBK。
2、確認當前php腳本文件的編碼,我的編碼是UTF-8。
3、轉換SQL查詢語句的的編碼。
補充:有的網友提到要把php的腳本文件編碼轉成和數據庫編碼一致,其實這一步大可不必,只要確認你的SQL語句和數據庫的編碼一致就可以,這里建議不必轉換的原因是如果你的php腳本文件里包含其它php腳本,那也得對所有include或require的腳本文件編碼轉換,不然php腳本編碼不統一很容易出錯,若互相關聯的文件很多,這也是一件很麻煩的問題而且把事情復雜化了。

三、方案:

寫一個轉換函數,在把SQL操作前把SQL語句編碼轉換。下面貼出我的范例代碼:
復制代碼 代碼如下:
//編碼轉換函數
function utf8togb($s) {
return iconv('utf-8', 'gbk//IGNORE', $s); // IGNORE 參數是遇到不成轉換的字符時忽略
}
//建議把所有中文字段用英文別名替換,方便下面操作還有編碼轉換等問題
$sql="SELECT [id], [欄目] as typeid, [正題] as title, [作者] as author, convert(text, [正文]) as body FROM [文章表];";
$sql = utf8togb($sql);

php技術php mssql擴展SQL查詢中文字段名解決方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产亚洲精品在线视频 | 老师洗澡让我吃她胸的视频 | 亚洲宅男天堂a在线 | qvod 在线电影 | 迈开腿让我看下你的小草莓声音 | 久久re6热在线视频精品 | 日本熟妇乱妇熟色在线电影 | 伊人久久综合影院 | 精品欧美小视频在线观看 | 亚洲中文字幕无码爆乳APP | 亚洲免费无码中文在线亚洲在 | 亚洲国产成人在线视频 | 西施打开双腿下面好紧 | 成年妇女免费播放 | 99视频免费在线 | 电影 qvod | 超碰国产视频免费播放 | 午夜影院费试看黄 | 亚洲精品综合在线影院 | 新图解av吧 | 国产AV国片精品无套内谢无码 | 亚洲一区乱码电影在线 | 亚洲精品欧美精品中文字幕 | 欧美残忍xxxx极端 | 国产激情文学 | 18videosex性欧美黑色 | 色橹橹欧美在线观看视频高 | 亚洲国产在线精品国自产拍五月 | 亚洲伊人精品综合在合线 | 忘忧草在线影院WWW日本二 | 伊人网综合| 三色午夜秀 | 全免费A敌肛交毛片免费懂色AV | 秋霞网在线伦理免费 | 极品美女穴 | 国产在线视频一区二区不卡 | xxx日本hd| 亚洲国产精品免费线观看视频 | 丝瓜视频樱桃视频在线观看免费 | xxxxxx视频 | 97人人碰免费视频公开 |