Movatterモバイル変換


[0]ホーム

URL:


Open In App
It is recommended to go throughSQL using Python | Set 1 andSQL using Python and SQLite | Set 2In the previous articles the records of the database were limited to small size and single tuple. This article will explain how to write & fetch large data from the database using module SQLite3 covering all exceptions.A simple way is to execute the query and use fetchall(). This has been already discussed in SET 1.
  • executescript()This is a convenience method for executing multiple SQL statements at once. It executes the SQL script it gets as a parameter.
    Syntax:sqlite3.connect.executescript(script)
    PYTHON
    importsqlite3# Connection with the DataBase# 'library.db'connection=sqlite3.connect("library.db")cursor=connection.cursor()# SQL piece of code Executed# SQL piece of code Executedcursor.executescript("""    CREATE TABLE people(        firstname,        lastname,        age    );    CREATE TABLE book(        title,        author,        published    );    INSERT INTO    book(title, author, published)    VALUES (        'Dan Clarke''s GFG Detective Agency',        'Sean Simpsons',        1987    );    """)sql="""SELECT COUNT(*) FROM book;"""cursor.execute(sql)# The output in fetched and returned# as a List by fetchall()result=cursor.fetchall()print(result)sql="""SELECT * FROM book;"""cursor.execute(sql)result=cursor.fetchall()print(result)# Changes saved into databaseconnection.commit()# Connection closed(broken)# with DataBaseconnection.close()
    Output:
    [(1,)][("Dan Clarke's GFG Detective Agency", 'Sean Simpsons', 1987)]
    Note: This piece of code may not work on online interpreters, due to permission privileges to create/write database.
  • executemany()It is often the case when, large amount of data has to be inserted into database from Data Files(for simpler case take Lists, arrays). It would be simple to iterate the code many a times than write every time, each line into database. But the use of loop would not be suitable in this case, the below example shows why. Syntax and use of executemany() is explained below and how it can be used like a loop.PYTHON
    importsqlite3# Connection with the DataBase# 'library.db'connection=sqlite3.connect("library.db")cursor=connection.cursor()# SQL piece of code Executedcursor.execute("""    CREATE TABLE book(        title,        author,        published);""")List=[('A','B',2008),('C','D',2008),('E','F',2010)]connection.executemany("""    INSERT INTO    book(title, author, published)    VALUES (?, ?, ?)""",List)sql="""      SELECT * FROM book;"""cursor.execute(sql)result=cursor.fetchall()forxinresult:print(x)# Changes saved into databaseconnection.commit()# Connection closed(broken)# with DataBaseconnection.close()
    Output:
    Traceback (most recent call last):  File "C:/Users/GFG/Desktop/SQLITE3.py", line 16, in     List[2][3] =[['A', 'B', 2008], ['C', 'D', 2008], ['E', 'F', 2010]]NameError: name 'List' is not defined
    The use of executemany(), can make the piece of code functional.PYTHON
    importsqlite3# Connection with the DataBase# 'library.db'connection=sqlite3.connect("library.db")cursor=connection.cursor()# SQL piece of code Executedcursor.execute("""    CREATE TABLE book(        title,        author,        published);""")List=[('A','B',2008),('C','D',2008),('E','F',2010)]connection.executemany("""    INSERT INTO    book(title, author, published)    VALUES (?, ?, ?)""",List)sql="""SELECT * FROM book;"""cursor.execute(sql)result=cursor.fetchall()forxinresult:print(x)# Changes saved into databaseconnection.commit()# Connection closed(broken)# with DataBaseconnection.close()
    Output:
    ('A', 'B', 2008)('C', 'D', 2008)('E', 'F', 2010)
  • Fetch Large DataPYTHON
    importsqlite3# Connection created with the# database using sqlite3.connect()connection=sqlite3.connect("company.db")cursor=connection.cursor()# Create Table command executedsql="""        CREATE TABLE employee (        ID INTEGER PRIMARY KEY,        fname VARCHAR(20),        lname VARCHAR(30),        gender CHAR(1),        dob DATE);"""cursor.execute(sql)# Single Tuple insertedsql="""        INSERT INTO employee        VALUES (1007, "Will", "Olsen", "M", "24-SEP-1865");"""cursor.execute(sql)# Multiple Rows insertedList=[(1008,'Rkb','Boss','M',"27-NOV-1864"),(1098,'Sak','Rose','F',"27-DEC-1864"),(1908,'Royal','Bassen',"F","17-NOV-1894")]connection.executemany("INSERT INTO employee VALUES (?, ?, ?, ?, ?)",List)print("Method-1\n")# Multiple Rows fetched from# the Databaseforrowinconnection.execute('SELECT * FROM employee ORDER BY ID'):print(row)print("\nMethod-2\n")# Method-2 to fetch multiple# rowssql="""        SELECT * FROM employee ORDER BY ID;"""cursor.execute(sql)result=cursor.fetchall()forxinresult:print(x)connection.commit()connection.close()
    Output:
    Method-1(1007, 'Will', 'Olsen', 'M', '24-SEP-1865')(1008, 'Rkb', 'Boss', 'M', '27-NOV-1864')(1098, 'Sak', 'Rose', 'F', '27-DEC-1864')(1908, 'Royal', 'Bassen', 'F', '17-NOV-1894')Method-2(1007, 'Will', 'Olsen', 'M', '24-SEP-1865')(1008, 'Rkb', 'Boss', 'M', '27-NOV-1864')(1098, 'Sak', 'Rose', 'F', '27-DEC-1864')(1908, 'Royal', 'Bassen', 'F', '17-NOV-1894')
    Note: This piece of code may not work on online interpreters, due to permission privileges to create/write database.


Improve
Improve
Article Tags :

Explore

Lightbox
Improvement
Suggest Changes
Help us improve. Share your suggestions to enhance the article. Contribute your expertise and make a difference in the GeeksforGeeks portal.
geeksforgeeks-suggest-icon
Create Improvement
Enhance the article with your expertise. Contribute to the GeeksforGeeks community and help create better learning resources for all.
geeksforgeeks-improvement-icon
Suggest Changes
min 4 words, max Words Limit:1000

Thank You!

Your suggestions are valuable to us.

What kind of Experience do you want to share?

Interview Experiences
Admission Experiences
Career Journeys
Work Experiences
Campus Experiences
Competitive Exam Experiences

[8]ページ先頭

©2009-2025 Movatter.jp