2017-02-16 8 views
1

Python 3을 사용하여 pyodbc를 통해 MS SQL 테이블에 튜플 목록을 삽입하려고합니다.pyodbc : NumPy 데이터로 ('Params는 목록, 튜플 또는 행에 있어야합니다.', 'HY000')

conn_string = (('DRIVER=FreeTDS;' 
       'SERVER={};' 
       'PORT=1433;' 
       'DATABASE={};' 
       'UID={};' 
       'PWD={};' 
       'TDS_Version=8.0;') 
       .format(server, db, user, pwd)) 
sql = """ 
insert into Table1(field1, field2, field3) values (?, ?, ?) 
""" 

cursor.executemany(sql, [('1175B57E-7A10-4BAC-B22E-457C8266C0F2', '1D111FA5-A65D-4F77-A3AB-78B80BAF0C0B', 2), 
('C60FA1C9-7656-4EBF-A577-44CBF0C641F4', '365FB706-9F7F-4ED4-AB88-927AE1F762A6', 1), 
('2DF071CE-ABDF-4119-9573-2B0CA2B99C9C', '590E266D-810C-4DC2-BA5A-BAC05A9982C4', 0), 
('EB794EF9-5FF4-49D3-B81E-F14F69C09306', '1D6E0C95-DF96-45D5-B8F3-211D825A160F', 0), 
('EB794EF9-5FF4-49D3-B81E-F14F69C09306', '17D2EC66-845F-495D-9020-91E144B2E595', 0), 
('EB794EF9-5FF4-49D3-B81E-F14F69C09306', '3A694B33-39F4-4F5B-899B-9B27810E4D82', 1), 
('2DF071CE-ABDF-4119-9573-2B0CA2B99C9C', '4EE1D6F4-4A1E-4316-93D5-2AE1F461A193', 0), 
('410DE087-1ADF-4EEA-BCE6-D7A1124E2A51', '17D2EC66-845F-495D-9020-91E144B2E595', 0), 
('C60FA1C9-7656-4EBF-A577-44CBF0C641F4', '250256D4-4A3A-48E0-BCBA-7CD89011D81F', 1), 
('2DF071CE-ABDF-4119-9573-2B0CA2B99C9C', '4D363718-FE0C-4257-8E4C-5C9A024BAEFF', 0)]) 

하지만이되지 않습니다

params = list(row for row in data_table.round(0).head(10).to_records(index=False)) 

cursor.executemany(sql, params) 

생산이 오류 :

params의 출력
('Params must be in a list, tuple, or Row', 'HY000') 

이더라도을 :

질문에 대한 코멘트에 명시된 바와 같이
[('1175B57E-7A10-4BAC-B22E-457C8266C0F2', '1D111FA5-A65D-4F77-A3AB-78B80BAF0C0B', 2), 
    ('C60FA1C9-7656-4EBF-A577-44CBF0C641F4', '365FB706-9F7F-4ED4-AB88-927AE1F762A6', 1), 
    ('2DF071CE-ABDF-4119-9573-2B0CA2B99C9C', '590E266D-810C-4DC2-BA5A-BAC05A9982C4', 0), 
    ('EB794EF9-5FF4-49D3-B81E-F14F69C09306', '1D6E0C95-DF96-45D5-B8F3-211D825A160F', 0), 
    ('EB794EF9-5FF4-49D3-B81E-F14F69C09306', '17D2EC66-845F-495D-9020-91E144B2E595', 0), 
    ('EB794EF9-5FF4-49D3-B81E-F14F69C09306', '3A694B33-39F4-4F5B-899B-9B27810E4D82', 1), 
    ('2DF071CE-ABDF-4119-9573-2B0CA2B99C9C', '4EE1D6F4-4A1E-4316-93D5-2AE1F461A193', 0), 
    ('410DE087-1ADF-4EEA-BCE6-D7A1124E2A51', '17D2EC66-845F-495D-9020-91E144B2E595', 0), 
    ('C60FA1C9-7656-4EBF-A577-44CBF0C641F4', '250256D4-4A3A-48E0-BCBA-7CD89011D81F', 1), 
    ('2DF071CE-ABDF-4119-9573-2B0CA2B99C9C', '4D363718-FE0C-4257-8E4C-5C9A024BAEFF', 0)] 
+0

그냥 테스트, 당신의 문제를 다시 만들 수 없습니다 :이 솔루션은 params는 튜플의 목록을 포함 있도록하는 "기록"을 변환하는 것이 었습니다. RDMS는 무엇입니까? – Parfait

+0

감사합니다. MS SQL Server 2014입니다. 문자열 필드는 COLLATE "SQL_Latin1_General_CP1_CI_AS"입니다. –

+0

params에있는 것은 목록이며 함수 인수로 목록을 전달할 수 없습니다. 'params = (('A ','B ', 2), ('C ','D ', 1), ('E ','F ', 0))'로 변경하고 –

답변

0

, 문제는

cursor.executemany(sql, params) 

실패했다

params = list(row for row in data_table.round(0).head(10).to_records(index=False)) 

때문에이 목록 [S "의 목록을 반환하지 않는 것을이었다 ], tuple [s] 또는 [pyodbc] Row [s] "일 때,"numpy.records "의 목록을 반환하고있었습니다.

params = list(tuple(row) for row in data_table.head(10).values)