使用connection_ninja(https://github.com/cherring/connection_ninja)從我的rails應用程序連接到遠程mysql數據庫。我的模型中有一個方法,它使用運行我的rails應用程序的服務器中的'load data local infile ..'將csv文件加載到遠程mysql數據庫中。啓用local-infile將數據從rails導入遠程mysql
的代碼如下:
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
這是給我下面的錯誤:
Mysql2::Error: The used command is not allowed with this MySQL version: LOAD DATA LOCAL INFILE..
我已經在我的運行Rails應用程序的服務器的/etc/mysql/my.cnf
[mysql]
部分設置local-infile=1
。這允許我導入數據到遠程數據庫,如果我直接登錄到服務器上的MySQL並在那裏運行load data local ..命令。
我該如何爲我的導軌代碼設置local-infile = 1?
我愛你!一直在尋找這個 – Kevin
是的,這不是最常用的功能:)享受;) – trushkevich
在哪裏我可以找到這個文件...我使用MySQL服務器5.6 – saikiran