Python中SQLite数据库怎么使用


这篇文章主要介绍“Python中SQLite数据库怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python中SQLite数据库怎么使用”文章能帮助大家解决问题。

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

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

预备知识

sqlite数据库的创建与连接

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

(1)导入模块

importsqlite3#或者:fromsqlite3importdbapi2#导入sqlite3模块的dbapi2接口模块

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

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

(3)关闭连接对象

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

SQL语句创建数据表

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

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

createtable表名(字段1,…,字段n)

如,创建mytb表:

createtableifnotexistsmytb(xmchar,cjreal,kctext)

表名是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('createtableifnotexistsmytb(xmchar,cjreal,kctext)')

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

插入记录

(1)插入记录的SQL语句

语法格式如下 :

insertinto表名[字段名]values[常量]

如:

insertintoPersonsvalues('Gates','Bill','Xuanwumen10','Beijing')

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

cur.exceute(sql语句)

(3)提交事务

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

查询SQL语句

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

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

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

selectsnameagefromstudentwhereage<20

如,查询表中所有记录:

select*fromstudent

fetchall()

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

sqlite_master表

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

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

selectname,sqlfromsqlite_masterwheretype='table'

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

更新记录

更新记录的SQL语句:

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

当“条件”成立时,将某列的值改为“表达式” 如:

updatestudentsetcj=90wherexh="001"

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

删除记录

DROP TABLE和DELETE语句:

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

DELETEFROM<表名>

如,删除student表

deletefromstudent

(2)删除记录

DELETEFROM<表名>WHERE<条件>

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

deletefromstudentwherexh='001'

(3)删除整个数据表

DROPTABLE表名

如,删除student表结构

droptablestudent

例题练习

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

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

代码解析

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

第2关:创建数据表

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

代码解析

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

第3关:插入记录

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

代码解析

#(1)导入sqlite3模块importsqlite3#(2)创建数据库文件mytest.dbconn=sqlite3.connect("mytest.db")#(3)定义一个游标对象cur=conn.cursor()#(4)定义创建数据表SQL语句sql_create="createtableifnotexistsmytb(xmchar,cjreal,kctext)"sql_insert_by="insertintomytbvalues('宝玉',85,'计算机')"sql_insert_dy="insertintomytbvalues('黛玉',90,'计算机')"sql_insert_bc="insertintomytbvalues('宝钗',80,'数据库')"#(5)执行SQL语句,创建数据表mytbconn.execute(sql_create)#(6)依次插入3条记录,内容分别为:('宝玉',85,'计算机')、('黛玉',92,'计算机')、('宝钗',80,'数据库')cur.execute(sql_insert_by)cur.execute(sql_insert_dy)cur.execute(sql_insert_bc)#(7)提交事务connmit()#(8)关闭连接cur.close()conn.close()

第4关:查询记录

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

代码解析

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

第5关:更新和删除记录

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

代码解析

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

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

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

代码解析

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

关于“Python中SQLite数据库怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注主机评测网行业资讯频道,小编每天都会为大家更新不同的知识点。


上一篇:php将json转成数组对象的方法是什么

下一篇:python函数运行内存时间等性能检测工具如何用


Copyright © 2002-2019 测速网 https://www.inhv.cn/ 皖ICP备2023010105号 城市 地区 街道
温馨提示:部分文章图片数据来源与网络,仅供参考!版权归原作者所有,如有侵权请联系删除!
热门搜索