在英文版操作系统中安装的MS SQL server,中文字段无法匹配

在英文版的操作系统中安装的MS SQL server,会出现中文字段无法被匹配到。其原因在于英文环境下安装的MS SQL server的排序规则不包括中文。

所以解决办法就是更改MS SQL server的排序规则:一般情况下,只需要右键数据库->properties->optiones->collation->chose "Chinese RPC CI AS"->OK.如果执行成功则OK。

但是如果数据库中设置了一些临时表的依赖,那么执行会报错。

解决办法如下:

导出数据->删除数据库->重新创建数据库->导入数据。

使用数据库管理工具:选择数据库,右键菜单->Tasks->Export Data->Data Source:SqlServer Native Client XX.XX->Destination:SqlServer Native Client XX.XX->next...->finish.

然后重新创建数据库,注意!在创建时设置options->collation->chose "Chinese RPC CI AS"。然后恢复表结构,然后导入数据,逆向导出步骤就可以了。

如果报错的话,则很有可能是新建的数据库的表结构的原因,有个好办法就是删除所有的表结构。sql 如下:(出自AlexChen

复制代码
--删除所有约束
DECLARE c1 cursor for
    select 'alter table ['+ object_name(parent_obj) + '] drop constraint ['+name+']; '
    from sysobjects
    where xtype = 'F'
open c1
declare @c1 varchar(8000)
fetch next from c1 into @c1
while(@@fetch_status=0)
    begin
        exec(@c1)
        fetch next from c1 into @c1
    end
close c1
deallocate c1
--删除数据库所有表
declare @tname varchar(8000)
set @tname=''
select @tname=@tname + Name + ',' from sysobjects where xtype='U'
select @tname='drop table ' + left(@tname,len(@tname)-1)
exec(@tname)
复制代码

然后再导入数据。

 

ps:这样做可能会导致数据结构有些问题。

 

导入、导出数据,参考Rei Tu.

排序规则:原因

posted @   蝌蝌  阅读(1902)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
点击右上角即可分享
微信分享提示