2015-04-27 83 views
3

我试图用LOAD LOCAL DATA INFILE和sqlalchemy将批处理文件上传到我的服务器。我编辑了我的/etc/mysql/my.conf,在[mysql][mysqld]下包含local-infile == 1,但是当我运行该程序时,我得到了这个回溯。LOAD DATA LOCAL INFILE sqlalchemy和Python到mysql db

的代码中的相关行是:

Traceback (most recent call last): 
    File "main.py", line 48, in <module> 
    con.execute(sql) 
    File "/Users/eoddata/venv/lib/python2.7/site-packages/sqlalchemy/engine/base.py", line 906, in execute 
    return self._execute_text(object, multiparams, params) 
    File "/Users/eoddata/venv/lib/python2.7/site-packages/sqlalchemy/engine/base.py", line 1054, in _execute_text 
    statement, parameters 
    File "/Users/eoddata/venv/lib/python2.7/site-packages/sqlalchemy/engine/base.py", line 1146, in _execute_context 
    context) 
    File "/Users/eoddata/venv/lib/python2.7/site-packages/sqlalchemy/engine/base.py", line 1332, in _handle_dbapi_exception 
    exc_info 
    File "/Users/eoddata/venv/lib/python2.7/site-packages/sqlalchemy/util/compat.py", line 199, in raise_from_cause 
    reraise(type(exception), exception, tb=exc_tb) 
    File "/Users/eoddata/venv/lib/python2.7/site-packages/sqlalchemy/engine/base.py", line 1139, in _execute_context 
    context) 
    File "/Users/eoddata/venv/lib/python2.7/site-packages/sqlalchemy/engine/default.py", line 442, in do_execute 
    cursor.execute(statement, parameters) 
    File "/Users/eoddata/venv/lib/python2.7/site-packages/MySQLdb/cursors.py", line 205, in execute 
    self.errorhandler(self, exc, value) 
    File "/Users/eoddata/venv/lib/python2.7/site-packages/MySQLdb/connections.py", line 36, in defaulterrorhandler 
    raise errorclass, errorvalue 
sqlalchemy.exc.OperationalError: (_mysql_exceptions.OperationalError) (1148, 'The used command is not allowed with 
this MySQL version') [SQL: "LOAD DATA LOCAL 
INFILE 'stocks/AMEX_20150420.txt' INTO TABLE database.new_table\n      
FIELDS TERMINATED BY ',' (Symbol,@Date,Open,High,Low,Close,Volume)\n      
SET Date = STR_TO_DATE(@Date,'%%Y%%m%%d');"] 

我从文档做了一些研究,并不能找到一个方法来解决这个错误。使用python MySQLdb(从pip install MySQL-Python)将允许我传入本地infile参数。我无法在SQLAlchemy中找到等价物。任何帮助表示赞赏。

编辑:我一直在这一整晚,仍然没有取得任何进展 - 很多死角。有任何想法吗?

感谢,贾里德

回答

6

您应该添加local_infile=1到连接字符串。

SQLALCHEMY_DATABASE_URI = "mysql://user:[email protected]/dbname?charset=utf8&local_infile=1"