深入了解SQLite資料庫

SQLite是一個嵌入式關係型資料庫,支持ACID事務,並且被廣泛應用於Android、iOS、Java等跨平台開發中。SQLite資料庫具有小巧、便捷和易用等優點,下面從多個方面詳細闡述SQLite資料庫。

一、SQLite的基礎

SQLite是一個輕型的嵌入式關係型資料庫管理系統,它的數據存儲在單一的磁碟文件中。它可以使用SQL語言進行操作,支持大部分SQL語法,包括事務、觸發器、索引等。SQLite不像傳統的資料庫那樣需要安裝、啟動和配置,只需要將SQLite的可執行文件和開發庫文件導入到項目中即可。

SQLite的代碼示例:

import sqlite3

conn = sqlite3.connect('test.db')
print("Opened database successfully")
conn.execute('''CREATE TABLE COMPANY
       (ID INT PRIMARY KEY     NOT NULL,
       NAME           TEXT    NOT NULL,
       AGE            INT     NOT NULL,
       ADDRESS        CHAR(50),
       SALARY         REAL);''')
print("Table created successfully")
conn.close()

二、SQLite的數據類型

SQLite支持多種數據類型,包括NULL、INTEGER、REAL、TEXT以及BLOB等數據類型。在創建表的時候需要為每一個欄位指定數據類型,一旦指定無法更改。SQLite的數據類型並不需要指定長度,因為SQLite會根據實際存儲的數據自動調整欄位的長度。例如,如果欄位類型為TEXT,那麼SQLite會自動根據存儲的內容分配相應的長度。

SQLite的數據類型示例:

import sqlite3

conn = sqlite3.connect('test.db')
print ("Opened database successfully")

conn.execute('''CREATE TABLE COMPANY
       (ID INT PRIMARY KEY     NOT NULL,
       NAME           TEXT    NOT NULL,
       AGE            INT     NOT NULL,
       ADDRESS        CHAR(50),
       SALARY         REAL);''')

print ("Table created successfully")

conn.close()

三、SQLite的事務

SQLite支持ACID事務,也就是Atomicity(原子性)、Consistency(一致性)、Isolation(隔離性)和Durability(持久化)。如果在事務中的任意一步驟出現錯誤,那麼整個事務會被回滾,使得資料庫的狀態恢復到操作之前的狀態。

SQLite的事務代碼示例:

import sqlite3

conn = sqlite3.connect('test.db')
print ("Opened database successfully")

conn.execute('''CREATE TABLE COMPANY
       (ID INT PRIMARY KEY     NOT NULL,
       NAME           TEXT    NOT NULL,
       AGE            INT     NOT NULL,
       ADDRESS        CHAR(50),
       SALARY         REAL);''')

print ("Table created successfully")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (1, 'Paul', 32, 'California', 20000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (2, 'Allen', 25, 'Texas', 15000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (3, 'Teddy', 23, 'Norway', 20000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (4, 'Mark', 25, 'Rich-Mond', 65000.00 )")

conn.commit()
print ("Records created successfully")
conn.close()

四、SQLite的索引

索引是一種特殊的數據結構,用於加速查詢操作。SQLite支持B-Tree和Hash索引,可以使用CREATE INDEX語句創建索引。可以根據需要為一個表創建多個索引,每一個索引可以包含多列,可以根據索引的列進行排序和過濾。

SQLite的索引代碼示例:

import sqlite3

conn = sqlite3.connect('test.db')
print ("Opened database successfully")

conn.execute('''CREATE TABLE COMPANY
       (ID INT PRIMARY KEY     NOT NULL,
       NAME           TEXT    NOT NULL,
       AGE            INT     NOT NULL,
       ADDRESS        CHAR(50),
       SALARY         REAL);''')

print ("Table created successfully")

conn.execute("CREATE INDEX IDX_NAME ON COMPANY (NAME)")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (1, 'Paul', 32, 'California', 20000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (2, 'Allen', 25, 'Texas', 15000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (3, 'Teddy', 23, 'Norway', 20000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (4, 'Mark', 25, 'Rich-Mond', 65000.00 )")

conn.commit()
print ("Records created successfully")
conn.close()

五、SQLite的觸發器

SQLite的觸發器是一種特殊的資料庫對象,它可以捕獲特定的資料庫事件(如INSERT、UPDATE、DELETE等),並在事件發生時自動執行某些操作。通過使用觸發器,可以方便地保持資料庫的完整性和約束。

SQLite的觸發器代碼示例:

import sqlite3

conn = sqlite3.connect('test.db')
print ("Opened database successfully")

conn.execute('''CREATE TABLE COMPANY
       (ID INT PRIMARY KEY     NOT NULL,
       NAME           TEXT    NOT NULL,
       AGE            INT     NOT NULL,
       ADDRESS        CHAR(50),
       SALARY         REAL);''')

print ("Table created successfully")

conn.execute('''CREATE TRIGGER salary_update
       AFTER UPDATE ON COMPANY
       FOR EACH ROW
       WHEN NEW.SALARY > 50000
       BEGIN
          INSERT INTO HIGH_SALARY (ID, NAME, AGE, SALARY)
          VALUES (NEW.ID, NEW.NAME, NEW.AGE, NEW.SALARY);
       END;''')

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (1, 'Paul', 32, 'California', 20000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (2, 'Allen', 25, 'Texas', 15000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (3, 'Teddy', 23, 'Norway', 20000.00 )")

conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
      VALUES (4, 'Mark', 25, 'Rich-Mond', 65000.00 )")

conn.commit()
print ("Records created successfully")
conn.close()

結束語

本文詳細地闡述了SQLite資料庫的多個方面,包括基礎、數據類型、事務、索引以及觸發器等方面,並給出了對應的代碼示例。SQLite有著小巧、便捷和易用等優點,廣泛應用於跨平台開發中,值得開發者們深入了解。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/310129.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2025-01-04 19:32
下一篇 2025-01-04 19:32

相關推薦

  • Python 常用資料庫有哪些?

    在Python編程中,資料庫是不可或缺的一部分。隨著互聯網應用的不斷擴大,處理海量數據已成為一種趨勢。Python有許多成熟的資料庫管理系統,接下來我們將從多個方面介紹Python…

    編程 2025-04-29
  • openeuler安裝資料庫方案

    本文將介紹在openeuler操作系統中安裝資料庫的方案,並提供代碼示例。 一、安裝MariaDB 下面介紹如何在openeuler中安裝MariaDB。 1、更新軟體源 sudo…

    編程 2025-04-29
  • 資料庫第三範式會有刪除插入異常

    如果沒有正確設計資料庫,第三範式可能導致刪除和插入異常。以下是詳細解釋: 一、什麼是第三範式和範式理論? 範式理論是關係資料庫中的一個規範化過程。第三範式是範式理論中的一種常見形式…

    編程 2025-04-29
  • leveldb和unqlite:兩個高性能的資料庫存儲引擎

    本文將介紹兩款高性能的資料庫存儲引擎:leveldb和unqlite,並從多個方面對它們進行詳細的闡述。 一、leveldb:輕量級的鍵值存儲引擎 1、leveldb概述: lev…

    編程 2025-04-28
  • Python怎麼導入資料庫

    Python是一種高級編程語言。它具有簡單、易讀的語法和廣泛的庫,讓它成為一個靈活和強大的工具。Python的資料庫連接類型可以多種多樣,其中包括MySQL、Oracle、Post…

    編程 2025-04-28
  • Think-ORM數據模型及資料庫核心操作

    本文主要介紹Think-ORM數據模型建立和資料庫核心操作。 一、模型定義 Think-ORM是一個開源的ORM框架,用於簡化在PHP應用中(特別是ThinkPHP)與關係資料庫之…

    編程 2025-04-27
  • 如何使用Python將CSV文件導入到資料庫

    CSV(Comma Separated Values)是一種可讀性高、易於編輯與導入導出的文件格式,常用於存儲表格數據。在數據處理過程中,我們有時需要將CSV文件導入到資料庫中進行…

    編程 2025-04-27
  • Python批量導入資料庫

    本文將介紹Python中如何批量導入資料庫。首先,對於數據分析和挖掘領域,資料庫中批量導入數據是一個必不可少的過程。這種高效的導入方式可以極大地提高數據挖掘、機器學習等任務的效率。…

    編程 2025-04-27
  • Activiti 6自動部署後不生成資料庫act_hi_*的解決方法

    本文將從多個方面詳細闡述Activiti 6自動部署後不生成資料庫act_hi_*的問題,並提供對應的代碼示例。 一、問題分析 在使用Activiti 6部署流程後,我們發現act…

    編程 2025-04-27
  • Python更新資料庫數據

    Python更新資料庫數據是一個非常實用的功能。在工作中,我們經常需要從外部獲取數據,然後將這些數據保存到資料庫中,或者對現有資料庫中的數據進行更新。Python提供了許多庫和框架…

    編程 2025-04-27

發表回復

登錄後才能評論