Class: Sequel::Rails::Storage::Jdbc
Instance Attribute Summary
#config
Instance Method Summary
collapse
#charset, #create, create_all, create_environment, #database, #drop, drop_all, drop_environment, #host, #initialize, new, #owner, #password, #port, #username
Instance Method Details
#_create ⇒ Object
198
199
200
201
202
203
204
|
# File 'lib/sequel/rails/storage.rb', line 198
def _create
if _is_mysql?
Sequel.connect("#{_root_url}#{_params}") do |db|
db.execute("CREATE DATABASE IF NOT EXISTS `#{db_name}` DEFAULT CHARACTER SET #{charset} DEFAULT COLLATE #{collation}")
end
end
end
|
#_drop ⇒ Object
206
207
208
209
210
211
212
|
# File 'lib/sequel/rails/storage.rb', line 206
def _drop
if _is_mysql?
Sequel.connect("#{_root_url}#{_params}") do |db|
db.execute("DROP DATABASE IF EXISTS `#{db_name}`")
end
end
end
|
#_is_mysql? ⇒ Boolean
182
183
184
|
# File 'lib/sequel/rails/storage.rb', line 182
def _is_mysql?
database.match(/^jdbc:mysql/)
end
|
#_params ⇒ Object
194
195
196
|
# File 'lib/sequel/rails/storage.rb', line 194
def _params
database.scan /\?.*$/
end
|
#_root_url ⇒ Object
186
187
188
|
# File 'lib/sequel/rails/storage.rb', line 186
def _root_url
database.scan /^jdbc:mysql:\/\/\w*:?\d*/
end
|
#db_name ⇒ Object
190
191
192
|
# File 'lib/sequel/rails/storage.rb', line 190
def db_name
database.scan(/^jdbc:mysql:\/\/\w+:?\d*\/(\w+)/).flatten.first
end
|