原文: https://pythonspot.com/python-database-programming-sqlite-tutorial/

在本教程中,您将学习如何在 Python 中使用 SQLite 数据库管理系统。 您将学习如何使用 SQLite,SQL 查询,RDBMS 以及更多有趣的东西!

Pyton 数据库

Python 数据库编程:SQLite(教程) - 图1

Python 数据库。

使用 SQL 语言从数据库系统检索数据。 数据无处不在,软件应用程序使用它。 数据位于内存,文件或数据库中。

Python 具有许多数据库系统的绑定,包括 MySQL, Postregsql, Oracle, Microsoft SQL Server 和 Maria DB。

这些数据库管理系统(DBMS)之一称为 SQLite。 SQLite 创建于 2000 年,是数据库动物园中众多管理系统之一。

SQL 是专用于管理数据库中保存的数据的专用编程语言。该语言自 1986 年以来一直存在,值得学习。这是关于 SQL 的古老有趣的视频

SQLite

Python 数据库编程:SQLite(教程) - 图2

SQLite,一个关系数据库管理系统。SQLite 是世界上部署最广泛的 SQL 数据库引擎。SQLite 的源代码位于公共领域。

它是一个自包含,无服务器,零配置的事务型 SQL 数据库引擎。SQLite 项目由彭博社和 Mozilla 赞助。

安装 SQLite:

使用此命令安装 SQLite:

  1. $ sudo apt-get install sqlite

验证是否正确安装。 复制此程序并将其另存为test1.py

  1. #!/usr/bin/python
  2. # -*- coding: utf-8 -*-
  3. import sqlite3 as lite
  4. import sys
  5. con = None
  6. try:
  7. con = lite.connect('test.db')
  8. cur = con.cursor()
  9. cur.execute('SELECT SQLITE_VERSION()')
  10. data = cur.fetchone()
  11. print "SQLite version: %s" % data
  12. except lite.Error, e:
  13. print "Error %s:" % e.args[0]
  14. sys.exit(1)
  15. finally:
  16. if con:
  17. con.close()

执行:

  1. $ python test1.py

它应该输出:

  1. SQLite version: 3.8.2

上面的脚本做了什么?

该脚本使用以下代码行连接到名为test.db的新数据库:

  1. con = lite.connect('test.db')

然后,它使用以下命令查询数据库管理系统

  1. SELECT SQLITE_VERSION()

依次返回其版本号。 该行称为 SQL 查询。

SQL 创建和插入

下面的脚本会将数据存储到名为user.db的新数据库中

  1. #!/usr/bin/python
  2. # -*- coding: utf-8 -*-
  3. import sqlite3 as lite
  4. import sys
  5. con = lite.connect('user.db')
  6. with con:
  7. cur = con.cursor()
  8. cur.execute("CREATE TABLE Users(Id INT, Name TEXT)")
  9. cur.execute("INSERT INTO Users VALUES(1,'Michelle')")
  10. cur.execute("INSERT INTO Users VALUES(2,'Sonya')")
  11. cur.execute("INSERT INTO Users VALUES(3,'Greg')")

SQLite 是使用表的数据库管理系统。 这些表可以与其他表建立关系:称为关系数据库管理系统或 RDBMS。 该表定义了数据的结构并可以保存数据。 数据库可以容纳许多不同的表。 使用以下命令创建表:

  1. cur.execute("CREATE TABLE Users(Id INT, Name TEXT)")

我们使用以下命令将记录添加到表中:

  1. cur.execute("INSERT INTO Users VALUES(2,'Sonya')")
  2. cur.execute("INSERT INTO Users VALUES(3,'Greg')")

第一个值是 ID。 第二个值是名称。 一旦运行脚本,数据便被插入到数据库表Users中:

Python 数据库编程:SQLite(教程) - 图3

SQL 表

SQLite 查询数据

我们可以使用两种方法浏览数据库:命令行和图形界面。

从控制台:要使用命令行进行浏览,请键入以下命令:

  1. sqlite3 user.db
  2. .tables
  3. SELECT * FROM Users;

这将在表Users中输出数据。

  1. sqlite> SELECT * FROM Users;
  2. 1|Michelle
  3. 2|Sonya
  4. 3|Greg

从 GUI:如果要使用 GUI,则有很多选择。 我个人选择了 sqllite-man,但还有很多其他。我们使用以下方法安装:

  1. sudo apt-get install sqliteman

我们启动应用程序 sqliteman。 gui 弹出。

Python 数据库编程:SQLite(教程) - 图4

sqliteman

按“文件 > 打开 > user.db”。 似乎变化不大,不用担心,这只是用户界面。 左侧是一棵小树状视图,请按“表 > 用户”。 现在将显示包括所有记录的完整表格。

Python 数据库编程:SQLite(教程) - 图5

sqliteman

该 GUI 可用于修改表中的记录(数据)并添加新表。

SQL 数据库查询语言

SQL 有许多命令可以与数据库进行交互。 您可以从命令行或 GUI 尝试以下命令:

  1. sqlite3 user.db
  2. SELECT * FROM Users;
  3. SELECT count(*) FROM Users;
  4. SELECT name FROM Users;
  5. SELECT * FROM Users WHERE id = 2;
  6. DELETE FROM Users WHERE id = 6;

我们可以在 Python 程序中使用这些查询:

  1. #!/usr/bin/python
  2. # -*- coding: utf-8 -*-
  3. import sqlite3 as lite
  4. import sys
  5. con = lite.connect('user.db')
  6. with con:
  7. cur = con.cursor()
  8. cur.execute("SELECT * FROM Users")
  9. rows = cur.fetchall()
  10. for row in rows:
  11. print row

这将从数据库输出Users表中的所有数据:

  1. $ python get.py
  2. (1, u'Michelle')
  3. (2, u'Sonya')
  4. (3, u'Greg')

创建用户信息数据库

我们可以跨多个表构建数据。 这使我们的数据保持结构化,快速和有条理。 如果我们只有一个表来存储所有内容,那么很快就会陷入混乱。 我们将要做的是创建多个表并将它们组合使用。 我们创建两个表:

Users

Python 数据库编程:SQLite(教程) - 图6

SQL Table

Jobs

Python 数据库编程:SQLite(教程) - 图7

SQL Table

要创建这些表,您可以在 GUI 中手动进行操作或使用以下脚本:

  1. # -*- coding: utf-8 -*-
  2. import sqlite3 as lite
  3. import sys
  4. con = lite.connect('system.db')
  5. with con:
  6. cur = con.cursor()
  7. cur.execute("CREATE TABLE Users(Id INT, Name TEXT)")
  8. cur.execute("INSERT INTO Users VALUES(1,'Michelle')")
  9. cur.execute("INSERT INTO Users VALUES(2,'Howard')")
  10. cur.execute("INSERT INTO Users VALUES(3,'Greg')")
  11. cur.execute("CREATE TABLE Jobs(Id INT, Uid INT, Profession TEXT)")
  12. cur.execute("INSERT INTO Jobs VALUES(1,1,'Scientist')")
  13. cur.execute("INSERT INTO Jobs VALUES(2,2,'Marketeer')")
  14. cur.execute("INSERT INTO Jobs VALUES(3,3,'Developer')")

作业表有一个额外的参数Uid。 我们使用它来连接 SQL 查询中的两个表:

  1. SELECT users.name, jobs.profession FROM jobs INNER JOIN users ON users.ID = jobs.uid

您可以将该 SQL 查询合并到 Python 脚本中:

  1. #!/usr/bin/python
  2. # -*- coding: utf-8 -*-
  3. import sqlite3 as lite
  4. import sys
  5. con = lite.connect('system.db')
  6. with con:
  7. cur = con.cursor()
  8. cur.execute("SELECT users.name, jobs.profession FROM jobs INNER JOIN users ON users.ID = jobs.uid")
  9. rows = cur.fetchall()
  10. for row in rows:
  11. print row

它应该输出:

  1. $ python get2.py
  2. (u'Michelle', u'Scientist')
  3. (u'Howard', u'Marketeer')
  4. (u'Greg', u'Developer')

您可能会喜欢:数据库和数据分析