python3 sqlite3操作工具类

2024-09-04 05:58
文章标签 工具 操作 python3 sqlite3

本文主要是介绍python3 sqlite3操作工具类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本工具类对sqlite3的操作进行了封装,对外只提供初始化和execute()方法,使用极其简单,代码如下:

easy_sqlite.py

import sqlite3class EasySqlite:"""sqlite数据库操作工具类database: 数据库文件地址,例如:db/mydb.db"""_connection = Nonedef __init__(self, database):# 连接数据库self._connection = sqlite3.connect(database)def _dict_factory(self, cursor, row):d = {}for idx, col in enumerate(cursor.description):d[col[0]] = row[idx]return ddef execute(self, sql, args=[], result_dict=True, commit=True)->list:"""执行数据库操作的通用方法Args:sql: sql语句args: sql参数result_dict: 操作结果是否用dict格式返回commit: 是否提交事务Returns:list 列表,例如:[{'id': 1, 'name': '张三'}, {'id': 2, 'name': '李四'}]"""if result_dict:self._connection.row_factory = self._dict_factoryelse:self._connection.row_factory = None# 获取游标_cursor = self._connection.cursor()# 执行SQL获取结果_cursor.execute(sql, args)if commit:self._connection.commit()data = _cursor.fetchall()_cursor.close()return dataif __name__ == '__main__':db = EasySqlite('browser.db')# print(db.execute("select name from sqlite_master where type=?", ['table']))# print(db.execute("pragma table_info([user])"))# print(execute("insert into user(id, name, password) values (?, ?, ?)", [2, "李四", "123456"]))print(db.execute("select id, name userName, password pwd from user"))print(db.execute("select * from user", result_dict=False))print(db.execute("select * from user"))


执行输出结果:

[{'id': 1, 'userName': '张三', 'pwd': '123456'}, {'id': 2, 'userName': '李四', 'pwd': '123456'}]
[(1, '张三', '123456'), (2, '李四', '123456')]
[{'id': 1, 'name': '张三', 'password': '123456'}, {'id': 2, 'name': '李四', 'password': '123456'}]


这篇关于python3 sqlite3操作工具类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1135194

相关文章

Python文件操作与IO流的使用方式

《Python文件操作与IO流的使用方式》:本文主要介绍Python文件操作与IO流的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python文件操作基础1. 打开文件2. 关闭文件二、文件读写操作1.www.chinasem.cn 读取文件2. 写

Java实现MinIO文件上传的加解密操作

《Java实现MinIO文件上传的加解密操作》在云存储场景中,数据安全是核心需求之一,MinIO作为高性能对象存储服务,支持通过客户端加密(CSE)在数据上传前完成加密,下面我们来看看如何通过Java... 目录一、背景与需求二、技术选型与原理1. 加密方案对比2. 核心算法选择三、完整代码实现1. 加密上

Spring Validation中9个数据校验工具使用指南

《SpringValidation中9个数据校验工具使用指南》SpringValidation作为Spring生态系统的重要组成部分,提供了一套强大而灵活的数据校验机制,本文给大家介绍了Spring... 目录1. Bean Validation基础注解常用注解示例在控制器中应用2. 自定义约束验证器定义自

SQL常用操作精华之复制表、跨库查询、删除重复数据

《SQL常用操作精华之复制表、跨库查询、删除重复数据》:本文主要介绍SQL常用操作精华之复制表、跨库查询、删除重复数据,这些SQL操作涵盖了数据库开发中最常用的技术点,包括表操作、数据查询、数据管... 目录SQL常用操作精华总结表结构与数据操作高级查询技巧SQL常用操作精华总结表结构与数据操作复制表结

Linux系统调试之ltrace工具使用与调试过程

《Linux系统调试之ltrace工具使用与调试过程》:本文主要介绍Linux系统调试之ltrace工具使用与调试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、ltrace 定义与作用二、ltrace 工作原理1. 劫持进程的 PLT/GOT 表2. 重定

Java使用Stream流的Lambda语法进行List转Map的操作方式

《Java使用Stream流的Lambda语法进行List转Map的操作方式》:本文主要介绍Java使用Stream流的Lambda语法进行List转Map的操作方式,具有很好的参考价值,希望对大... 目录背景Stream流的Lambda语法应用实例1、定义要操作的UserDto2、ListChina编程转成M

使用Java编写一个字符脱敏工具类

《使用Java编写一个字符脱敏工具类》这篇文章主要为大家详细介绍了如何使用Java编写一个字符脱敏工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、字符脱敏工具类2、测试工具类3、测试结果1、字符脱敏工具类import lombok.extern.slf4j.Slf4j

使用Python开发Markdown兼容公式格式转换工具

《使用Python开发Markdown兼容公式格式转换工具》在技术写作中我们经常遇到公式格式问题,例如MathML无法显示,LaTeX格式错乱等,所以本文我们将使用Python开发Markdown兼容... 目录一、工具背景二、环境配置(Windows 10/11)1. 创建conda环境2. 获取XSLT

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获