sqlite3修改表内容python_Python sqlite3数据库模块使用攻略

Python作为数据科学主流语言,被广泛用于数据读存、处理、分析、建模,可以说是无所不能。

数据一般存放在本地文件或者数据库里,之前介绍过如何使用python读取本地文件,也对# PyMySQL、cx_Oracle等数据库连接库做过简单的使用分享。

这次推荐一个python自带的轻量级数据库模块-sqlite3,先要弄清楚什么是SQLite:❝ SQLite是一种用C写的小巧的嵌入式数据库,它的数据库就是一个文件。SQLite 不需要一个单独的服务器进程或操作的系统,不需要配置,这意味着不需要安装或管理,所有的维护都来自于SQLite 软件本身。

sqlite3模块不同于PyMySQL模块,PyMySQL是一个python与mysql的沟通管道,需要你在本地安装配置好mysql才能使用,而SQLite是python自带的数据库,不需要任何配置,使用sqlite3模块就可以驱动它。

本文我们将进行连接 SQLite数据库、创建表、插入数据、读取数据、修改数据等操作。

1. 导入sqlite3模块

sqlite3是内置模块,所以不需要安装的,直接import导入即可:

import sqlite3

2. 创建与SQLite数据库的连接

使用sqlite3.connect()函数连接数据库,返回一个Connection对象,我们就是通过这个对象与数据库进行交互。 数据库文件的格式是filename.db,如果该数据库文件不存在,那么它会被自动创建。 该数据库文件是放在电脑硬盘里的,你可以自定义路径,后续操作产生的所有数据都会保存在该文件中。

# 创建与数据库的连接

conn = sqlite3.connect('test.db')

还可以在内存中创建数据库,只要输入特殊参数值:memory:即可,该数据库只存在于内存中,不会生成本地数据库文件。

conn = sqlite3.connect(':memory:')

建立与数据库的连接后,需要创建一个游标cursor对象,该对象的.execute()方法可以执行sql命令,让我们能够进行数据操作。

#创建一个游标 cursor

cur = conn.cursor()

3. 在SQLite数据库中创建表

这里就要执行sql的建表语句了,我们先创建一张如下的学生成绩表-scores:

该表目前只有字段名和数据类型,没有数据,执行以下语句实现:

# 建表的sql语句

sql_text_1 = '''CREATE TABLE scores(姓名 TEXT,班级 TEXT,性别 TEXT,语文 NUMBER,数学 NUMBER,英语 NUMBER);'''

# 执行sql语句

cur.execute(sql_text_1)

4. 向表中插入数据

建完表-scores之后,只有表的骨架,这时候需要向表中插入数据:

执行以下语句插入单条数据:

# 插入单条数据

sql_text_2 = "INSERT INTO scores VALUES('A', '一班', '男', 96, 94, 98)"

cur.execute(sql_text_2)

执行以下语句插入多条数据:

data = [('B', '一班', '女', 78, 87, 85),

('C', '一班', '男', 98, 84, 90),

]

cur.executemany('INSERT INTO scores VALUES (?,?,?,?,?,?)', data)

# 连接完数据库并不会自动提交,所以需要手动 commit 你的改动conn.commit()

5. 查询数据

我们已经建好表,并且插入了三条数据,现在来查询特定条件下的数据:

# 查询数学成绩大于90分的学生

sql_text_3 = "SELECT * FROM scores WHERE 数学>90"

cur.execute(sql_text_3)

# 获取查询结果

cur.fetchall()

返回:

备注:获取查询结果一般可用.fetchone()方法(获取第一条),或者用.fetchall()方法(获取所有条)。

6. 其他操作

对数据库做改动后(比如建表、插数等),都需要手动提交改动,否则无法将数据保存到数据库。

# 提交改动的方法

conn.commit()

使用完数据库之后,需要关闭游标和连接:

# 关闭游标

cur.close()

# 关闭连接

conn.close()

附连接connection和游标cursor的API方法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/556206.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

parseInt(string, radix)

一、 变成 整形数字 二、 当字母和数字混杂的时候,从数字位开始看,一直看到非数字位为止,如果这个混杂的字符串不是以数字开头,那么就是 NaN 三、 第二个参数,表示将变量的值以多少进制(范围2~32&#xff0…

查看论坛隐藏链接_软连接与硬链接的区别

点击上方蓝色“后端开发杂谈”关注我们, 专注于后端日常开发技术分享硬链接与软连接的联系与区别文件都有文件名和数据, 这在Linux上被分为两部分: 用户数据(user data) 与 元数据(metadata). 用户数据, 即文件数据块( data block), 数据块是记录文件真实内容的地方; 元数据是文…

parseFloat(string)

一、 将字符串转换为浮点数(小数) 二、 能正常输出小数 三、只看除了一个点以前的非数字位为止 let demo 100.1; let num parseFloat(demo); // 能正常输出小数 console.log(typeof(num) : num); // number : 100.1let demo 100.1.2; let num p…

python的合法语句_Python练习2

问答:1. 写出python中的几种分支结构,并解释其执行过程;(1) if:if 表达式: #条件语句 #输出(2)if...else...if 表达式: #条件语句 #输出else: #其他条件语句 #其他输出(3)if...elif...else...if 表达式: #条件1语…

java日志框架JUL、JCL、Slf4j、Log4j、Log4j2、Logback 一网打尽

为什么程序需要记录日志 我们不可能实时的24小时对系统进行人工监控,那么如果程序出现异常错误时要如何排查呢?并且系统在运行时做了哪些事情我们又从何得知呢?这个时候日志这个概念就出现了,日志的出现对系统监控和异常分析起着…

python继承问题_Python类的继承问题

Python相比较Java,C之类的高级语言是相对来说比较容易的,但能把Python学的很好的人却不多。虽然Python容易,但python的学习道路并不简单,可借助的资料不多,能把python讲的明白的人更是不多。作为一门高级语言&#xff…

String(min)

不管括号里面是啥,都尝试转换为字符串 let demo 1234.1; let num String(demo); console.log(typeof(num) : num); // string : 1234.1let demo undefined; let num String(demo); console.log(typeof(num) : num); // string : undefinedlet demo nu…

SpringBoot项目中Controller层代码编写规范整理

文章目录Controller层代码规范SpringMVC接口定义要注意以下常见的几种问题1. 返回格式不统一2. 没有考虑失败情况3. 出现和业务无关的输入参数Controller层代码规范 主要的内容是就是接口定义里面的内容,你只要遵循里面的规范,controller就问题不大&…

如何从一张图片里取出其中一部分_如何鉴别坑人的锌合金龙头

01.对大部分人而言,锌合金龙头是一个熟悉又陌生的词儿。当我们提起锌合金龙头时,很多人会一脸茫然的回答:啥?锌合金龙头?没听过!不认识!但在日常生活中锌合金龙头的出现率可不低!不信…

Boolean()

一、 尝试把括号里面值转换为布尔值。 二、 只要是六个表示 false 之外的(false / null / undefined / NaN / ""),都是 true let demo undefined; let num Boolean(demo); console.log(typeof(num) : num); // Boolean : f…

SpringBoot框架中各层(DTO、DAO、Service、Controller)理解

粗略理解 View层→Controller层(响应用户请求)→Service层(接口→接口实现类)→DAO层,即Mapper层(抽象类:xxxMapper.java文件,具体实现在xxxMapper.xml)→Model层&#…

verilog找不到模块_工欲善其事,必先利其器 verilog编辑器搭建

一款合适的编辑器能够大大提高我们代码的编写速度,而sublime就是一款非常强大的编辑器,它在拥有丰富的插件的同时,也具备非常美型的外观。sublime是一款免费的编辑器,虽然不进行购买的话会时不时地提示购买,但是无视就…

toString(radix)

一、一般用来做进制转换,括号里面就是填进制数 二、 把其它类型的变量转换字符串类型,少用,一般要转换为字符串拼接一个空字符串就可以了 let num 1 ; console.log(typeof(num) : num); // string : 1let demo 1234; let num demo.t…

Springboot中几个层的功能总结

具体的一个web项目中是:Controller层调用了Service层的具体功能方法,Service层调用Dao层的方法,其中调用的参数是使用Entity层进行传递的 下面我们来了解一下各个层的功能及作用: Service层: 业务层–>控制业务 ; service层…

python 分类变量转为哑变量_python 虚拟变量

# -*- coding: utf-8 -*-import pandasdata pandas.read_csv(D:\\PDA\\4.18\\data.csv,encodingutf8)data[Education Level].drop_duplicates()"""博士后 Post-Doc博士 Doctorate硕士 Masters Degree学士 Bachelors Degree副学士 Associa…

log4j2漏洞

log4j2漏洞 这个漏洞到底是怎么回事? 怎么利用这个漏洞呢? 我看了很多技术分析文章,都太过专业,很多非Java技术栈或者不搞安全的人只能看个一知半解,导致大家只能看个热闹,对这个漏洞的成因、原理、利用…

python游戏csgo开挂_Python64位游戏读写--GTA锁血

37.jpg (19.22 KB, 下载次数: 1)2020-6-23 09:32 上传EPIC送了GTA5,最近考完试和朋友一起玩了下,由于刚开始,等级低,朋友带我打任务的时候,完全就打不过,我的甲没几下就爆了,刚开始没什么。但是…

log4j2 的使用【超详细图文】

log4j2 的使用 Apache Log4j2 是对Log4j 的升级版本,参考了logback 的一些优秀的设计,并且修复了一些问题,因此带来了一些重大的提升,主要有: 异常处理,在logback中,Appender中的异常不会被应…

python标准库os的方法listdir_Python 标准库 os 中的方法 listdir() 返回包含指定路径中所有文件和文件夹名称的列表。_药理学答案_学小易找答案...

【单选题】下列( )是脂肪酸 (2.0分)【单选题】关于固醇类的叙述,错误的是( ) (2.0分)【单选题】细胞膜的主动转运( ) (2.0分)【单选题】脂肪的碱水解作用又称为( ) (2.0分)【名词解释】比活力【简答题】4、什么是米氏方程,米氏常数 Km 的意义是什么?试求酶反应速度达到最大反应…

JS遍历数组的12种方法

一、 for 普通版 for (let i 0; i < arr.lengthl; i) {// ... }优化版 // 使用临时变量&#xff0c;将长度缓存起来&#xff0c;避免重复获取数组长度&#xff0c;当数组较大时优化效果才会比较明显。 let len arr.length; for (let i 0; i < len; i) {// ... }for…