在SQL 2005中用T-SQL插入中文数据时出现的问号或乱码的解决方案[转]

简介:

在SQL 2005中用T-SQL插入中文数据时出现的问号或乱码的解决方案

病症表现为:主要表现为用T-sql语句插入中文数据时数据库显示全是问号“???” 
解决办法:

第一种办法:先选中出错的数据库→选中以后右键点击属性会弹出数据库属性 对话框→选中数据库属性对话框中的选项→把选项中的排序规则设置成:Chinese_PRC_90_CI_AS→最后点击确定即可。
注意:在选择数据库属性的时候必须确保你所修改的数据库未被使用才可以修改否则会失败的

第二种办法:首先打开你的sql查询分析器(新建查询),然后输入以下代码执行即可:

ALTER DATABASE 数据库名 COLLATE Chinese_PRC_90_CI_AS
例如: 

USE master
GO
ALTER DATABASE mydb COLLATE Chinese_PRC_CI_AS 


解析原因:出现以上情况主要是因为数据库属性的排序规则设置不正确,在Microsoft SQL Server 2005 中,字符串的物理存储由排序规则控制。排序规则指定表示每个字符的位模式以及存储和比较字符所使用的规则。
排序规则名称由两部份构成,前半部份是指本排序规则所支持的字符集。
如:
Chinese_PRC_90_CI_AS

前半部份:指UNICODE字符集,Chinese_PRC_指针对大陆简体字UNICODE的排序规则。
排序规则的后半部份即后缀 含义: 
_BIN 二进制排序 
_CI(CS) 是否区分大小写,CI不区分,CS区分
_AI(AS) 是否区分重音,AI不区分,AS区分   
_KI(KS) 是否区分假名类型&defKI不区分,KS区分 
_WI(WS) 是否区分宽度 WI不区分,WS区分 

区分大小写:如果想让比较将大写字母和小写字母视为不等,请选择该选项。
区分重音:如果想让比较将重音和非重音字母视为不等,请选择该选项。如果选择该选项,比较还将重音不同的字母视为不等。
区分假名:如果想让比较将片假名和平假名日语音节视为不等,请选择该选项。
区分宽度:如果想让比较将半角字符和全角字符视为不等,请选择该选项(完)。
欢迎加群互相学习,共同进步。QQ群:iOS: 58099570 | Android: 330987132 | Go:217696290 | Python:336880185 | 做人要厚道,转载请注明出处!http://www.cnblogs.com/sunshine-anycall/archive/2011/03/04/1971122.html
相关文章
|
16天前
|
SQL
sql语句将数字格式修改为字符
sql语句将数字格式修改为字符
|
9月前
|
SQL 关系型数据库 MySQL
mysql 进行update时,要更新的字段中有单引号或者双引号导致不能批量生成sql的问题...
mysql 进行update时,要更新的字段中有单引号或者双引号导致不能批量生成sql的问题...
153 0
|
SQL
where like,SQL 提供了四种匹配方式
where like,SQL 提供了四种匹配方式
257 0
|
SQL Oracle 关系型数据库
在plsql , sql语句中带有中文的查询条件查询不到数据
在plsql , sql语句中带有中文的查询条件查询不到数据
351 0
在plsql , sql语句中带有中文的查询条件查询不到数据
|
SQL 关系型数据库 MySQL
字符编码,竟然也是 SQL 不走索引的元凶之一。。
引言 某个忙(mo)碌(yu)的下午,旁边的刘哥(老江湖,从业5年+)突然发出了一声叹息:“哎,mysql 出bug了,有索引不走”。 作为一个热心的人,我立即说到:“是不是,对索引字段做了函数操作”。
56 0
字符编码,竟然也是 SQL 不走索引的元凶之一。。
|
SQL 数据库
SQLServer 数据库字符集、版本号sql语句查询语法
SQLServer 数据库字符集、版本号sql语句查询语法
371 0
SQLServer 数据库字符集、版本号sql语句查询语法
|
SQL
mssql sql语句过滤百分号的方法分享
原文:mssql sql语句过滤百分号的方法分享 转自:http://www.maomao365.com/?p=6743  摘要: 下文讲述sql脚本中过滤百分号的方法: 实验环境:sql server 2008 R2  百分号:在sql脚本编写中“百分号”被界定为一种通配符,那么如果我们需检索数据中是否存在百分号时,需采用何种方法呢?下文通过实例的方式分析百分号的匹配方式。
882 0