I'll be back!

            Focus on BPM, celebrate PegaRULES Process Commander (PRPC)
          posts - 76, comments - 161, trackbacks - 0, articles - 2
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          無法解決 equal to 操作中 "SQL_Latin1_General_CP1_CI_AS" 和 "Chinese_PRC_CI_AS" 之間的排序規則沖突。
          Cannot resolve the collation conflict between SQL_Latin1_General_CP1_CI_AS and Finnish_Swedish_CI_AS in the equal to operation.

          網上有很多解決辦法,但基本上都要改動SQL語句。

          工作中,從國外得到一個MS SQL Server 2005的備份文件,打算把他還原到本地服務器使用里面的數據。

          本地操作系統是MS Windows XP Professional 英文版,安裝了MS SQL Server 2005 開發版,還原數據庫后,運行數據出現錯誤如下:
          “無法解決 equal to 操作中 "SQL_Latin1_General_CP1_CI_AS" 和 "Chinese_PRC_CI_AS" 之間的排序規則沖突。”

          檢查數據庫發現:SQL Server 2005服務器的排序規則是"Chinese_PRC_CI_AS",而數據庫的排序規則是"SQL_Latin1_General_CP1_CI_AS",在網上查詢得知,原因是這兩種排序規則不統一所致。我嘗試過兩種方法讓他們統一,但結果都無效:
          1。 更改數據庫的排序規則為"Chinese_PRC_CI_AS"。通過SQL Server Management Studio圖形界面Property-Options-Collaction或SQL語句“ALTER DATABAS [DBName] COLLATE Chinese_PRC_CI_AS”更改無效。
          2。 重構數據庫“setup.exe /qn INSTANCENAME=SQL2005 REINSTALL=SQL_Engine REBUILDDATABASE=1 SAPWD=sa2005 SQLCOLLATION=SQL_Latin1_General_CP1_CI_AS” 方法無效。

          后來研究了很多種方法,如下載SQL Server 2005企業版安裝,但是企業版不適合安裝在XP Professional系統上,以失敗告終。

          最后實在沒辦法,決定在此重裝SQL Server,推測原因最可能還是本地系統使用了中文的排序規則,必須讓本Server的地排序規則安裝的時候就設置成"SQL_Latin1_General_CP1_CI_AS",即在純英文操作系統下安裝SQL Server 2005,后來實驗成功。具體方法如下:
          1。 盡管我的操作系統是XP系統,但是“區域語言設置”中全部設置為中文了,當前系統和中文操作系統無異。要讓SQL Server 2005順利安裝,需要將所有“區域語言設置”都切換成英語(美國),這個在中文操作系統中也應該有效。
          2。 安裝MS SQL Server 2005,到“排序規則設置”界面時,系統默認選擇的是以下拉框的形式選擇排序規則的選項,英文狀態下應該默認是“Latin1_General”,切忌不要選擇這個排序規則,需要選擇的是第二個單選框:SQL排序規則(用于確保與舊版本的SQL Server兼容) 這個選項,在列表中選擇“字典順序,不區分大小寫,用于1252字符集。”就ok了,這就是傳說中的"SQL_Latin1_General_CP1_CI_AS"字符集,即英文字符集。

          SQL Server安裝好后,打開SQL Server Management Studio界面查看Server的排序規則,確認為"SQL_Latin1_General_CP1_CI_AS",重新導入外來備份文件,大功告成!


          評論

          # re: 無法解決 equal to 操作中 "SQL_Latin1_General_CP1_CI_AS" 和 "Chinese_PRC_CI_AS" 之間的排序規則沖突  回復  更多評論   

          2010-06-21 10:48 by 18傲骨中文
          數據庫就是令人頭大

          # re: 無法解決 equal to 操作中 "SQL_Latin1_General_CP1_CI_AS" 和 "Chinese_PRC_CI_AS" 之間的排序規則沖突  回復  更多評論   

          2010-07-14 08:49 by MICKLI
          ALTER DATABASE [DBName] COLLATE Chinese_PRC_CI_AS需要在單用戶模式下執行

          ALTER DATABASE [DBName] SINGLE_USER WITH ROLLBACK IMMEDIATE;

          # re: 無法解決 equal to 操作中 "SQL_Latin1_General_CP1_CI_AS" 和 "Chinese_PRC_CI_AS" 之間的排序規則沖突  回復  更多評論   

          2011-12-28 11:01 by stalwartwill
          暈,現在我的機器上需要用兩個數據庫,但兩個數據庫需要的排序規則不一樣。。。。

          # re: 無法解決 equal to 操作中 "SQL_Latin1_General_CP1_CI_AS" 和 "Chinese_PRC_CI_AS" 之間的排序規則沖突  回復  更多評論   

          2014-10-20 18:01 by 勇敢的心
          FROM A INNER JOIN
          B ON (A.CODE BETWEEN B.From collate SQL_Latin1_General_CP850_BIN AND B.To collate SQL_Latin1_General_CP850_BIN )
          AND (A.[NO] BETWEEN B.From collate SQL_Latin1_General_CP850_BIN AND B.To collate SQL_Latin1_General_CP850_BIN)

          字段后面加上更改后的排序規則即可
          collate SQL_Latin1_General_CP850_BIN

          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 黔西| 延长县| 张家港市| 广河县| 曲麻莱县| 南京市| 祥云县| 花莲县| 金山区| 繁昌县| 颍上县| 阳谷县| 阳新县| 巴中市| 应城市| 灯塔市| 台中县| 马尔康县| 安乡县| 赣榆县| 余姚市| 大荔县| 中山市| 和林格尔县| 绥棱县| 贵州省| 青海省| 青岛市| 安康市| 彩票| 舞阳县| 新龙县| 屏东县| 沙雅县| 东丽区| 吉林市| 建昌县| 南皮县| 兴隆县| 巩留县| 潞西市|