forked from fhwang/odbc-rails
-
Notifications
You must be signed in to change notification settings - Fork 0
/
README
229 lines (140 loc) · 7.31 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
= OpenLink ODBC Data Adapter for Ruby on Rails
(C) 2008 OpenLink Software
== Status
<b>23-Apr-2008</b>
The adapter has been updated to support Rails 2.0.2 / ActiveRecord 2.0.2
The new adapter (v2.0) is not recommended for use with earlier releases of
Rails or ActiveRecord.
* For Rails 2.0.2 / ActiveRecord 2.0.2 or later, use odbc-rails v2.0
* For Rails 1.2.x / ActiveRecord 1.15.x, use odbc-rails v1.5
* For Rails 1.1.x / ActiveRecord 1.14.x, use odbc-rails v1.3
The configuration instructions for v1.4 or earlier differ slightly from those
included here for v2.0. Please refer to the documentation packaged with the
respective adapter when using the previous releases.
Added support for DSN-less connections (thanks to Ralf Vitasek).
Added support for SQLAnywhere (thanks to Bryan Lahartinger).
<b>23-Feb-2007</b>
The adapter has been updated to support Rails 1.2.x / ActiveRecord 1.15.x.
The new adapter (v1.4) is not recommended for use with Rails 1.1 / ActiveRecord
1.14.x. Please use v1.3 of the adapter with Rails 1.1.
The driver now supports the new ActiveRecord :decimal type and an
:emulate_booleans connection option. See http://odbc-rails.rubyforge.org for
more information about this option.
<b>09-Jan-2007</b>
The adapter accompanying this note is a Generic ODBC Adapter for Ruby on Rails
being developed by <B>OpenLink Software</B>[http://www.openlinksw.com].
The aim of this development is to provide a single ODBC-based adapter
capable of supporting the most popular DBMSes, in contrast to the
current approach in the Rails community of each database requiring
its own adapter.
It currently supports Ingres r3, Informix 9.3 or later, Oracle 10g,
MySQL 5 and OpenLink's Virtuoso
(Open Source Edition[http://virtuoso.openlinksw.com]),
SQL Server 2000/2005, Sybase ASE 15, DB2 v9, Progress v8/9/10 and PostgreSQL 8.2.
Testing to date has been limited to the ROR 'Expenses' sample
application described at http://developer.apple.com/tools/rubyonrails.html
and the ActiveRecord test modules base_test.rb and migration_test.rb.
Testing has been performed on Linux, Windows and Mac OS X using
OpenLink's own ODBC drivers and the native Virtuoso ODBC client.
== Pre-Requisites
The OpenLink ODBC Adapter for Ruby on Rails needs the
ActiveRecord[http://wiki.rubyonrails.com/rails/pages/ActiveRecord]
package installed.
The Adapter also requires Christian Werner's
Ruby ODBC Bridge[http://www.ch-werner.de/rubyodbc]
(release 0.9991 or later), to bridge to an underlying ODBC driver.
== Contents
In the accompanying sources, the lib directory structure is equivalent
to the lib directory located under ACTIVE_RECORD_ROOT in your main
Ruby tree.
On Windows ACTIVE_RECORD_ROOT will be something like:
c:\ruby\lib\ruby\gems\1.8\gems\activerecord-x.y.z
On Unix and Mac OS X ACTIVE_RECORD_ROOT will be something like:
/usr/lib/ruby/gems/1.8/gems/activerecord-x.y.z
or
/usr/local/lib/ruby/gems/1.8/gems/activerecord-x.y.z
On Mac OS X using Locomotive ACTIVE_RECORD_ROOT will be
something like:
/Applications/Locomotive2/bundles/rails112.locobundle/i386/lib/ruby/gems/1.8/gems/activerecord-x.y.z
lib/ contains the files which constitute the new ODBC adapter.
test/ contains the fixture definitions for testing the adapter.
support/odbc_rails.diff contains some patches to ActiveRecord tests.
The patches to base_test.rb and migration_test.rb are not essential.
However, they modify or bypass certain tests to cope with limitations
of particular databases. Other developers have previously modified
the tests similarly to cope with limitations of other Rails-supported
databases. The patched versions of files touched by odbc_rails.diff can
be found in support/test.
== Installation
There are 3 ways to install the ODBC Adapter package: either as a gem
(recommended), a plugin, or by running the custom installation script. Pick
one of the following, depending on whether you want the adapter to be
available system-wide or just within a particular Rails project.
=== Installation as a Gem
* Install the odbc-rails gem by running:
# gem install -r activerecord-odbc-adapter --include-dependencies
=== Installation as a Plugin
Installing the OpenLink ODBC Data Adapter as a plugin makes it available to
a particular Rails application only.
==== Automatic Plugin installation
The adapter can be automatically installed as a plugin by navigating to the
root of your Rails application and typing either:
script/plugin install odbc-rails
or
script/plugin install http://odbc-rails.rubyforge.org/plugins/odbc-rails
On Windows, replace <tt>script/plugin</tt> by <tt>ruby script/plugin</tt>.
e.g. <tt>ruby script/plugin install odbc-rails</tt>
==== Manual Plugin Installation
You can also install the plugin manually by unpacking the sources into the
vendor/plugins directory of your Rails application.
=== Custom installation script
When using <tt>rake install</tt> or running the install_odbc.rb script by
hand, the script tries to determine the location of the activerecord
package within your Ruby installation and allows you to overrule the
directory it has found with a directory of your choice. If more than one
version of activerecord is found, the default will be the latest version.
On Mac OS X the installation script is also capable of locating Locomotive,
if installed, and will ask to install in there.
The install_odbc.rb script also verifies that the pre-requisites are
installed.
If all else fails this document also describes the steps to install the
ODBC adapter into activerecord manually.
==== Using rake
The simplest way to install the adapter is by using the following
command as root:
# rake install
or if your system supports sudo:
$ sudo rake install
The Rakefile also defines some targets specifically for developers:
$ rake rdoc # Generate rdoc documentation in ~/doc
$ rake package # Create distribution package in ~/distrib
$ rake clean # Remove generated files and directories
==== Running installation script
The second way of installing the adapter is running the
<tt>install_odbc.rb</tt> script as root.
# ruby install_odbc.rb
or if your system supports sudo:
$ sudo ruby install_odbc.rb
=== Installing files manually
The third way of installing the adapter is by performing the installation
steps yourself.
* Copy odbc_adapter.rb to the ACTIVE_RECORD_ROOT/lib/active_record/connection_adapters/ directory
* Copy the odbcext_*.rb files to the ACTIVE_RECORD_ROOT/lib/active_record/vendor/ directory
== Configuring the Adapter
Examples of the required connection parameters can be found in
test/connections/native_odbc/connection.rb
If you enable call-tracing by setting :trace => true, specify the
logger output file as illustrated in connection.rb, e.g.
ActiveRecord::Base.logger = Logger.new("debug_odbc.log")
== License
The OpenLink ODBC Adapter for Ruby on Rails is released under the
MIT license as detailed in the file COPYING.
=== Submitting fixes and enhancements
Patches and new contributions can be submitted as diffs from the
current CVS archive by:
$ cvs add newfiles
$ cvs -z3 diff -uN > diffs
Patches and contributions can be send to the OpenLink iODBC source
archive mainainter at mailto:[email protected] to be included
in the next distribution. Please provide accompanying documentation
on which bugs are fixed or new features are introduced.