Home >Database >Mysql Tutorial >Why Doesn\'t My Python Code Insert CSV Data into MySQL?

Why Doesn\'t My Python Code Insert CSV Data into MySQL?

Linda Hamilton
Linda HamiltonOriginal
2024-11-27 05:03:141008browse

Why Doesn't My Python Code Insert CSV Data into MySQL?

Loading CSV Data into MySQL in Python

When attempting to load CSV data into a MySQL table using Python, users may encounter a scenario where the code executes without errors but fails to insert data into the table. To address this issue, it is crucial to understand the role of mydb.commit() in this process.

To begin, the mydb.connect() function establishes a connection to the database. Once a cursor is created, the CSV data is read and inserted into the table using the INSERT INTO statement. However, it is essential to perform a mydb.commit() after the insertion to save the changes to the database. Without this step, the data remains in an uncommitted state and will not be visible in the table.

Here is the modified code with mydb.commit() added:

import csv
import MySQLdb

mydb = MySQLdb.connect(host='localhost',
    user='root',
    passwd='',
    db='mydb')
cursor = mydb.cursor()

csv_data = csv.reader(file('students.csv'))
for row in csv_data:

    cursor.execute('INSERT INTO testcsv(names, \
          classes, mark )' \
          'VALUES("%s", "%s", "%s")', 
          row)
mydb.commit() # Save changes to database
#close the connection to the database.
cursor.close()
print "Done"

By including mydb.commit(), you ensure that the data is successfully inserted into the MySQL table.

The above is the detailed content of Why Doesn\'t My Python Code Insert CSV Data into MySQL?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn