在Python中使用sqlite3进行数据持久化操作

目录

引言

一、安装sqlite3模块

二、创建数据库连接

三、创建游标对象

四、执行SQL命令

五、提交更改

六、关闭连接

七、使用参数化查询

八、使用ORM进行数据操作

九、备份和恢复数据库

十、处理大量数据

十一、优化查询性能

十二、处理并发访问

十三、处理数据持久化

十四、进行数据库备份与恢复

总结



引言

数据持久化是将数据从临时存储状态转换为永久存储状态的过程。在Python中,有很多种方法可以实现数据持久化,其中最常见的是使用关系型数据库,如MySQL、PostgreSQL等。然而,对于一些小型的项目或简单的数据存储需求,使用SQLite3这样的嵌入式数据库可能更加方便和高效。本篇文章将介绍如何在Python中使用sqlite3模块进行数据持久化操作。

一、安装sqlite3模块

在Python中,sqlite3模块是标准库的一部分,无需额外安装。你可以直接使用以下命令导入该模块:

import sqlite3

二、创建数据库连接

要使用sqlite3模块进行数据持久化操作,首先需要创建一个数据库连接。可以使用以下代码创建一个名为test.db的SQLite数据库连接:

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

三、创建游标对象

创建数据库连接后,需要创建一个游标对象来执行SQL命令。可以使用以下代码创建一个游标对象:

cursor = conn.cursor()

四、执行SQL命令

创建游标对象后,可以使用它来执行SQL命令。以下是一些常见的SQL命令示例:

创建表:

CREATE TABLE users (id INTEGER PRIMARY KEY, name TEXT, age INTEGER)
插入数据:

INSERT INTO users (name, age) VALUES ('Alice', 25)
查询数据:

SELECT * FROM users WHERE age > 30
更新数据:

UPDATE users SET age = 31 WHERE id = 1
删除数据:

DELETE FROM users WHERE id = 1

五、提交更改

执行SQL命令后,需要使用commit()方法提交更改。例如:

conn.commit()

六、关闭连接

最后,记得关闭数据库连接以释放资源。可以使用以下代码关闭数据库连接:

conn.close()

七、使用参数化查询

为了避免SQL注入攻击,推荐使用参数化查询。参数化查询可以确保输入被正确处理,并且与查询分开,从而提高安全性。以下是一个使用参数化查询的示例:

name = 'Alice'  
age = 25  
cursor.execute("INSERT INTO users (name, age) VALUES (?, ?)", (name, age))  
conn.commit()

八、使用ORM进行数据操作

ORM(对象关系映射)是一种将数据库表映射到Python类的技术。使用ORM可以使数据操作更加面向对象和易于管理。在Python中,有很多ORM框架可供选择,其中比较流行的有SQLAlchemy和Django ORM。以下是一个使用Django ORM的示例:

from django.db import models  
  
class User(models.Model):  
    name = models.CharField(max_length=100)  
    age = models.IntegerField()  
  
# 创建用户对象  
user = User(name='Alice', age=25)  
user.save()  
  
# 查询用户  
users = User.objects.filter(age__gt=30)  
for user in users:  
    print(user.name, user.age)

九、备份和恢复数据库

为了保证数据安全,需要定期备份数据库。可以使用sqlite3的backup()方法来备份数据库。以下是一个备份数据库的示例:

import sqlite3  
from sqlite3 import Error  
  
def backup_db(db_path, backup_path):  
    if not sqlite3.sqlite_version_info >= (3, 3, 4):  
        raise EnvironmentError("Backup requires SQLite version 3.3.4 or greater.")  
    try:  
        conn = sqlite3.connect(db_path)  
        cursor = conn.cursor()  
        with open(backup_path, "wb") as backup_file:  
            backup_file.write(conn.backup(backup_file))  
        return True  
    except Error as e:  
        print(e)  
    finally:  
        cursor.close()          
        conn.close()

十、处理大量数据

如果需要处理大量数据,建议使用事务(transaction)来一次性提交或回滚多个操作,以提高性能和减少数据库交互次数。可以使用conn.execute()方法执行事务,通过传入参数isolation_level设置隔离级别,例如:

conn.execute('BEGIN TRANSACTION;')  
try:  
    # 在这里执行多个SQL操作  
    cursor.execute('INSERT INTO users (name, age) VALUES (?, ?)', ('Bob', 30))  
    cursor.execute('UPDATE users SET age = ? WHERE name = ?', (31, 'Alice'))  
    # 一次性提交事务  
    conn.execute('COMMIT;')  
except Exception as e:  
    # 如果出现异常,回滚事务  
    conn.execute('ROLLBACK;')  
    raise e  
finally:  
    conn.close()

十一、优化查询性能

对于大型数据表,查询性能可能会成为问题。以下是一些优化查询性能的方法:

1、使用索引:在经常用于查询条件的列上创建索引,可以加快查询速度。例如,可以在users表的name列上创建索引:

CREATE INDEX idx_users_name ON users (name);
2、减少查询返回结果:只获取需要的列,而不是使用SELECT *返回所有列。例如:

SELECT name, age FROM users WHERE age > 30;
3、使用连接(JOIN)代替子查询:在某些情况下,连接比子查询更高效。例如:

SELECT users.name, users.age FROM users JOIN orders ON users.id = orders.user_id WHERE orders.total > 100;

十二、处理并发访问

如果多个用户同时访问数据库,可能会导致并发问题。可以使用锁来防止并发访问导致的数据不一致。sqlite3支持对数据库进行锁定,可以通过以下代码实现:

conn = sqlite3.connect('test.db')  
conn.execute('BEGIN TRANSACTION;')  
try:  
    # 在这里执行SQL操作  
    cursor.execute('SELECT * FROM users WHERE age > ?', (30,))  
    # 获取共享锁,其他并发连接可以共享这个锁,直到事务结束或锁被释放为止。  
    conn.execute('SELECT * FROM locktable WHERE id = ?', (1,))  
    # 获取排他锁,其他并发连接无法访问这个锁所保护的表或行。  
    conn.execute('SELECT * FROM users WHERE age > ?', (30,))  
    # 释放锁,其他连接可以访问这个锁所保护的表或行。  
finally:  
    conn.execute('COMMIT;')  
    conn.close()

十三、处理数据持久化

数据持久化是将数据从内存存储到磁盘的过程,以保证数据在程序关闭后仍然可以持久保存。在Python中,可以使用sqlite3模块提供的数据库连接对象来实现数据持久化。以下是一个将数据持久化到数据库的示例:

import sqlite3  
  
# 创建数据库连接  
conn = sqlite3.connect('test.db')  
  
# 创建游标对象  
cursor = conn.cursor()  
  
# 创建数据表  
cursor.execute('CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY, name TEXT, age INTEGER)')  
  
# 插入数据  
cursor.execute('INSERT INTO users (name, age) VALUES (?, ?)', ('Alice', 25))  
cursor.execute('INSERT INTO users (name, age) VALUES (?, ?)', ('Bob', 30))  
  
# 提交更改  
conn.commit()  
  
# 关闭连接  
conn.close()

在上面的示例中,我们首先创建了一个数据库连接对象,然后使用游标对象执行SQL命令来创建数据表和插入数据。最后,我们通过调用commit()方法提交更改,并关闭数据库连接。这样,数据就被持久化到数据库中了。

十四、进行数据库备份与恢复

为了保护数据安全,我们需要定期备份数据库。可以使用sqlite3模块提供的backup()方法来备份数据库。以下是一个备份数据库的示例:

import sqlite3  
from sqlite3 import Error  
  
def backup_db(db_path, backup_path):  
    if not sqlite3.sqlite_version_info >= (3, 3, 4):  
        raise EnvironmentError("Backup requires SQLite version 3.3.4 or greater.")  
    try:  
        conn = sqlite3.connect(db_path)  
        cursor = conn.cursor()  
        with open(backup_path, "wb") as backup_file:  
            backup_file.write(conn.backup(backup_file))  
        return True  
    except Error as e:  
        print(e)  
    finally:  
        cursor.close()          
        conn.close()

总结

在本文中,我们介绍了使用Python的sqlite3模块进行数据库操作的一些基本知识和技巧。首先,我们介绍了如何创建数据库连接、游标对象和数据表。接着,我们详细讲解了如何执行SQL查询、插入、更新和删除数据,以及如何使用参数化查询来避免SQL注入攻击。

此外,我们还介绍了如何使用ORM进行数据操作、处理大量数据、优化查询性能、处理并发访问以及进行数据库备份与恢复等方面的知识和技巧。通过这些内容,我们可以了解到使用Python的sqlite3模块进行数据库操作可以更加方便、灵活和高效。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

仿真算法收敛与初值的关系

问题: 当电路中存在大电容时,由于初值设置不合理可能导致的仿真算法不收敛的问题。 解决方法:设置初始节点值。 疑问:Node set和Initial Condition的区别。 [求助] node set 和initial condition有很么区别呢? 注&…

7-4链表去重

题目 给定一个带整数键值的链表 L,你需要把其中绝对值重复的键值结点删掉。即对每个键值 K,只有第一个绝对值等于 K 的结点被保留。同时,所有被删除的结点须被保存在另一个链表上。例如给定 L 为 21→-15→-15→-7→15,你需要输出…

前端算法面试之堆排序-每日一练

如果对前端八股文感兴趣,可以留意公重号:码农补给站,总有你要的干货。 今天分享一个非常热门的算法--堆排序。堆的运用非常的广泛,例如,Python中的heapq模块提供了堆排序算法,可以用于实现优先队列&#xf…

C/C++ stm32基础知识超详细讲解(系统性学习day14)

目录 前言 一、ARM和STM32是什么? 二、STM32的开发方式 三、GPIO----寄存器开发方式 1.八种输入输出模式分析 2.寄存器 四、stm32芯片图片 五、怎么学好stm32 总结 前言 stm32的广泛含义及背景: STM32是一款由意法半导体(ST&…

mmdetection安装与训练

一、什么是mmdetection 商汤科技(2018 COCO 目标检测挑战赛冠军)和香港中文大学最近开源了一个基于Pytorch实现的深度学习目标检测工具箱mmdetection,支持Faster-RCNN,Mask-RCNN,Fast-RCNN等主流的目标检测框架&#…

前端js面试题 (四)

文章目录 ES6新增的proxy手写,proxy访问某对象输出别的数字深度拷贝,为啥无法使用JSON.parse(JSON.stringify(obj))异步编程有哪些,async await来由,本质原理是什么事件队列输出题第一题第二题第三题 粘性布局的原理,以…

Live800:2023年客服团队管理有哪些思路和方法?

在数字化时代,客服团队成为企业与客户之间的重要桥梁。随着技术不断发展,客服团队管理也在不断进化。到了2023年,最新的客服团队管理将会有哪些思路和方法呢? 一、智能化客服系统 随着人工智能技术的不断发展,智能化客…

redis-5.0.8主从集群搭建、不重启修改配置文件

一、环境准备 192.168.5.100 redis-01 192.168.5.101 redis-02 192.168.5.102 redis-03 关闭防火墙、能够通网 二、安装redis [rootlocalhost ~]# wget http://download.redis.io/releases/redis-5.0.8.tar.gz [rootlocalhost ~]# tar xf redis-5.0.8.tar.gz -C /usr/loca…

2023.11.15 hive sql之函数标准,字符串,日期,数学函数

目录 一.函数分类标准 二.查看官方函数,与简单演示 三.3种类型函数演示 四.字符串函数 1.常见字符串函数 2.索引函数 解析函数 五.日期函数 1.获取当前时间 2.获取日期相关 3.周,季度等计算 4.时间戳 六.数学函数 一.函数分类标准 目前hive三大标准 UDF:&#xff08…

十大适合外贸企业邮箱的Gmail替代品推荐

电子邮件仍然是许多人选择的媒介,因为它是交换信息的最可靠和正式的方法。无论是个人还是小型企业,电子邮件仍然是个人和专业用途的重要通信工具。它提供了一种安全、可靠且正式的方法来交换信息和文档以及共享文件。 对于大多数人来说,Googl…

RT-Thread STM32F407 DMA

这里以串口的DMA方式接收为例,串口1进行调试,串口2进行DMA接收 第一步,进入RT-Thread Settings配置DMA 第二步,进入board.h,定义串口及DMA宏 第三步,回到main.c,配置串口及DMA模式 第四步…

uniapp开发ios上线(在win环境下使用三方)

苹果 1、win环境下无法使用苹果os编译器所以使用第三方上传工具,以下示例为 初雪云 (单次收费,一元一次) 初雪云(注册p12证书):https://www.chuxueyun.com/#/pages/AppleCertificate 苹果开发者…

将ECharts图表插入到Word文档中

文章目录 在后端调用JS代码准备ECharts库生成Word文档项目地址库封装本文示例 EChartsGen_DocTemplateTool_Sample 如何通过ECharts在后台生成图片,然后插入到Word文档中? 首先要解决一个问题:总所周知,ECharts是前端的一个图表库…

websocket学习笔记【springboot+websocket聊天室demo】

文章目录 WebSocket是什么?为什么需要WebSocket?WebSocket和Http连接的区别WebSocket的工作原理基本交互过程: Java中的WebSocket支持WebSocket的优势springboot websocket themlef 一个聊天室demopom.xmlWebSocketConfigChatControllerWebController…

数字人,虚拟数字人——你看好数字人领域的发展吗?

你看好数字人领域的发展吗? 目录 一、虚拟人、数字人、虚拟数字人基本概念 1.1、虚拟人(Virtual Person) 1.2、 数字人(Digital Human) 1.3、虚拟数字人(Virtual Digital Human) 1.4、侧重…

Java魔法解密:HashMap底层机制大揭秘

文章目录 一、 源码深度解析1.1 窥探Java集合框架中的设计思想1.2 逐行解读HashMap的源代码1.2.1 类信息1.2.2 常量属性1.2.3 变量属性1.2.4 节点信息1.2.5 构造方法1.2.6 put方法1.2.6.1 putVal方法1.2.6.2 putTreeVal方法1.2.6.3 tieBreakOrder方法1.2.6.4 treeifyBin方法1.2…

菜单栏图标隐藏管理Bartender 5.0.44

Bartender是一款Mac上的菜单栏图标隐藏管理软件,它可以帮助用户轻松整理和管理菜单栏上的图标,使其更加整洁和有序。 以下是Bartender的一些主要特点和功能: 菜单栏图标隐藏:Bartender允许用户将一些不常用的菜单栏图标隐藏起来&a…

Uniapp-小程序自定义导航栏

一、项目背景 制作小程序页面时候发现原生导航栏有一定的高度是没有背景渲染的会出现这种情况 但是我们需要的是 二、原因 小程序的原生导航栏存在。一般可以使用 纯色填充顶部栏 可以直接使用navigationBarBackgroundColor完成 在style中添加 "navigationBarBackgrou…

【跨境电商独立站新手入门手册】

一直想要更新一个独立站的系列合集,用小白也看得懂的方式阐述怎么从0到1搭建并运营一个独立站,并且后续我也会录制成视频。 今天,它来了。 这是《跨境电商独立站新手入门手册》系列的第一篇。 你是否有过这样的经历:当你在网上浏…

AMEYA360分析:蔡司工业CT中的自动缺陷检测

蔡司自动缺陷检测:适用于您的应用领域的AI软件 蔡司自动化缺陷检测机器学习软件将人工智能应用于3D CT和2D X射线系统,树立了新的标杆,可对缺陷或异常(不规则)进行检测、定位与分类,同时通过读取CT扫描和X射线结果对其进行详细分析…