【30天玩转python】数据库操作

news2024/9/20 16:58:27

数据库操作

数据库是应用程序中用于存储和管理数据的核心组件。Python 提供了多种与数据库交互的方式,支持不同类型的数据库,包括关系型数据库(如 MySQL、PostgreSQL)和 NoSQL 数据库(如 MongoDB)。在这篇文章中,我们将介绍 Python 如何与常见的数据库进行操作。


1. 关系型数据库

关系型数据库(Relational Database)使用表的形式存储数据,并通过 SQL(结构化查询语言)来进行数据查询和操作。常见的关系型数据库包括 MySQL、PostgreSQL、SQLite 等。

1.1 使用 SQLite

SQLite 是一种轻量级的关系型数据库,Python 内置了对 SQLite 的支持,无需安装其他软件或驱动。

创建 SQLite 数据库并执行基本操作

import sqlite3

# 连接到 SQLite 数据库,如果数据库不存在则会自动创建
conn = sqlite3.connect('example.db')

# 创建一个游标对象,用于执行 SQL 语句
cursor = conn.cursor()

# 创建一个表
cursor.execute('''CREATE TABLE IF NOT EXISTS users (
                    id INTEGER PRIMARY KEY AUTOINCREMENT,
                    name TEXT NOT NULL,
                    age INTEGER NOT NULL)''')

# 插入数据
cursor.execute("INSERT INTO users (name, age) VALUES ('Alice', 30)")
cursor.execute("INSERT INTO users (name, age) VALUES ('Bob', 25)")

# 提交事务
conn.commit()

# 查询数据
cursor.execute("SELECT * FROM users")
rows = cursor.fetchall()

for row in rows:
    print(row)

# 关闭连接
conn.close()

代码说明:

  • 我们首先连接到一个名为 example.db 的 SQLite 数据库。
  • 使用 SQL 语句创建一个名为 users 的表,包含 idnameage 三列。
  • 然后,插入了两条数据并通过 SELECT 语句查询数据库中的所有数据。
  • 最后关闭数据库连接。
1.2 使用 MySQL

MySQL 是一种常用的开源关系型数据库管理系统。要使用 MySQL 进行 Python 编程,你需要安装 mysql-connector-python 库:

pip install mysql-connector-python

连接 MySQL 数据库并执行基本操作

import mysql.connector

# 连接到 MySQL 数据库
conn = mysql.connector.connect(
    host="localhost",
    user="root",
    password="your_password",
    database="test_db"
)

# 创建一个游标对象
cursor = conn.cursor()

# 创建一个表
cursor.execute('''CREATE TABLE IF NOT EXISTS employees (
                    id INT AUTO_INCREMENT PRIMARY KEY,
                    name VARCHAR(255) NOT NULL,
                    salary DECIMAL(10, 2) NOT NULL)''')

# 插入数据
cursor.execute("INSERT INTO employees (name, salary) VALUES (%s, %s)", ('John Doe', 50000.00))
cursor.execute("INSERT INTO employees (name, salary) VALUES (%s, %s)", ('Jane Smith', 60000.00))

# 提交事务
conn.commit()

# 查询数据
cursor.execute("SELECT * FROM employees")
rows = cursor.fetchall()

for row in rows:
    print(row)

# 关闭连接
conn.close()

代码说明:

  • 使用 mysql.connector.connect 函数连接到 MySQL 数据库。
  • 使用 CREATE TABLE 创建一个名为 employees 的表。
  • 使用 INSERT INTO 插入数据,并通过 SELECT 查询表中的所有数据。
1.3 使用 PostgreSQL

PostgreSQL 是另一种强大的开源关系型数据库。要使用 PostgreSQL 进行 Python 编程,你需要安装 psycopg2 库:

pip install psycopg2

连接 PostgreSQL 数据库并执行基本操作

import psycopg2

# 连接到 PostgreSQL 数据库
conn = psycopg2.connect(
    host="localhost",
    database="test_db",
    user="postgres",
    password="your_password"
)

# 创建一个游标对象
cursor = conn.cursor()

# 创建一个表
cursor.execute('''CREATE TABLE IF NOT EXISTS products (
                    id SERIAL PRIMARY KEY,
                    name VARCHAR(255) NOT NULL,
                    price NUMERIC(10, 2) NOT NULL)''')

# 插入数据
cursor.execute("INSERT INTO products (name, price) VALUES (%s, %s)", ('Laptop', 1200.00))
cursor.execute("INSERT INTO products (name, price) VALUES (%s, %s)", ('Phone', 800.00))

# 提交事务
conn.commit()

# 查询数据
cursor.execute("SELECT * FROM products")
rows = cursor.fetchall()

for row in rows:
    print(row)

# 关闭连接
conn.close()

代码说明:

  • 使用 psycopg2.connect 函数连接到 PostgreSQL 数据库。
  • 使用 SQL 语句创建 products 表,并插入产品数据。
  • 使用 SELECT 查询数据并输出。

2. NoSQL 数据库

NoSQL 数据库以非表格的方式存储数据,适合处理大规模数据集。常见的 NoSQL 数据库包括 MongoDB、Redis 等。

2.1 使用 MongoDB

MongoDB 是一种流行的 NoSQL 数据库,使用 BSON(类似 JSON)格式来存储数据。要使用 MongoDB 与 Python 进行交互,需要安装 pymongo 库:

pip install pymongo

连接 MongoDB 并执行基本操作

from pymongo import MongoClient

# 连接到 MongoDB 数据库
client = MongoClient('localhost', 27017)

# 选择数据库和集合
db = client['test_db']
collection = db['users']

# 插入文档
user_data = {"name": "Alice", "age": 30}
collection.insert_one(user_data)

# 查询文档
for user in collection.find():
    print(user)

# 更新文档
collection.update_one({"name": "Alice"}, {"$set": {"age": 31}})

# 删除文档
collection.delete_one({"name": "Alice"})

# 关闭连接
client.close()

代码说明:

  • 使用 MongoClient 连接到 MongoDB 服务器,并选择 test_db 数据库中的 users 集合。
  • 插入一个用户文档,并使用 find 方法查询所有文档。
  • 更新用户文档中的年龄字段,并删除用户。

3. 数据库连接池

对于大规模的应用程序,使用数据库连接池能够提高性能,避免每次请求都需要重新建立数据库连接。Python 中的 SQLAlchemyDBUtils 库提供了数据库连接池的支持。

3.1 使用 SQLAlchemy 连接池

SQLAlchemy 是一个强大的 ORM 库,同时支持数据库连接池功能。

pip install sqlalchemy

创建 MySQL 连接池并执行操作

from sqlalchemy import create_engine

# 创建连接池
engine = create_engine('mysql+mysqlconnector://root:password@localhost/test_db', pool_size=5, max_overflow=10)

# 执行数据库操作
with engine.connect() as conn:
    result = conn.execute("SELECT * FROM employees")
    for row in result:
        print(row)

4. 小结

  • Python 提供了多种方式与数据库进行交互,支持关系型数据库(如 SQLite、MySQL、PostgreSQL)和 NoSQL 数据库(如 MongoDB)。
  • 使用 sqlite3 模块可以轻松操作 SQLite 数据库,适合轻量级应用。
  • 通过第三方库 mysql-connector-pythonpsycopg2,可以连接和操作 MySQL 和 PostgreSQL 数据库。
  • pymongo 库提供了与 MongoDB 的接口,适合 NoSQL 数据库操作。
  • 数据库连接池提高了大规模应用的性能,使用 SQLAlchemy 可以实现连接池的管理。

掌握这些数据库操作方法,能让你在应用开发中灵活选择合适的数据库,并高效管理和处理数据。

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

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

相关文章

【STL】stack,deque,queue 基础,应用与操作

stack 1.stack相关介绍 stack(栈) 栈是一种后进先出(LIFO, Last In First Out)的数据结构,意味着最后插入的数据最先被移除。C 中的栈是通过容器适配器实现的,底层默认使用 deque(双端队列&am…

数字电子技术-数值比较器

目录 数值比较器 1、1位二进制数值比较器 多位数值比较器 4位数值比较器74LS85(TTL型) 74LS85数值比较器的使用说明 数值比较器 Digital Comparator,又称数字比较器,用以对两个数字的大小或是否相等进行比较的逻辑电路。 1、1位二进制数值比较器 A和B只能取值…

硬盘数据恢复必备:4 款强大硬盘数据恢复软件推荐!

在数字化的时代,我们的生活和工作越来越离不开电脑,而硬盘作为重要的数据存储设备,一旦出现数据丢失的情况,往往会给我们带来极大的困扰。别担心,今天就为大家推荐四款强大的硬盘数据恢复软件,帮助你轻松找…

六西格玛绿带培训多少钱?从授“鱼”到授“渔”

六西格玛作为一种全球公认的质量管理方法,其影响力日益扩大,而六西格玛绿带培训作为这一体系中的关键环节,更是吸引了众多希望在职场上脱颖而出的专业人士。本文,深圳天行健企业管理咨询公司将从多个维度深入探讨“六西格玛绿带培…

巴菲特的长期投资策略:新投资者实现财务自由的启示

在投资界,沃伦巴菲特的名字几乎无人不晓。作为伯克希尔哈撒韦公司的董事长和首席执行官,巴菲特以其卓越的投资智慧和长期价值增长策略,成为了全球投资者的偶像。巴菲特的成功不仅仅是因为他的财富,更在于他对投资的深刻理解和对财…

Linux嵌入式驱动开发指南(速记版)---Linux基础篇

第一章 Ubuntu系统入门 1.1 Linux磁盘管理 1.1.1 Linux磁盘管理基本概念 关键词: Linux 磁盘管理 挂载点 /etc/fstab文件 分区 ls /dev/sd* 联系描述: Linux 磁盘管理体系通过“挂载点”概念替代了 Windows 中的“分区”概念,将硬盘部分以文…

如何保养净水器

俗话说,“三分用,七分养”,这句话道出了家电这类消费品使用寿命的秘诀。家电的长久运行并不仅仅依赖于其出厂时的品质,更与我们日常的维护保养息息相关。虽然行业标准或制造商通常会规定家电的推荐使用年限,但在许多家…

【计算机网络】传输层协议UDP

目录 一、端口号1.1 端口号范围划分1.2 认识知名端口号 二、UDP协议2.1 UDP协议端格式2.2 UDP的特点2.3 UDP的缓冲区2.4 UDP使用注意事项2.5 基于UDP的应用层协议 一、端口号 传输层协议负责数据的传输,从发送端到接收端。端口号标识一个主机上进行通信的不同的应用…

Go语言的io输入输出流

Go语言的输入输出流不如其他语言那么直观,由于是通过实现接口方法的隐式继承所以比较抽象,今天具体介绍一下go语言的输入输出流。 go语言输入输出在io库中,使用Reader接口,如下: type Reader interface {Read(p []by…

windows下用cmake编译腾讯云的对象存储COS的XML C++SDK

首先在腾讯云官网上下载sdk,网址及官方说明文档如下: 对象存储 快速入门-SDK 文档-文档中心-腾讯云 我下载解压之后的路径如下图: 下载完后就要编译了。 1.下载VS,我的开发环境是 visual studio 2019 2. 下载CMake&#xff…

UNRAID系统忘记密码解决办法

前言 unraid系统自己通过命令修改密码以后,怎么也进不去了。 这次带来如何重置密码 操作

1-2.Jetpack 之 Navigation 跳转编码模板

一、Navigation 1、Navigation 概述 Navigation 是 Jetpack 中的一个重要成员,它主要是结合导航图(Navigation Graph)来控制和简化 Fragment 之间的导航,即往哪里走,该怎么走 2、Navigate 引入 在模块级 build.gra…

《关节机械臂:智能仓库的高效助手》

关节机械臂作为一种高度精密的机器设备,在现代制造工厂的智能仓库系统中发挥着至关重要的作用。其设计初衷便是精准地模拟人类手臂在订单拣选操作中的各种运动,以实现高效、准确的物流作业。 这些多功能的机器人由多个关节巧妙组合而成,通常拥…

人工智能【AI】:未来的驱动力

在21世纪,人工智能(AI)已经成为推动技术进步和创新的关键力量。AI不仅仅是科幻小说中的概念,它已经渗透到我们日常生活的方方面面,从智能手机的语音助手到复杂的医疗诊断系统,AI的应用无处不在。 人工智能…

KG Structure as Prompt:利用知识图谱构建Prompt,提高大模型对因果关系的理解

KG Structure as Prompt:利用知识图谱构建Prompt,提高大模型对因果关系的理解 秒懂大纲提出背景解法拆解创意视角中文意译 论文:Knowledge Graph Structure as Prompt: Improving Small Language Models Capabilities for Knowledge-based Ca…

Mybatis框架映射---代码实现(XML配置以及注解形式)

目录 一. 映射关系 1 对 1-映射方式 1.通过xml文件实现映射的一对一关系 总结 : 2.通过注解的方式来实现下面的 1 对 1 的映射关系,实现级联查询 总结: 二. 映射关系多对一 1.通过xml文件实现映射的多对一关系 2.通过注解的方式来实现…

PHP发邮件教程:配置SMTP服务器发送邮件?

PHP发邮件的几种方式?如何使用PHP通过SMTP协议发信? PHP作为一种广泛使用的服务器端脚本语言,提供了多种方式来发送邮件。AokSend将详细介绍如何通过配置SMTP服务器来实现PHP发邮件教程的核心内容。 PHP发邮件教程:设置参数 这…

Qt 模型视图(一):概述

文章目录 Qt 模型视图(一):概述1、模型/视图结构基本原理2、模型3、视图4、代理5、简单实例 Qt 模型视图(一):概述 ​ 模型/视图结构是一种将数据存储和界面展示分离的编程方法。模型存储数据,视图组件显示模型中的数据,在视图组件里修改的数据会被自动…

PCIe扫盲(11)

系列文章目录 PCIe扫盲(一) PCIe扫盲(二) PCIe扫盲(三) PCIe扫盲(四) PCIe扫盲(五) PCIe扫盲(六) PCIe扫盲(七&#xff09…

剪画:一带一路机遇下,自媒体如何跨越语言障碍!

随着国家 “一带一路” 的持续推进,我国的文化魅力如璀璨星辰,在世界舞台上熠熠生辉。美食的独特风味、华服的精美绝伦,越来越受到外国人的喜爱。这对于做自媒体的小伙伴们而言,无疑是一个巨大的机遇。 然而,机遇往往与…