浏览 10931 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2007-02-12
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: 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) 整个系统编码一至,整个系统中不会再出现任何乱码. 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2007-03-06
非常感谢,这个方法管用。我已经在sqlserver 2000和2005下测试通过。
|
|
返回顶楼 | |
发表时间:2007-09-15
可是可以的,但是第一条不是必须的。。。
另外数据库连接中的host应该是这样的 development: adapter: sqlserver database: pubs host: DBI:ADO:Provider=SQLOLEDB;Data Source="127.0.0.1";Initial Catalog="pubs";User Id="sa";password="123456"; username: sa password: 123456 |
|
返回顶楼 | |