raz*_*yed 8 mysql csv activerecord ruby-on-rails ruby-on-rails-3
我使用connection_ninja(https://github.com/cherring/connection_ninja)从我的rails应用程序连接到远程mysql数据库.我的模型中有一个方法,它使用'load data local infile ..'从运行我的rails app的服务器加载到远程mysql db中的csv文件.
代码如下:
class Product < ActiveRecord::Base
@conn = use_connection_ninja(:rl_op)
self.table_name = 'RlProduct'
def self.update(file_path)
sql = "LOAD DATA LOCAL INFILE '#{file_path}'
INTO TABLE RlProduct
FIELDS TERMINATED BY ',' ENCLOSED BY '\"'
LINES TERMINATED BY '\n'
(name,price,productId)"
@conn.connection().execute(sql)
end
end
Run Code Online (Sandbox Code Playgroud)
这给了我以下错误:
Mysql2::Error: The used command is not allowed with this MySQL version: LOAD DATA LOCAL INFILE..
Run Code Online (Sandbox Code Playgroud)
我已local-infile=1在[mysql]部分/etc/mysql/my.cnf运行我的Rails应用程序的服务器.如果我直接登录到服务器上的mysql并在那里运行load data local ..命令,这允许我将数据导入远程数据库.
如何为我的rails代码设置local-infile = 1?
tru*_*ich 23
将此添加到database.yml:
local_infile: true
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2191 次 |
| 最近记录: |