如何修改mssql数据库编码

MSSQL数据库的编码如何更改编码,我有一个数据库里面有几个表,有些表修改数据正常,有些表修改后是乱码,找服务商说我那些表是不同一个工具创建的,有些是utf-8编码有些是... MSSQL数据库的编码如何更改编码,我有一个数据库里面有几个表,有些表修改数据正常,有些表修改后是乱码,找服务商说我那些表是不同一个工具创建的,有些是utf-8编码有些是GBK编码的,所以有些表正常,有些表数据变成了乱码,我要如何才可以查询到这些表的编码还有如何修改,我装了SQL2008里面没看到有这些功能
修改数据的ASP代码如下
if request("editto")="yes" then
Set rs = Server.CreateObject("ADODB.Recordset")
sql="select * from cdma where id="&request("id")&""
rs.open sql,conn,1,3
if not rs.eof then
rs("number")=request("number")
rs("huafei")=request("huafei")
rs("dls")=request("dls")
rs("kzzt")=request("kzzt")
rs("xsy")=request("xsy")
rs("buyer")=request("buyer")
rs("remark")=request("remark")
rs("cs")=rs("cs")+1
rs.update
Response.Write("<script language=""JavaScript"">;history.go(-2);</script>")
response.end
end if
end if

帮看下是不是代码存在问题
展开
 我来答
可以叫我表哥
推荐于2016-06-22 · 知道合伙人数码行家
可以叫我表哥
知道合伙人数码行家
采纳数:25897 获赞数:1464978
2010年毕业于北京化工大学北方学院计算机科学与技术专业毕业,学士学位,工程电子技术行业4年从业经验。

向TA提问 私信TA
展开全部
sql server 2000的unicode编码有特殊性,仅仅在rails中使用utf8编码,和把全部rails项目文件格式改成utf8之外,还是不够的。仅仅这样做,只是部分中文字符能够正确处理,而且存入sql server2000中的中文数据,也完全是乱码。正确的配置方法应该如下。

1. ms sql server2000中数据字段全部要选择成n打头的类型,比如ntext,nvarchar等。

2.安装ADO Driver
安装one -click installer 来安装ruby 的话就已经安装了所有连接SQL Server使用的需求包.但是,并没有安装ADO Driver.
这样来安装它:

在Ruby目录下找到这个目录: \ruby\lib\ruby\site_ruby\1.8\DBD .例如:我的Ruby安装在D:\ruby中,所以是这个目录D:\ruby\lib\ruby\site_ruby\1.8\DBD 在该目录中创建一个ADO文件夹. 下载Ruby-DBI,将lib/dbd_ado/ADO.rb文件拷贝到X:/ruby/lib/ruby/site_ruby/1.8/DBD/ADO/ADO.rb

3. 配置database.yml:Java代码
development:
adapter: sqlserver
database: database_name
host: server_name
username: user_name
password: your_pw_here

development:
adapter: sqlserver
database: database_name
host: server_name
username: user_name
password: your_pw_here

4.在environment.rb添加下面代码
require 'win32ole'
WIN32OLE.codepage = WIN32OLE::CP_UTF8

在这里稍微解释下第四部分的设置。sql server 2000中使用的unicode 并非是utf8,ado的默认链接编码都是当前系统设置的code pages相关的。

一般的windows设置都是非unicode的,比如简体中文windows系统下一般都是gb2312, 在rails中database.yml设置encoding: utf8,对于sql server没有任何用处。

为了迫使sql server接受utf8数据,必须修改ado链接的code pages值为utf8,才能让ado部分代码在接受rails传入的utf8数据之后,不做任何额外的处理. 否则的话,ado部分代码会根据当前系统的默认code pages值来处理这里字符数据。

于是在中文windows系统上,从utf8的rails项目中传入的数据,会被当作gb2312编码的数据来传递到sql server2000中,于是sql server2000中存入的数据会成为乱码,也有部分数据在处理过程中出错,导致sql 语句执行出错。比如常见的中文字符右边的单引号会不见的情况。

不设置 WIN32OLE.codepage = WIN32OLE::CP_UTF8,你的整个系统编码配置是这样的
rails(utf8)<-->ado(根据当前系统cp来取得编码,或是gb2312或是其他)<-->sql server 2000 (unicode)
整个系统编码不一至 。

WIN32OLE.codepage = WIN32OLE::CP_UTF8 这句代码就是为了更改cp值.整个系统编码配置是这样的
rails(utf8)<-->ado(utf8)<-->sql server 2000 (unicode)
整个系统编码一至,整个系统中不会再出现任何乱码。
blacklong
2013-01-08 · TA获得超过1500个赞
知道大有可为答主
回答量:2745
采纳率:0%
帮助的人:1242万
展开全部
得重新建表吧,建表时选择正确的排序规则就行了,然后把数据导入。
追问
所有表的排序规则是默认的:Chinese_PRC_CI_AS,字段是:nvarchar
新创建表时没看到有哪里有设置编码的,
追答
排序规则就决定了编码。你用什么语言操作数据库的?
-----------------------------------
服务器和客户端都是简体中文系统吗?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
darkmummy
推荐于2016-11-26 · TA获得超过327个赞
知道小有建树答主
回答量:132
采纳率:0%
帮助的人:32.4万
展开全部
你可以使用
SELECT COLLATIONPROPERTY('Chinese_PRC_Stroke_CI_AI_KS_WS', 'CodePage')

查看当前的编码格式,但是我编程这么多年,没有去刻意设置过数据库的编码,如果要放中文或者其他文本,用普通的varchar或者nvarchar都没出现过问题
更多追问追答
追问
我的表的数据都采用默认排序规则Chinese_PRC_CI_AS,字段也是用nvarchar,有部份表数据正常,有部份表的数据修改成功后中文部份变成乱码,网页代码没有指定编码写入,修改数据成功后,当时还是显示正常的,登录数据库查看也是正常的,然后数据会在十几到几十分钟左右就自动变成乱码,找过万网技术说有这几个表的编码不同所以有些正常有些乱码,自己没学过这个,摸索好久还是没解决,麻烦帮分析下原因,要如何解决
追答
SQL里面不想MYSQL,需要单独制定数据库编码的,通常你默认的Chinese_PRC_CI_AS排序规则就决定了编码。十几分钟之后变成乱码的现象是只有你的表是这样,还是所有的表都这样,有没有试过新建一个表试试?另外有没有排除过是网页在那十几分里面更新了数据,所以导致有乱码?
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式