database - 从 CSV 写入 SQL 数据库

标签 database performance csv pyodbc

我手头有这些 csv 文件,我必须将其上传到远程数据库,并且我使用 pyodbc 和 python 中的 csv 库来完成此操作。我不知道为什么,但它非常慢(大约 30 秒) a 100 行),我必须上传的一些 csv 文件有超过 30k 行。我也尝试过使用 pandas,但速度没有变化。 这或多或少是我的代码。不必要的部分已被省略。

if len(sys.argv) == 1:
print("This program needs needs an input state")
exit()

state_code = str(sys.argv[1])

f = open(state_code+".csv", "r")

reader = csv.reader(f, delimiter=',')


 cnxn = pyodbc.connect('DRIVER={ODBC Driver 17 for SQL Server};SERVER='+server+';DATABASE='+database+';UID='+username+';PWD='+ password)

insert_query = '''INSERT INTO table (Zipcode, Pers_Property_Coverage, Deductible, 
Liability,Average_Rate,
            Highest_Rate, Lowest_Rate, CREATE_DATE, Active_Flag)
            VALUES(?,?,?,?,?,?,?,?,?)'''
for row in reader:
    zipcode = row[0]

    if len(zipcode) == 4:
        zipcode = "0" + zipcode

    ppc=row[1][1:]
    ppc=ppc.replace(',', '')

    deductible = row[2][1:]
    deductible = deductible.replace(',', '')

    liability = row[3][1:]
    liability = liability.replace(',', '')

    average_rate = row[4][1:]
    average_rate = average_rate.replace(',', '')

    highest_rate = row[5][1:]
    highest_rate = highest_rate.replace(',', '')

    lowest_rate=row[6][1:]
    lowest_rate = lowest_rate.replace(',', '')

    ctr=ctr+1

    if ctr % 100 == 0:
        print("Time Elapsed = ", round(time.time() - start_time)," seconds")

    values = (zipcode, ppc, deductible, liability, average_rate, highest_rate, lowest_rate, date, "Y")

    print("Inserting "+zipcode ,ppc , deductible, liability, average_rate, highest_rate, lowest_rate,date, "Y")

    cursor.execute(insert_query, values)
cnxn.commit()

最佳答案

更新代码以使用 pyodbc executemany 和选项 fast_executemany=True 可能是节省时间的简单方法:

从文件中探索批量插入可能是另一种选择,尽管它很可能不使用 pyodbc 或 python:

关于database - 从 CSV 写入 SQL 数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61783115/

相关文章:

php - 我的 IF 语句有问题

c# - C++ 和 C# 在数学方面的性能差异

android - 如何限制 Android 设备网络速度以进行测试

python - 在 Python 中按日期对 CSV 进行排序

javascript: 未捕获类型错误: 无法读取未定义的属性 'objects': jquery-csv

mysql - MySQL 是否忽略唯一约束的空值?

java - 数据库中的 Hibernate Enum 关系映射

Java Tilemaps 使用 Cliping 来提高帧速率 : What can go WRONG?

php - 写入 csv 文件时转义分号字符

php - 从不同表插入时自动增量重叠