【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.mzph.cn/bicheng/57524.shtml

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

相关文章

No.20 笔记 | WEB安全 - 任意文件操作详解 part 2

一、文件后缀名验证 (一)验证方式分类 基于白名单验证:只允许上传白名单中指定后缀名的文件。基于黑名单验证:只允许上传黑名单中未包含后缀名的文件。 (二)实验准备 修改 Apache 的 httpd - conf 文件…

uni-app写的微信小程序如何体积太大如何处理

方法一:对主包进行分包处理,将使用url: /pages/components/equipment/equipment跳转页面的全部拆分为分包,如url: /pagesS/components/equipment/equipment 在pages.json中添加 "subPackages": [{ "root"…

2024年五一杯数学建模C题煤矿深部开采冲击地压危险预测求解全过程论文及程序

2024年五一杯数学建模 C题 煤矿深部开采冲击地压危险预测 原题再现: “煤炭是中国的主要能源和重要的工业原料。然而,随着开采深度的增加,地应力增大,井下煤岩动力灾害风险越来越大,严重影响着煤矿的安全高效开采。在…

transient关键字详解

今天没打算写blog,在看一篇关于多线程环境下SimpleDateFormat线程不安全的问题,一般我们都知道多线程下这个是不安全,但是为什么不安全不太清楚,我在看的这篇文章讲的比较透彻,我根据文章中讲结合SimpleDateFormat源码…

[Unity Demo]从零开始制作空洞骑士Hollow Knight第十五集:制作更多地图,更多敌人,更多可交互对象

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、第一个代表性场景 1.制作更多敌人2.制作更多可交互对象二、第二个代表性场景 1.制作更多敌人2.制作更多可交互对象三、第三个代表性场景 1.制作更多敌人2.制…

苹果手机照片误删还能恢复吗?3款数据恢复工具推荐

照片是人们记录生活点滴与美好回忆的重要方式之一。而苹果手机则具备了较强的拍照功能,深受市场欢迎,但其也存在误删照片并难以恢复的难题。现在市面上也又很多照片恢复软件,其功能参差不齐。今天,小编为您找到了3款高效且可靠的苹…

猫咪掉毛上岸!一招解决清理难题——好用的宠物空气净化器

养宠前就知道猫咪有换毛季,我了解的是一年有两次,养宠后才知道,一次是半年...秋天风大的时候更加严重,直接就是一只“蒲公英”,随时散落一地的猫毛。早晚给它梳毛,每次都能收获巨大一张猫饼。 家里的地板上…

高标准农田信息化推动农业产业链升级

在当前全球农业转型的关键时期,高标准农田信息化作为现代农业发展的核心驱动力之一,正深刻地影响并推动着农业产业链的全面升级。这一进程不仅关乎粮食安全与质量的提升,更是实现农业可持续发展、促进农村经济繁荣的重要途径。 技术应用&…

TCL中环开工率下滑,员工集体要求解约赔偿

“ 尽管中环的市占率有所提高,但是高开工率也带来了巨量硅片库存,严重拖累了公司业绩。 ” 转载:科技新知 原创 作者丨依蔓 编辑丨蕨影 因大幅下调开工率,光伏硅片龙头TCL中环疑似遭遇员工“离职潮”? 近日&…

Java EE规范

1、简介 Java EE的全称是Java Platform, Enterprise Edition。早期Java EE也被称为J2EE,即Java 2 Platform Enterprise Edition的缩写。从J2EE1.5以后,就改名成为Java EE。一般来说,企业级应用具备这些特征:1、数据量特别大&…

curl支持ssl报错:SSL certificate problem: unable to get local issuer certificate

1. 说明 在使用curl时返回CURLE_OUT_OF_MEMORY,猜想可能是ssl的问题,用curl命令做实验发现访问http没问题,访问https会有问题,根据打印log判断是缺少证书,需要下载证书并声明证书路径。 1.1 curl访问http 访问正常&…

计算机网络基础进阶

三次握手四次挥手 三次握手 1------建立连接----------------------2 ACK1,seq0 2------传输数据,建立连接---------1 1------传输数据,建立连接---------2 三次握手用于建立TCP连接,确保通信双方都准备好进行数据传输。整个…

Gin 协程mysql客户端

一、Gin框架 mysql配置 这里选择yaml文件配置 二、配置读取 viper 读取yaml文件中对应配置 三、mysql 的协程客户端 文件位置 package databaseimport ("database/sql""fmt""github.com/spf13/viper""log""net/http"&quo…

鸿蒙_基础

HarmonyOS基础 页面跳转 import { router } from kit.ArkUIButton(去首页).onClick(()>{router.pushUrl({ // 普通跳转,可以返回url:pages/Index}) }) Button(登录).onClick(()>{router.replaceUrl({ // 替换跳转,无法返回&#xff0…

Zabbix进阶实战!将告警推送到Syslog服务器详细教程

需求场景: 用户需要将zabbix产生的告警事件推送给rsyslog服务器,syslog服务器再对事件日志进行分析处理. 环境配置信息 服务器 IP地址 ZabbixServer 192.168.200.195 Rsyslog服务器 192.168.200.128 *Rsyslog服务器防火墙需要放通 UDP/514端口 推送脚本…

C#描述-计算机视觉OpenCV(7):MSER特征检测

C#描述-计算机视觉OpenCV(7):MSER特征检测 基本概念操作实例效果优化 基本概念 前文C#描述-计算机视觉OpenCV(6):形态学描述了如何对图像的前后景特征形态进行检测与运算,本篇将分析基于形态的…

CANoe与C#联合仿真方案

引言 CANoe作为一款强大的网络仿真工具,能够模拟各种通信协议,尤其是在汽车领域的CAN、LIN、Ethernet等协议。而C#作为一种广泛使用的编程语言,能够为CANoe提供灵活的用户界面和逻辑控制。本文将探讨如何将CANoe与C#结合,实现高效的联合仿真方案。 1. 系统架构 联合仿真…

秋招突击——8/6——万得数据面试总结

文章目录 引言正文面经整理一1、讲一下java的多态,重载,重写的概念,区别2、说一下Java的数组,链表的结构,优缺点3、创建java线程的方式有哪些,具体说说4、创建线程池呢、每个参数的意义5、通过那几种方式保…

软件测试工程师:如何写出好的测试用例?

软件测试用例(Test Case)是软件测试过程中的一种详细文档或描述,用于描述在特定条件下,对软件系统或组件进行测试的步骤、输入数据、预期输出和预期行为。编写高质量的测试用例是确保软件质量的关键步骤之一。以下是一些编写优秀测试用例的建议&#xff…

如何快速解决谷歌网站页面收录难题?

在外贸网站的运营中,页面无法被谷歌收录是一个常见的困扰。即便你的内容再优秀,如果搜索引擎的爬虫无法抓取到你的页面,那一切努力都将白费。而GPC爬虫池服务可以帮助你快速解决网站页面的收录问题。它通过千万级的爬虫池资源,强力…