目录
预备知识
SQL语句创建数据表
execute()方法
插入记录
查询SQL语句
fetchall()
sqlite_master表
更新记录
删除记录
例题练习
首页 后端开发 Python教程 Python中SQLite数据库如何使用

Python中SQLite数据库如何使用

May 11, 2023 am 08:25 AM
python sqlite

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

SQL语言有两种使用方式,一是直接以命令方式交互使用;二是嵌入到C/C++、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=&#39;table&#39;
登录后复制

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

更新记录

更新记录的SQL语句:

UPDATE 表名 SET 列名=表达式… [WHERE 条件]
登录后复制

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

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=&#39;001&#39;
登录后复制

(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 (&#39;宝玉&#39;,85,&#39;计算机&#39;)"
sql_insert_dy = "insert into mytb values (&#39;黛玉&#39;,90,&#39;计算机&#39;)"
sql_insert_bc = "insert into mytb values (&#39;宝钗&#39;,80,&#39;数据库&#39;)"
#(5)执行SQL语句,创建数据表mytb
conn.execute(sql_create)
#(6)依次插入3条记录,内容分别为:(&#39;宝玉&#39;,85,&#39;计算机&#39;)、(&#39;黛玉&#39;,92,&#39;计算机&#39;)、(&#39;宝钗&#39;,80,&#39;数据库&#39;)
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 = &#39;宝玉&#39;")
#(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)插入记录(&#39;9787302518358&#39;,&#39;欧美戏剧选读&#39;,88.00)
cur.execute("insert into mytb values (&#39;9787302518358&#39;,&#39;欧美戏剧选读&#39;,88.00)")
#(6)插入记录(&#39;9787302454038&#39;,&#39;组织理论与设计 第12版&#39;,75.00)
cur.execute("insert into mytb values (&#39;9787302454038&#39;,&#39;组织理论与设计 第12版&#39;,75.00)")
#(7)插入记录(&#39;9787302496878&#39;,&#39;中国文化经典读本&#39;,45.00)
cur.execute("insert into mytb values (&#39;9787302496878&#39;,&#39;中国文化经典读本&#39;,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()
登录后复制

以上是Python中SQLite数据库如何使用的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP和Python:代码示例和比较 PHP和Python:代码示例和比较 Apr 15, 2025 am 12:07 AM

PHP和Python各有优劣,选择取决于项目需求和个人偏好。1.PHP适合快速开发和维护大型Web应用。2.Python在数据科学和机器学习领域占据主导地位。

CentOS上PyTorch的GPU支持情况如何 CentOS上PyTorch的GPU支持情况如何 Apr 14, 2025 pm 06:48 PM

在CentOS系统上启用PyTorchGPU加速,需要安装CUDA、cuDNN以及PyTorch的GPU版本。以下步骤将引导您完成这一过程:CUDA和cuDNN安装确定CUDA版本兼容性:使用nvidia-smi命令查看您的NVIDIA显卡支持的CUDA版本。例如,您的MX450显卡可能支持CUDA11.1或更高版本。下载并安装CUDAToolkit:访问NVIDIACUDAToolkit官网,根据您显卡支持的最高CUDA版本下载并安装相应的版本。安装cuDNN库:前

docker原理详解 docker原理详解 Apr 14, 2025 pm 11:57 PM

Docker利用Linux内核特性,提供高效、隔离的应用运行环境。其工作原理如下:1. 镜像作为只读模板,包含运行应用所需的一切;2. 联合文件系统(UnionFS)层叠多个文件系统,只存储差异部分,节省空间并加快速度;3. 守护进程管理镜像和容器,客户端用于交互;4. Namespaces和cgroups实现容器隔离和资源限制;5. 多种网络模式支持容器互联。理解这些核心概念,才能更好地利用Docker。

CentOS上如何进行PyTorch模型训练 CentOS上如何进行PyTorch模型训练 Apr 14, 2025 pm 03:03 PM

在CentOS系统上高效训练PyTorch模型,需要分步骤进行,本文将提供详细指南。一、环境准备:Python及依赖项安装:CentOS系统通常预装Python,但版本可能较旧。建议使用yum或dnf安装Python3并升级pip:sudoyumupdatepython3(或sudodnfupdatepython3),pip3install--upgradepip。CUDA与cuDNN(GPU加速):如果使用NVIDIAGPU,需安装CUDATool

Python vs. JavaScript:社区,图书馆和资源 Python vs. JavaScript:社区,图书馆和资源 Apr 15, 2025 am 12:16 AM

Python和JavaScript在社区、库和资源方面的对比各有优劣。1)Python社区友好,适合初学者,但前端开发资源不如JavaScript丰富。2)Python在数据科学和机器学习库方面强大,JavaScript则在前端开发库和框架上更胜一筹。3)两者的学习资源都丰富,但Python适合从官方文档开始,JavaScript则以MDNWebDocs为佳。选择应基于项目需求和个人兴趣。

CentOS下PyTorch版本怎么选 CentOS下PyTorch版本怎么选 Apr 14, 2025 pm 02:51 PM

在CentOS下选择PyTorch版本时,需要考虑以下几个关键因素:1.CUDA版本兼容性GPU支持:如果你有NVIDIAGPU并且希望利用GPU加速,需要选择支持相应CUDA版本的PyTorch。可以通过运行nvidia-smi命令查看你的显卡支持的CUDA版本。CPU版本:如果没有GPU或不想使用GPU,可以选择CPU版本的PyTorch。2.Python版本PyTorch

PyTorch在CentOS上的数据预处理怎么做 PyTorch在CentOS上的数据预处理怎么做 Apr 14, 2025 pm 02:15 PM

在CentOS系统上高效处理PyTorch数据,需要以下步骤:依赖安装:首先更新系统并安装Python3和pip:sudoyumupdate-ysudoyuminstallpython3-ysudoyuminstallpython3-pip-y然后,根据您的CentOS版本和GPU型号,从NVIDIA官网下载并安装CUDAToolkit和cuDNN。虚拟环境配置(推荐):使用conda创建并激活一个新的虚拟环境,例如:condacreate-n

centos如何安装nginx centos如何安装nginx Apr 14, 2025 pm 08:06 PM

CentOS 安装 Nginx 需要遵循以下步骤:安装依赖包,如开发工具、pcre-devel 和 openssl-devel。下载 Nginx 源码包,解压后编译安装,并指定安装路径为 /usr/local/nginx。创建 Nginx 用户和用户组,并设置权限。修改配置文件 nginx.conf,配置监听端口和域名/IP 地址。启动 Nginx 服务。需要注意常见的错误,如依赖问题、端口冲突和配置文件错误。性能优化需要根据具体情况调整,如开启缓存和调整 worker 进程数量。

See all articles