Python: Insert a list of records into a given SQLite table
6. Insert List of Records
Write a Python program to insert a list of records into a given SQLite table.
Sample Solution:
Python Code :
import sqlite3 
from sqlite3 import Error 
def sql_connection():
    try:
      conn = sqlite3.connect('mydatabase.db')
      return conn
    except Error:
      print(Error)
 
def sql_table(conn, rows):
    cursorObj = conn.cursor()
# Create the table
    cursorObj.execute("CREATE TABLE salesman(salesman_id n(5), name char(30), city char(35), commission decimal(7,2));")
    sqlite_insert_query = """INSERT INTO salesman
                          (salesman_id, name, city, commission) 
                          VALUES (?, ?, ?, ?);"""    
    cursorObj.executemany(sqlite_insert_query, rows)
    conn.commit()      
    print("Number of records after inserting rows:")
    cursor = cursorObj.execute('select * from salesman;')
    print(len(cursor.fetchall()))
  
# Insert records
rows = [(5001,'James Hoog', 'New York', 0.15),
         (5002,'Nail Knite', 'Paris', 0.25),
         (5003,'Pit Alex', 'London', 0.15),
         (5004,'Mc Lyon', 'Paris', 0.35),
         (5005,'Paul Adam', 'Rome', 0.45)]
                   
sqllite_conn = sql_connection() 
sql_table(sqllite_conn, rows)
    
if (sqllite_conn):
  sqllite_conn.close()
  print("\nThe SQLite connection is closed.")
Sample Output:
Number of records after inserting rows: 5 The SQLite connection is closed.
Alternate solution:
Python Code :
import  sqlite3
conn  =  sqlite3 . connect ( 'mydatabase.db' )
cursor  =  conn.cursor ()
#create the salesman table 
cursor.execute("CREATE TABLE salesman(salesman_id n(5), name char(30), city char(35), commission decimal(7,2));")
# Insert records
rows = [(5001,'James Hoog', 'New York', 0.15),
         (5002,'Nail Knite', 'Paris', 0.25),
         (5003,'Pit Alex', 'London', 0.15),
         (5004,'Mc Lyon', 'Paris', 0.35),
         (5005,'Paul Adam', 'Rome', 0.45)]
                   
cursor . executemany ( """
INSERT INTO salesman (salesman_id, name, city, commission)
VALUES (?,?,?,?)
""" , rows )
print ( 'Data entered successfully.' )
conn.commit ()
if (conn):
  conn.close()
  print("\nThe SQLite connection is closed.")
Sample Output:
Data entered successfully. The SQLite connection is closed.
For more Practice: Solve these Related Problems:
- Write a Python program to insert a list of tuples into a SQLite table using executemany(), then verify the insertion by counting the rows.
 - Write a Python function that accepts a list of records and inserts them into a given SQLite table, printing a summary of the operation.
 - Write a Python script to generate a list of random records, insert them into a table, and then print the first 10 rows as a sample.
 - Write a Python program to insert a list of records into a SQLite table and then perform a query to confirm that the inserted data matches the input list.
 
Go to:
Previous: Write a Python program to create a table and insert some records in that table. Finally selects all rows from the table and display the records.
Next: Write a Python program to insert values to a table from user input.
Python Code Editor:
Have another way to solve this solution? Contribute your code (and comments) through Disqus.
What is the difficulty level of this exercise?
Test your Programming skills with w3resource's quiz.
