2014-01-21 42 views
5

使用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?

回答

18

其添加到database.yml

local_infile: true 
+0

我愛你!一直在尋找這個 – Kevin

+0

是的,這不是最常用的功能:)享受;) – trushkevich

+0

在哪裏我可以找到這個文件...我使用MySQL服務器5.6 – saikiran

0

運行此查詢的用戶在遠程服務器上應具有FILE訪問權限。

+0

感謝reply.It作品在我的dev的機器。我在部署應用程序的服務器上遇到問題。我需要爲服務器上的mysql客戶端啓用local-infile。我已經通過在my.cnf中創建條目來啓用它。但是,rails並不知道該設置。那麼我怎麼能爲我的導軌代碼啓用它呢? –

+0

你是對的。區別在於本地和遠程。當通過本地主機或遠程訪問時,同一用戶的行爲會有所不同。檢查此用戶的主機值。它應該是'%'而不是本地主機。 – emaillenin

相關問題