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

相关文章

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

Python+wxPython开发一个文件属性比对工具

《Python+wxPython开发一个文件属性比对工具》在日常的文件管理工作中,我们经常会遇到同一个文件存在多个版本,或者需要验证备份文件与源文件是否一致,下面我们就来看看如何使用wxPython模... 目录引言项目背景与需求应用场景核心需求运行结果技术选型程序设计界面布局核心功能模块关键代码解析文件大

MySQL基本表查询操作汇总之单表查询+多表操作大全

《MySQL基本表查询操作汇总之单表查询+多表操作大全》本文全面介绍了MySQL单表查询与多表操作的关键技术,包括基本语法、高级查询、表别名使用、多表连接及子查询等,并提供了丰富的实例,感兴趣的朋友跟... 目录一、单表查询整合(一)通用模版展示(二)举例说明(三)注意事项(四)Mapper简单举例简单查询

Nginx概念、架构、配置与虚拟主机实战操作指南

《Nginx概念、架构、配置与虚拟主机实战操作指南》Nginx是一个高性能的HTTP服务器、反向代理服务器、负载均衡器和IMAP/POP3/SMTP代理服务器,它支持高并发连接,资源占用低,功能全面且... 目录Nginx 深度解析:概念、架构、配置与虚拟主机实战一、Nginx 的概念二、Nginx 的特点

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

使用Python在PDF中绘制多种图形的操作示例

《使用Python在PDF中绘制多种图形的操作示例》在进行PDF自动化处理时,人们往往首先想到的是文本生成、图片嵌入或表格绘制等常规需求,然而在许多实际业务场景中,能够在PDF中灵活绘制图形同样至关重... 目录1. 环境准备2. 创建 PDF 文档与页面3. 在 PDF 中绘制不同类型的图形python

Java 操作 MinIO详细步骤

《Java操作MinIO详细步骤》本文详细介绍了如何使用Java操作MinIO,涵盖了从环境准备、核心API详解到实战场景的全过程,文章从基础的桶和对象操作开始,到大文件分片上传、预签名URL生成... 目录Java 操作 MinIO 全指南:从 API 详解到实战场景引言:为什么选择 MinIO?一、环境

python3中正则表达式处理函数用法总结

《python3中正则表达式处理函数用法总结》Python中的正则表达式是一个强大的文本处理工具,用于匹配、查找、替换等操作,在Python中正则表达式的操作主要通过内置的re模块来实现,这篇文章主要... 目录前言re.match函数re.search方法re.match 与 re.search的区别检索

在DataGrip中操作MySQL完整流程步骤(从登录到数据查询)

《在DataGrip中操作MySQL完整流程步骤(从登录到数据查询)》DataGrip是JetBrains公司出品的一款现代化数据库管理工具,支持多种数据库系统,包括MySQL,:本文主要介绍在D... 目录前言一、登录 mysql 服务器1.1 打开 DataGrip 并添加数据源1.2 配置 MySQL

Go语言中如何进行数据库查询操作

《Go语言中如何进行数据库查询操作》在Go语言中,与数据库交互通常通过使用数据库驱动来实现,Go语言支持多种数据库,如MySQL、PostgreSQL、SQLite等,每种数据库都有其对应的官方或第三... 查询函数QueryRow和Query详细对比特性QueryRowQuery返回值数量1个:*sql