數(shù)據(jù)庫是MS SQLServer2000,要把SQLServer2000里的一張表的數(shù)據(jù)導入MySQL5,其中SQLServer2000表的字段以簡體中文命名(強烈建議不要以中文做為字段名)。其實操作就是對SQLServer查詢記錄,插入到MySQL里。選擇 " /> 午夜精品久久久久久久白皮肤,一级毛片视频免费看,成年人黄视频

四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

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

一、問題:

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

二、解決方法:

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

三、方案:

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

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

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

主站蜘蛛池模板: 体温单的绘制及图解| 赵琦| 电影痴汉电车| 诈欺游戏电影| 女子监狱第五季| 欢乐的牧童钢琴谱| 包公决战潘金莲在线观看| 九九九九九九伊人| 美姐妹| 真实游戏完整版高清观看| 无籍者| 单色美甲图片| 张勇手演过的电影| 小敏家| 黄色网址视频| 即将到来1983年美国电影| 8号房间| 男插女曲| 黑暗圣经在线观看| 大追捕电影结局| 性视频免费| 355 电影| 2024年计划生育家庭特别扶助| 大场久美子| 山楂树简谱| 熊出没免费电影| 杨颖电影| 回响电视剧在线观看| 咸猪手| 境界千年血战篇| 声色犬马 电影| 男同性恋免费视频| lol小孩子不能看的动画视频| 浙江卫视直播在线观看高清电视台| 眼光娘娘治眼病口诀| 程门立雪文言文| 我金子般的孩子| 心理健康《微笑的力量》ppt| 伤感的头像| 山田孝之| 花有重开日电影|