Python中SQLite数据库的使用

作者:HkSwaggyD 时间:2024-01-21 17:33:58 

SQL(结构化查询语言)是一种通用数据库查询语言。SQL具有数据定义、数据操作和数据控制功能,可以完成数据库的全部工作。SQL语言使用时只需要用告诉计算机“做什么”,而不需要告诉它“怎么做”。

SQL语言有两种使用方式,一是直接以命令方式交互使用;二是嵌入到C/C++、Python等主语言中使用。

本章我们通过学习Python中的第三方库SQLite来掌握一些SQL的基本语句,以及运用Python来操作数据库的方法

预备知识

sqlite数据库的创建与连接

sqlite数据库的创建与连接分三步走:

(1)导入模块

import sqlite3
#或者:
from sqlite3 import dbapi2       #导入sqlite3模块的dbapi2接口模块

(2)利用connect方法创建数据库

connection=sqlite3.connect(filename)
#filename为数据库文件名,如果该文件存在则打开该数据库,如果不存在则创建一个新的数据库文件。
#该方法返回一个数据库连接对象

(3)关闭连接对象

connection.close()
#关闭连接,更新数据库文件

SQL语句创建数据表

表是数据库中存放关系数据的集合,一个数据库里通常包含了多个表,如学生表、班级表、教师表等,表和表之间通过外键关联。

在SQL中,利用create语句创建表语法结构如下:

create table 表名(字段1,…,字段n)

如,创建mytb表:

create table if not exists mytb( xm char, cj real, kc text )

表名是mytb;IF NOT EXISTS表示如果数据库中不存在mytb数据表,就创建该表;如果该数据表已经存在,则什么也不做;

xm char, cj real, kc text表示该数据表有3个字段,xm(姓名)是字符串类型,cj(成绩)是浮点数类型,kc(课程)是文本字符串。

SQLite3支持的数据类型有:

null(值=空)、integer(整数)、real(浮点数)、text(字符串文本)、blob(二进制数据块)。

execute()方法

在Python中我们可以使用 execute 方法执行一条SQL语句

conn.execute('create table if not exists mytb( xm char, cj real, kc text )')

conn为连接对象 execute()方法中参数为一条SQL语句,类型为字符串

插入记录

(1)插入记录的SQL语句

语法格式如下 :

insert into 表名 [字段名] values [常量]

如:

insert into Persons values ('Gates', 'Bill', 'Xuanwumen 10', 'Beijing')

(2)利用execute()执行SQL语句

cur.exceute(sql语句)

(3)提交事务

conn.commit() #提交事务,将数据写入文件,保存到磁盘中。

查询SQL语句

从“表”中查询满足条件表达式的“目标列”

SELECT 目标列 FROM 表 [WHERE 条件表达式]

如,查询年龄20岁以下的学生姓名及其年龄:

select sname age from student where age<20

如,查询表中所有记录:

select * from student

fetchall()

返回多条记录(rows),如果没有结果,则返回空()

sqlite_master表

每一个 SQLite 数据库都有一个叫 sqlite_master 的表,该表会自动创建。

sqlite_master是一个特殊表, 存储数据库的元信息, 如表(table), 索引(index), 视图(view), 触发器(trigger), 可通过select查询相关信息。

select name,sql from sqlite_master where type='table'

该语句用于查询数据库中数据表的名称name,以及创建表的SQL语句

更新记录

更新记录的SQL语句:

UPDATE 表名 SET 列名=表达式… [WHERE 条件]

当&ldquo;条件&rdquo;成立时,将某列的值改为&ldquo;表达式&rdquo; 如:

update student set cj=90 where xh="001"

可将001号同学的成绩改为90

删除记录

DROP TABLE和DELETE语句:

(1)删除数据表所有记录

DELETE FROM <表名>

如,删除student表

delete from student

(2)删除记录

DELETE FROM <表名> WHERE <条件>

如,删除表中学号xh为'001'记录

delete from student where xh='001'

(3)删除整个数据表

DROP TABLE 表名

如,删除student表结构

drop table student

例题练习

第1关:创建和连接数据库文件

本关任务:在当前目录下,创建和连接mytest.db数据库。

代码解析

def return_values():
#***********Begin**********#
   #(1)导入内置sqlite3模块
   import sqlite3
   #(2)创建conn连接对象(在当前路径下建立mytest.db数据库)
   conn = sqlite3.connect("mytest.db")
   #(3)关闭连接
   conn.close()
#***********End**********#

第2关:创建数据表

本关任务:创建或打开数据表示例。

代码解析

#(1)导入sqlite3模块
import sqlite3
#(2)创建conn连接对象,建立mytest.db数据库
conn = sqlite3.connect("mytest.db")
#(3)定义sql语句,创建mytb数据表,表中有三个字段xm、cj、kc,其数据类型分别为char、real、text
sql_demo = "create table if not exists mytb( xm char , cj real , kc text )"
#(4)执行sql语句
conn.execute(sql_demo)
#(5)关闭连接
conn.close()

第3关:插入记录

本关任务:创建一个sqlite3数据库文件mytest.db,再创建一个数据表mytb.db,往表里插入三行记录。

代码解析

#(1)导入sqlite3模块
import sqlite3
#(2)创建数据库文件mytest.db
conn = sqlite3.connect("mytest.db")
#(3)定义一个游标对象
cur = conn.cursor()
#(4)定义创建数据表SQL语句
sql_create = "create table if not exists mytb(xm char,cj real,kc text)"
sql_insert_by = "insert into mytb values ('宝玉',85,'计算机')"
sql_insert_dy = "insert into mytb values ('黛玉',90,'计算机')"
sql_insert_bc = "insert into mytb values ('宝钗',80,'数据库')"
#(5)执行SQL语句,创建数据表mytb
conn.execute(sql_create)
#(6)依次插入3条记录,内容分别为:('宝玉',85,'计算机')、('黛玉',92,'计算机')、('宝钗',80,'数据库')
cur.execute(sql_insert_by)
cur.execute(sql_insert_dy)
cur.execute(sql_insert_bc)
#(7)提交事务
conn.commit()
#(8)关闭连接
cur.close()
conn.close()

第4关:查询记录

本关任务:设计一个程序,查询已有数据库文件myfile.db中数据表mytb中所有记录,及查询数据表结构。

代码解析

#(1)导入sqlite3模块
import sqlite3
#(2)打开数据库文件myfile.db
conn = sqlite3.connect("myfile.db")
#(3)定义一个游标对象
cur = conn.cursor()
sql_select = "select * from mytb"
#(4)查询数据表mytb中所有记录,并赋值给列表
cur.execute(sql_select)
lst = cur.fetchall()
#(5)输出记录数
print(f"共{len(lst)}条记录")
#(6)输出所有记录列表
print(lst)
#(7)从sqlite_master表中查询数据表的名称和创建时的sql语句,查询结果赋值给列表,并输出列表内容
cur.execute("select name,sql from sqlite_master ")
print(cur.fetchall())

第5关:更新和删除记录

本关任务:在sqlite数据库中更新和删除记录

代码解析

#(1)导入sqlite3模块
import sqlite3
#(2)打开数据库my.db
conn = sqlite3.connect("my.db")
#(3)定义游标
cur = conn.cursor()
#(4)更新记录,将xm“宝玉”的成绩cj改为0
cur.execute("update mytb set cj = 0 where xm = '宝玉'")
#(5)删除成绩cj>90的记录
cur.execute("delete from mytb where cj > 90")
#(6)删除数据表mytb中所有记录
cur.execute("delete from mytb")
#(7)删除整个数据表mytb
cur.execute("drop table mytb")
#(8)提交事务
conn.commit()
#(9)关闭游标
cur.close()
#(10)关闭数据库连接
conn.close()

第6关:图书数据库的综合操作

本关任务:在SQLite中创建数据库mybook.db;在数据库中创建数据表mytb;在表中定义:isbn(text)、书名(text)、价格(real)等字段,并插入记录。

代码解析

#(1)导入sqlite3模块
import sqlite3
#(2)创建数据库mybook.db
conn = sqlite3.connect("mybook.db")
#(3)定义游标对象
cur = conn.cursor()
#(4)创建表mytb
cur.execute("create table if not exists mytb ( isbn text , 书名 text , 价格 real)")
#(5)插入记录('9787302518358','欧美戏剧选读',88.00)
cur.execute("insert into mytb values ('9787302518358','欧美戏剧选读',88.00)")
#(6)插入记录('9787302454038','组织理论与设计 第12版',75.00)
cur.execute("insert into mytb values ('9787302454038','组织理论与设计 第12版',75.00)")
#(7)插入记录('9787302496878','中国文化经典读本',45.00)
cur.execute("insert into mytb values ('9787302496878','中国文化经典读本',45.00)")
#(8)提交事务,保存数据
conn.commit()
#(9)读入所有记录,将查询记录赋值给列表,遍历输出列表内容
cur.execute("select * from mytb")
lst = cur.fetchall()
for x in lst:
   print(x)
#(10)关闭游标
cur.close()
#(11)关闭数据库
conn.close()

来源:https://blog.csdn.net/HkSwaggyD/article/details/130342029

标签:Python,SQLite,数据库
0
投稿

猜你喜欢

  • 正则的replace方法(产生的字符串副本)

    2008-06-03 13:31:00
  • python的类class定义及其初始化方式

    2023-08-07 11:52:15
  • 详细解读python操作json文件的详细

    2021-01-31 10:41:42
  • 禁止弹窗中蒙层底部页面跟随滚动的几种方法

    2024-06-05 09:12:59
  • python可视化hdf5文件的操作

    2022-11-16 16:35:48
  • Python实现发送邮件到自己邮箱

    2023-10-18 17:08:11
  • Windows下安装python2.7及科学计算套装

    2023-05-28 13:35:19
  • vue.js实现选项卡切换

    2024-04-30 10:26:13
  • c#判断数据库服务器是否已经启动的方法

    2024-01-25 06:23:05
  • ASP技巧:Script块不能放在另一个Script 块内

    2009-08-19 17:17:00
  • Python使用海龟绘图实现贪吃蛇游戏

    2022-01-03 15:21:28
  • Pytorch之8层神经网络实现Cifar-10图像分类验证集准确率94.71%

    2022-03-03 21:14:36
  • 微软工程师讲解SQL server阻塞

    2008-01-05 14:02:00
  • 超详细,教你用python语言实现QQ机器人制作教程

    2023-10-05 10:12:53
  • SQL Server数据迁移至云端应用技巧谈

    2011-05-05 08:01:00
  • 基于Python+Pygame实现经典赛车游戏

    2023-09-18 03:57:43
  • Python基于SMTP发送邮件的方法

    2021-07-17 23:42:46
  • Numpy 三维数组索引与切片的实现

    2021-08-17 22:19:35
  • Django代码性能优化与Pycharm Profile使用详解

    2022-06-28 21:13:06
  • 自动生成sql语句

    2008-05-09 12:42:00
  • asp之家 网络编程 m.aspxhome.com