【Python数据库操作】使用SQLite和MySQL进行数据存储和查询!

【Python数据库操作】使用SQLite和MySQL进行数据存储和查询!

在现代应用程序中,数据存储与管理是至关重要的。Python为开发者提供了多种与数据库进行交互的方式,其中SQLite和MySQL是最常用的两种数据库。本文将深入探讨如何使用Python进行SQLite和MySQL数据库的操作,包括创建数据库、表、插入数据、查询数据等基本操作。以下是本博客的结构:
在这里插入图片描述

1. 数据库基础知识

1.1 什么是数据库?

数据库是一个有组织的集合,用于存储、管理和检索数据。数据库系统能够确保数据的一致性、安全性和完整性。

1.2 SQLite与MySQL的区别

  • SQLite

    • 嵌入式数据库,适合小型应用。
    • 数据库存储在单个文件中。
    • 支持ACID事务。
  • MySQL

    • 关系数据库管理系统,适合大型应用。
    • 需要服务器支持,支持多用户并发。
    • 提供更复杂的功能,如存储过程、触发器等。
      在这里插入图片描述

2. 使用SQLite

SQLite是Python内置的数据库库,非常适合快速原型开发和小型应用程序。

2.1 安装与导入SQLite

SQLite通常是Python标准库的一部分,无需额外安装。你只需导入sqlite3模块即可使用。

import sqlite3

2.2 创建SQLite数据库与连接

你可以使用sqlite3.connect()函数创建或连接到一个SQLite数据库。

# 创建或连接到SQLite数据库
connection = sqlite3.connect('example.db')

2.3 创建表

使用SQL语句创建表。以下是一个创建用户表的示例。

# 创建表
def create_table():with connection:connection.execute('''CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT NOT NULL,age INTEGER NOT NULL);''')
create_table()

2.4 插入数据

使用INSERT INTO语句将数据插入表中。

def insert_user(name, age):with connection:connection.execute('''INSERT INTO users (name, age) VALUES (?, ?);''', (name, age))# 插入数据
insert_user('Alice', 30)
insert_user('Bob', 25)

2.5 查询数据

使用SELECT语句查询数据。你可以使用游标来获取查询结果。

def fetch_users():cursor = connection.cursor()cursor.execute('SELECT * FROM users;')users = cursor.fetchall()return users# 查询并打印数据
for user in fetch_users():print(user)

2.6 更新数据

使用UPDATE语句更新现有数据。

def update_user(user_id, name, age):with connection:connection.execute('''UPDATE users SET name = ?, age = ? WHERE id = ?;''', (name, age, user_id))# 更新数据
update_user(1, 'Alice Smith', 31)

2.7 删除数据

使用DELETE语句删除数据。

def delete_user(user_id):with connection:connection.execute('''DELETE FROM users WHERE id = ?;''', (user_id,))# 删除数据
delete_user(2)

在这里插入图片描述

3. 使用MySQL

MySQL是一个功能丰富的关系数据库,适用于大规模应用。我们将使用mysql-connector-python库与MySQL数据库交互。

3.1 安装MySQL Connector

使用pip安装MySQL连接器:

pip install mysql-connector-python

3.2 连接到MySQL数据库

使用mysql.connector.connect()方法连接到MySQL数据库。

import mysql.connector# 连接到MySQL数据库
connection = mysql.connector.connect(host='localhost',user='your_username',password='your_password',database='your_database'
)

3.3 创建表

创建表的SQL语句与SQLite类似。

def create_mysql_table():cursor = connection.cursor()cursor.execute('''CREATE TABLE IF NOT EXISTS employees (id INT AUTO_INCREMENT PRIMARY KEY,name VARCHAR(100) NOT NULL,salary DECIMAL(10, 2) NOT NULL);''')connection.commit()create_mysql_table()

3.4 插入数据

使用INSERT INTO语句插入数据。

def insert_employee(name, salary):cursor = connection.cursor()cursor.execute('''INSERT INTO employees (name, salary) VALUES (%s, %s);''', (name, salary))connection.commit()# 插入数据
insert_employee('John Doe', 50000.00)
insert_employee('Jane Doe', 60000.00)

3.5 查询数据

查询MySQL中的数据。

def fetch_employees():cursor = connection.cursor()cursor.execute('SELECT * FROM employees;')employees = cursor.fetchall()return employees# 查询并打印数据
for employee in fetch_employees():print(employee)

3.6 更新数据

使用UPDATE语句更新现有数据。

def update_employee(employee_id, name, salary):cursor = connection.cursor()cursor.execute('''UPDATE employees SET name = %s, salary = %s WHERE id = %s;''', (name, salary, employee_id))connection.commit()# 更新数据
update_employee(1, 'John Smith', 55000.00)

3.7 删除数据

使用DELETE语句删除数据。

def delete_employee(employee_id):cursor = connection.cursor()cursor.execute('''DELETE FROM employees WHERE id = %s;''', (employee_id,))connection.commit()# 删除数据
delete_employee(2)

在这里插入图片描述

4. 数据库连接管理

在实际应用中,数据库连接管理至关重要。我们应该确保在使用后关闭连接,以避免资源泄露。

# 关闭连接
def close_connection():connection.close()close_connection()

在这里插入图片描述

5. 使用ORM进行数据库操作

ORM(对象关系映射)是一种通过对象来操作数据库的方式,简化了数据库操作。Python中常用的ORM库有SQLAlchemy和Django ORM。

5.1 使用SQLAlchemy

安装SQLAlchemy:

pip install SQLAlchemy

使用SQLAlchemy进行数据操作的基本步骤包括创建模型、创建数据库和执行查询。

from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker# 创建引擎和基础类
engine = create_engine('sqlite:///example.db')
Base = declarative_base()# 定义模型
class User(Base):__tablename__ = 'users'id = Column(Integer, primary_key=True)name = Column(String)age = Column(Integer)# 创建表
Base.metadata.create_all(engine)# 创建会话
Session = sessionmaker(bind=engine)
session = Session()# 插入数据
new_user = User(name='Alice', age=30)
session.add(new_user)
session.commit()# 查询数据
for user in session.query(User).all():print(user.name)

在这里插入图片描述

6. 数据库事务管理

事务确保一系列数据库操作要么全部成功,要么全部失败。使用Python的数据库库时,应确保使用事务以保持数据一致性。

# 使用事务
def insert_multiple_users(users):try:with connection:for user in users:insert_user(user['name'], user['age'])except Exception as e:print(f"Error: {e}")# 插入多条数据
insert_multiple_users([{'name': 'Tom', 'age': 28}, {'name': 'Jerry', 'age': 26}])

在这里插入图片描述

7. 数据库性能优化

性能优化是数据库管理的重要组成部分,以下是一些基本的优化策略:

  • 使用索引:为常用查询字段创建索引,以提高查询速度。
  • 避免使用SELECT *:明确列出需要的字段,减少数据传输量。
  • 使用连接池:在高并发情况下使用连接池来复用连接,提高性能。
    在这里插入图片描述

8. 数据库安全性

确保数据库安全性是开发中的一项重要任务,以下是一些基本的安全措施:

  • 使用参数化查询:防止SQL注入攻击。
  • 定期备份:确保数据的安全和恢复。
  • 限制数据库权限:仅授予必要的权限,避免过度权限。
    在这里插入图片描述

9. 处理异常

在与数据库交互时,处理异常至关重要。使用try-except语句捕获可能的错误,以便采取适当的措施。

try:# 进行数据库操作insert_user('Error Test', 20)
except sqlite3.Error as e:print(f"An error occurred: {e}")

在这里插入图片描述

10. 结束与总结

在这篇博客中,我们深入探讨了如何在Python中使用SQLite和MySQL进行数据库操作。我们学习了如何创建数据库和表、插入、查询、更新和删除数据、使用ORM以及如何处理事务和异常。希望这些实用的技巧能帮助你在开发中高效地进行数据库操作,并确保数据的安全和完整性。无论你是新手还是经验丰富的开发者,掌握这些技能都将极大地提升你的开发能力。
在这里插入图片描述

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

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

相关文章

ES6 Promise的用法

学习链接:ES6 Promise的用法,ES7 async/await异步处理同步化,异步处理进化史_哔哩哔哩_bilibili 一、同步与异步区别 1.JavaScript代码是单线程的程序,即通过一行一行代码顺序执行,即同步概念。 2.若处理一些简短、…

uploads-labs靶场刷题记录

Pass-01 尝试上传一句话木马 1.php: <?php eval($_POST[cmd]);?>发现设置了白名单且抓包没有记录&#xff0c;说明在前端进行的拦截&#xff08;可以禁用前端的JS从而绕过拦截&#xff0c;达到直接上传木马的目的&#xff09;。 将一句话木马文件加上.jpg后缀1.php.jp…

后端常用安全措施

一、限流 1.简介 限流就是限制流量&#xff0c;但这里的流量是一个比较笼统的概念。如果考虑各种不同的场景&#xff0c;限流是非常复杂的&#xff0c;而且和具体的业务规则密切相关 通过限流&#xff0c;可以控制服务请求的速率&#xff0c;从而提高系统应对突发大流量的能…

ElementPlus中时间选择器配置

看文档老是力不从心&#xff0c;感觉找不到自己想要的样式的选择器记录一下吧 <el-date-pickerv-model"group.timeLimit"type"datetimerange":default-time"DEFAULT_DATE_TIME"range-separator"-"start-placeholder"开始时间&…

计算机组成原理一句话

文章目录 计算机系统概述存储系统 计算机系统概述 指令和数据以同等地位存储在存储器中&#xff0c;形式上没有差别&#xff0c;但计算机应能区分他们。通过指令周期的不同阶段。 完整的计算机系统包括&#xff0c;1&#xff09;软件系统&#xff1a;程序、文档和数据&#xff…

字符串(3)_二进制求和_高精度加法

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 字符串(3)_二进制求和_高精度加法 收录于专栏【经典算法练习】 本专栏旨在分享学习算法的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目…

2024 四川省大学生信息安全技术大赛 安恒杯 部分 WP

文章目录 一、前言二、MISCunzip-png拓展 第47张图片重要的文件 三、WEB四、CRYPTO五、REVERSE 一、前言 WP不完整&#xff0c;仅供参考&#xff01; 除WEB外&#xff0c;其余附件均已打包完毕&#xff0c;在这里也是非常感谢师傅的附件支持&#xff01; 123网盘下载&#x…

最佳简历--JAVA程序员的项目经验如何写

小熊学Java全能学习+面试指南:https://www.javaxiaobear.cn 首先你要明确,你能干什么,包括你自己编写的专业技能,到底会不会,怎么运用到技术上的? 1、你能干什么? 你能干什么,其实就展现你的能力,这是简历中最重要的部分,你需要证明前面说的你会的东东; 这就有点…

三周精通FastAPI:1 第一步入门

FastAPI是一个非常棒的python web和api框架&#xff0c;准备用三周的时间“精通它” 学习流程参考FastAPI官网的用户教程&#xff1a;教程 - 用户指南 - FastAPI 学前提示 运行代码 所有代码片段都可以复制后直接使用&#xff08;它们实际上是经过测试的 Python 文件&#x…

【前端】如何制作一个自己的网页(14)

当我们还需要对网页中的内容进行局部样式的修改。这时候&#xff0c;就需要用到HTML中的重要元素&#xff1a;span。 span是一个行内元素&#xff0c;可以对HTML文档中的内容进行局部布局。 如图&#xff0c;我们给标题和段落元素的部分内容设置了各种样式。 接下来&#xff0…

树上启发式合并(详解)

核心思想 借用了一个节点到根的路径上轻边个数不会超过logn条。 故重节点保留&#xff0c;轻节点删去&#xff0c;多重统计。 实际复杂度&#xff08;nlogn&#xff09; 例题 Lomsat gelral - 洛谷 AC 代码 #include<bits/stdc.h> #define int long long using na…

新型电力系统精细化时序模拟分析软件

一、背景意义 在“碳达峰碳中和”及“新型电力系统”战略引领下&#xff0c;新型电力系统电力电量平衡分析成为电力系统规划运行模拟仿真的必要环节。近年来&#xff0c;随着电网新能源渗透率逐渐提升&#xff0c;储能等灵活性调节资源大幅增加&#xff0c;传统的基于典型曲线…

qiankun 应用之间数据传递

qiankun 应用之间数据传递 全局共享 initGlobalState qiankun initGlobalState API 单击前往 qiankun 内部提供了 initGlobalState 方法用于注册 MicroAppStateActions 实例用于通信&#xff0c;该实例有三个方法&#xff0c;分别是onGlobalStateChange、setGlobalState、of…

小巧设计,强大功能:探索SoC模块的多样化功能

LoRa-STM32WLE5模块基于ST的STM32WLE5芯片&#xff0c;采用LoRa调制&#xff0c;适用于超远程和超低功耗无线电解决方案。搭载高性能Arm Cortex-M4核心&#xff0c;频率高达48 MHz&#xff0c;支持256 KB闪存和64 KB运行内存&#xff0c;具备安全性增强功能。广泛应用于安防、智…

C++进阶之路:日期类的实现、const成员(类与对象_中篇)

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢&#xff0c;在这里我会分享我的知识和经验。&am…

ue5 扇形射线检测和鼠标拖拽物体

这里的NumTrace是要发射几根射线&#xff0c;Degrees Per Trace是每根射线之间的角度&#xff0c; 例如 要在角色面前实现一个180度的扇形射线检测&#xff0c;就需这两个变量乘起来等于180 TraceLength是射线的长度 下面是鼠标拖动物体逻辑&#xff0c;很简单 这里的Floor和…

文心快码 - Baidu Comate 让AI帮你提高生产力|AI代码助理

码随心动&#xff0c;快人一步&#xff0c;更懂你的智能代码助手 基于文心大模型&#xff0c;结合百度编程大数据&#xff0c;为你生成优质编程代码。文心快码 - Baidu Comate&#xff0c;更懂你的AI编程伙伴&#xff0c;研发效率提升好帮手。 一、更懂研发知识 开发速度快 构…

提示词高级阶段学习day3.1

第三个类型就是让模型做信息的转化 最直观的例子就是翻译 去翻译英文&#xff0c;它的效果都非常好 除此之外&#xff0c;给大家举一个让大模型翻译代码的例子&#xff0c; 还有就是让大模型写代码的 这是一个数据分析场景&#xff0c;其实数据分析场景一直追求的就是一个…

LeetCode 精选 75 回顾

目录 一、数组 / 字符串 1.交替合并字符串 &#xff08;简单&#xff09; 2.字符串的最大公因子 &#xff08;简单&#xff09; 3.拥有最多糖果的孩子&#xff08;简单&#xff09; 4.种花问题&#xff08;简单&#xff09; 5.反转字符串中的元音字母&#xff08;简单&a…

企业级调度器 LVS

集群和分布式基础知识 系统性能的扩展方式 当一个系统&#xff0c;或一个服务的请求量达到一定的数量级的时候&#xff0c;运行该服务的服务器的性能和资源上限&#xff0c; 很容易成为其性能瓶颈。除了性能问题之外&#xff0c;如果只部署在单台服务器上&#xff0c;在此服务…