zoukankan      html  css  js  c++  java
  • 在英文版操作系统中安装的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.

    排序规则:原因

  • 相关阅读:
    scala程序启动时,Could not locate executable nullinwinutils.exe in the Hadoop binaries解决方案
    binlog_format的模式有哪几种?各自的特点是?
    解决IDEA控制台junit不能用Scanner输入问题
    【转】什么是乐观锁,什么是悲观锁
    lyt经典版MySQL基础——流程控制结构
    ambari 2.5.0源码编译安装
    linux(centeros)svn的安装
    机器学习
    算法思想整理
    lucene
  • 原文地址:https://www.cnblogs.com/kexxxfeng/p/5690999.html
Copyright © 2011-2022 走看看