***** Ruby on Rails 实践 读书笔记一 *****
ruby script\generate model book
ruby script\generate controller book
Rails连接Sql Server问题
从
RubyForge下载
dbi-0.2.2.tar.gz

,\lib\dbd\ADO.rb复制到Ruby安装目录\lib\ruby\site_ruby\1.8\DBD\ADO 下,更改config\database.yml。
# SQLite version 3.x
# gem install sqlite3-ruby (not necessary on OS X Leopard)
development:
adapter: sqlserver
database: mybook
host: localhost
username: sa
password: dol
# Warning: The database defined as "test" will be erased and
# re-generated from your development database when you run "rake".
# Do not set this db to the same as development or production.
test:
adapter: sqlserver
database: mybook
host: localhost
username: sa
password: dol
production:
adapter: sqlserver
database: mybook
host: localhost
username: sa
password: dol
新版本Rails的scaffold问题
ruby script/plugin install scaffolding
ruby script/plugin install http://tools.assembla.com/svn/breakout/breakout/vendor/plugins/classic_pagination/
暂时不明白这个指令的含义
ruby script\generate scaffold book title:string description:text buydate:datetime
http://127.0.0.1:3000/book/new能够打开,但点击Create报错
Unknown action
No action responded to /book/created
***** Rails安装问题 *****
使用rubygems安装rails,执行远程命令
gem install rails,但不知为何始终无法成功,可能是网络问题,报错信息如下:
引用
ERROR: While executing gem ... (Gem::RemoteFetcher::FetchError)
SocketError reading http://gems.rubyforge.org/gems/activerecord-2.1.1.gem
于是决定手动安装,在
RubyForge下载
rails-2.1.0.zip

和
rails-2.1.0.gem

,存于F:\Ruby\source目录下,在此路径下执行
gem install rails rails-2.1.0.gem,依旧同样错误。
执行
gem update --system更新gem版本后,执行
gem -v查看版本已从0.9.4升至1.3.0。
再次安装:
引用
F:\Ruby\source>
gem install rails rails-2.1.0.gem
Successfully installed activeresource-2.1.1
Successfully installed rails-2.1.1
ERROR: could not find gem rails-2.1.0.gem locally or in a repository
2 gems installed
Installing ri documentation for activeresource-2.1.1...
Installing RDoc documentation for activeresource-2.1.1...
F:\Ruby\source>
gem -v
1.3.0
F:\Ruby\source>
gem install rails
Successfully installed rails-2.1.1
1 gem installed
F:\Ruby\source>
rails -v
Rails 2.1.1
***** Ruby on Rails 实践 读书笔记二 *****
反复试了几个小时,终于在我的Sql Server 2000环境中完成实践里的CRUD功能。
1、下载
sqlserver_adapter.rb

存于{Ruby安装目录}\lib\ruby\gems\1.8\gems\activerecord-2.1.1\lib\active_record\connection_adapters下。
2、下载
dbi-0.2.2.tar.gz

,解压后将\lib\dbd\ADO.rb复制到{Ruby安装目录}\lib\ruby\site_ruby\1.8\DBD\ADO下。
3、执行F:\Ruby\railsdoc>
rails booksample2(railsdoc是我的项目目录)创建工程文件夹,rails将生成该应用程序的完整目录结构。
4、修改booksample2\config\database.yml文件,如下:
adapter: sqlserver
database: mybook
host: localhost
username: sa
password: dol
5、执行F:\Ruby\railsdoc\booksample2>
ruby script/generate scaffold Book title:string description:text buydate:date,为Book类创建更多相关的数据库移植文件及model、controller、views文件。
6、先后执行
rake db:create创建数据库和
rake db:migrate创建表结构,但发生了以下错误:
引用
F:\Ruby\railsdoc\booksample2>
rake db:create
(in F:/Ruby/railsdoc/booksample2)
F:\Ruby\railsdoc\booksample2>
rake db:migrate
(in F:/Ruby/railsdoc/booksample2)
rake aborted!
Open
OLE error code:80004005 in Microsoft OLE DB Provider for SQL Server
无法打开登录 'mybook' 中请求的数据库。登录失败。
HRESULT error code:0x80020009
发生意外。
(See full trace by running task with --trace)
打开数据库发现数据库并未建立
(Why?...),于是在企业管理器中手动新建了一个名为mybook的数据库,再执行
rake db:migrate,如下(如不执行此命令而手动建表的话,Create时会显示主键字段无法插入NULL值的错误信息):
引用
F:\Ruby\railsdoc\booksample2>
rake db:migrate
(in F:/Ruby/railsdoc/booksample2)
== 20081012063300 CreateBooks: migrating ======================================
-- create_table(:books)
-> 0.0150s
== 20081012063300 CreateBooks: migrated (0.0310s) =============================
7、执行
ruby script/server以启动WEBrick服务器,如下:
引用
F:\Ruby\railsdoc\booksample2>
ruby script/server
=> Booting WEBrick...
=> Rails 2.1.1 application started on http://0.0.0.0:3000
=> Ctrl-C to shutdown server; call with --help for options
[2008-10-12 14:40:25] INFO WEBrick 1.3.1
[2008-10-12 14:40:25] INFO ruby 1.8.6 (2007-09-24) [i386-mswin32]
[2008-10-12 14:40:25] INFO WEBrick::HTTPServer#start: pid=3948 port=3000
8、在浏览器键入http://127.0.0.1:3000/books打开页面,但却发现输入中文是乱码,且Create后报错,如下:
引用
DBI::DatabaseError: Execute OLE error code:80040E10 in Microsoft OLE DB Provider for SQL Server
至少一个参数没有被指定值。
9、在booksample2\config\environment.rb文件中添加如下代码:
引用
require 'win32ole'
WIN32OLE.codepage = WIN32OLE::CP_UTF8
10、Ruby on Rails实例中的CRUD功能就完成了,如下图所示:
引用
F:\Ruby\railsdoc\booksample2>ruby -v
ruby 1.8.6 (2007-09-24 patchlevel 111) [i386-mswin32]
F:\Ruby\railsdoc\booksample2>rails -v
Rails 2.1.1
F:\Ruby\railsdoc\booksample2>gem -v
1.3.0
原空间地址:
http://rc.org.cn/9571/spacelist-blog.html