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='table'
该语句用于查询数据库中数据表的名称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='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()
以上是Python中SQLite数据库如何使用的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

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

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

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

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

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

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

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

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