/sqlite_db_tutorial

Read , Learn, and Practice sqlite3 with various sources materials and projects.

Sqlite Tutorial and Practice

The aim of this project is to read and practice the sqlite documentation with projects.

Tutorial

The tutorial information can be found on the official documentation of python for sqlite3.

The tutorial a database of Monty Python Movies would be created using basic sqlite3 functionality.

Fundamental concept need to successfully understand the project are the fundementals of cursors and transactions.

From Wikipedia: Cursor (Databases)

A database cursor is a machanism that enables traversal over the records in a database. Cursors facilitate subsequent processing in conjunction with the traversal, such as retrieval, addition and removal of database records.

Usage To use cursors in SQL procedure, you need to do the following:

  1. Declare a cursor that defines a result set.
  2. Open the cursor to establish the result set.
  3. Fetch the data in local variable as needed from the cursor, one row at a time.
  4. Close the cursor when done.

From Wikipedia: Database Transaction

A database transaction symbolizes a unit of work, performed within a database management system against a database, that is treated in coherent and reliable way independent of other transactions. In a database management system, a transaction is a single unit of logic or work, sometimes made up of multiple operations. Any logical calculation done in a consistent mode in a database is known as a transaction.

A transaction generally represents any change in a database.Transactions in a database environment have two main purposes:

  1. To provide reliable unites of work that allow correct recovey from failures and keep a database consistent even in cases of system failure.
  2. To provide isolation between programs accessing a database concurrently. If this isolation is not provided, the programs outcomes are posibly erroneous.

Back to the sqlite tutorial from python documentation.

The first thing we would need to do is create a database that is connected to sqlite3. To do that we call on sqlite3.connect() to create a connection to the database tutoraial.db which is found in our current working directory, or it would implicitly create the database if it does not exist.

import sqlite3
con = sqlite3. connect("tutorial.db")

In order to execute SQL statements and fetch results from SQL queries, we will need to use a database cursor. Call con.cursor() to create the Cursor:

cur = con.cursor()

With the two code blocks above we have successfully connected to sqlite3 and a cursor, now we can create a database table in tutorial.db called movie with columns for title, release year, and review score.

cur.execute("CREATE TABLE movie(title, year, score)")

To verify if we created the new table by querying the sqlite_master table built-in to SQLite, which should now contain an entery for the movie table definition. We execute the query cur.executer("query statement"), then assign the result to res, and call res.fetchone()` to fetch the resulting row:

res = cur.execute("SELECT name FROM sqlite_master")
res.fetchone()

output: ('movie',)

If we query sqlite_master for a non-existent table spam, res.fetchone() is None.