【100天精通python】Day31:使用python操作数据库_数据库编程接口,连接对象和游标对象,数据库连接配置

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 【100天精通python】Day31:使用python操作数据库_数据库编程接口,连接对象和游标对象,数据库连接配置

专栏导读

专栏订阅地址:https://blog.csdn.net/qq_35831906/category_12375510.html

       数据库编程接口是用于连接、操作和管理数据库的一组函数、类和方法。不同类型的数据库可能有不同的编程接口。以下是一些常见的数据库编程接口:

一、数据库编程接口

1. Python标准库接口

Python标准库中的sqlite3模块提供了与SQLite数据库的连接和操作接口。

import sqlite3
# 连接到SQLite数据库
conn = sqlite3.connect('mydatabase.db')
cursor = conn.cursor()
# 执行SQL查询
cursor.execute("SELECT * FROM users")
# 处理查询结果
rows = cursor.fetchall()
# 关闭连接
conn.close()

2. MySQL Connector/Python接口

mysql.connector库提供了连接和操作MySQL数据库的接口。

import mysql.connector
# 连接到MySQL数据库
conn = mysql.connector.connect(
    host="localhost",
    user="username",
    password="password",
    database="mydb"
)
cursor = conn.cursor()
# 执行SQL查询
cursor.execute("SELECT * FROM users")
# 处理查询结果
rows = cursor.fetchall()
# 关闭连接
conn.close()

3. Psycopg2接口(用于连接PostgreSQL数据库)

psycopg2库提供了连接和操作PostgreSQL数据库的接口。

import psycopg2
# 连接到PostgreSQL数据库
conn = psycopg2.connect(
    host="localhost",
    user="username",
    password="password",
    database="mydb"
)
cursor = conn.cursor()
# 执行SQL查询
cursor.execute("SELECT * FROM users")
# 处理查询结果
rows = cursor.fetchall()
# 关闭连接
conn.close()

4. SQLAlchemy接口

 SQLAlchemy库是一个全功能的SQL工具包和对象关系映射(ORM)库,提供了更高级的数据库操作接口。

from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
# 创建数据库引擎
engine = create_engine('sqlite:///mydatabase.db')
# 创建会话
Session = sessionmaker(bind=engine)
session = Session()
# 查询数据
users = session.query(User).all()
# 关闭会话
session.close()

以上是一些常见的数据库编程接口示例。根据所使用的数据库类型、项目需求和个人偏好,你可以选择合适的接口来进行数据库操作。每种接口都有其特定的优势和适用场景。

二、连接对象和游标对象

       在数据库编程中,连接对象和游标对象是两个重要的概念。它们用于执行数据库操作,但具有不同的角色和功能。

1. 连接对象(Connection Object)

       连接对象是用于建立与数据库之间的物理连接。它包含了连接数据库所需的所有信息,如主机名、用户名、密码、数据库名等。连接对象还管理着与数据库之间的通信通道,并支持事务管理。一个连接对象可以被多个游标对象所共享,但在多线程环境中需要小心处理,以避免竞争条件。

通常,连接对象的方法包括:

  • cursor(): 创建一个游标对象,用于执行SQL语句和处理查询结果。
  • commit(): 提交事务,将之前的操作永久保存到数据库。
  • rollback(): 回滚事务,撤销之前的操作。
  • close(): 关闭连接,释放资源。
  • 表1. 创建连接对象connect()函数常用的参数及说明
  • 表2. 连接对象的方法

2. 游标对象(Cursor Object)

       游标对象用于执行SQL语句并处理查询结果。每个游标对象都与一个连接对象相关联,通过连接对象创建。游标对象允许你在连接上执行多个SQL操作,并且可以逐行处理查询结果。

游标对象通常的方法包括:

  • execute(sql, params): 执行SQL语句,可以使用参数。
  • fetchone(): 获取查询结果中的下一行数据。
  • fetchall(): 获取所有查询结果的行数据。
  • fetchmany(size): 获取指定数量的查询结果行数据。
  • close(): 关闭游标,释放资源。
  • 表3 游标对象的方法

示例代码(使用sqlite3库):

import sqlite3
# 连接到SQLite数据库
conn = sqlite3.connect('mydatabase.db')
# 创建游标对象
cursor = conn.cursor()
# 执行查询语句
cursor.execute("SELECT * FROM users")
# 获取查询结果
rows = cursor.fetchall()
# 遍历和处理结果
for row in rows:
    print(row)
# 关闭游标和连接
cursor.close()
conn.close()

        连接对象用于管理物理连接,游标对象用于执行和处理数据库操作。在进行数据库操作时,要确保适当地管理连接和游标,以避免资源泄露和其他问题。

三、数据库连接配置

       数据库连接配置是在应用程序中指定用于连接数据库的各种参数,包括主机、端口、用户名、密码、数据库名称、字符集等。这些参数在建立与数据库的连接时起着关键作用。以下是一个典型的数据库连接配置示例:

1 MySQL 数据库连接配置示例

对于连接到MySQL数据库,常见的连接配置包括:

  1. 主机和端口:数据库服务器的主机名或IP地址以及连接端口。
  2. 用户名和密码:用于进行身份验证的用户名和密码。
  3. 数据库名称:要连接的具体数据库的名称。
  4. 字符集:在连接过程中要使用的字符集,以确保正确的数据交换。
import mysql.connector
# 配置数据库连接参数
config = {
    "host": "localhost",   # 主机
    "port": 3306,          # 端口
    "user": "username",    # 用户名
    "password": "password",
    "database": "mydb",    # 数据库名称
    "charset": "utf8mb4"   # 字符集
}
# 建立数据库连接
conn = mysql.connector.connect(**config)

2 PostgreSQL 数据库连接配置示例

对于连接到PostgreSQL数据库,连接配置可能包括:

  1. 主机和端口:数据库服务器的主机名或IP地址以及连接端口。
  2. 用户名和密码:用于进行身份验证的用户名和密码。
  3. 数据库名称:要连接的具体数据库的名称。
import psycopg2
# 配置数据库连接参数
conn = psycopg2.connect(
    host="localhost",     # 主机
    port="5432",          # 端口
    user="username",      # 用户名
    password="password",
    database="mydb"       # 数据库名称
)

3 SQLite 数据库连接配置示例

       对于连接到SQLite数据库,连接配置通常只涉及文件路径,因为SQLite数据库是嵌入式的,存储在本地文件中。

import sqlite3
# 配置数据库连接参数(文件路径)
conn = sqlite3.connect('mydatabase.db')

       在实际应用中,根据所使用的数据库库和数据库服务器的配置,你需要适当地调整连接配置参数。连接配置的目的是为了在应用程序中建立与数据库的可靠连接,以便进行数据交换和操作。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
16天前
|
数据采集 JSON API
深入解析:使用 Python 爬虫获取淘宝店铺所有商品接口
本文介绍如何使用Python结合淘宝开放平台API获取指定店铺所有商品数据。首先需注册淘宝开放平台账号、创建应用并获取API密钥,申请接口权限。接着,通过构建请求、生成签名、调用接口(如`taobao.items.search`和`taobao.item.get`)及处理响应,实现数据抓取。代码示例展示了分页处理和错误处理方法,并强调了调用频率限制、数据安全等注意事项。此技能对开发者和数据分析师极具价值。
|
2月前
|
API Python
【02】优雅草央央逆向技术篇之逆向接口协议篇-以小红书为例-python逆向小红书将用户名转换获得为uid-优雅草央千澈
【02】优雅草央央逆向技术篇之逆向接口协议篇-以小红书为例-python逆向小红书将用户名转换获得为uid-优雅草央千澈
149 1
|
3月前
|
数据采集 存储 XML
Python爬虫:深入探索1688关键词接口获取之道
在数字化经济中,数据尤其在电商领域的价值日益凸显。1688作为中国领先的B2B平台,其关键词接口对商家至关重要。本文介绍如何通过Python爬虫技术,合法合规地获取1688关键词接口,助力商家洞察市场趋势,优化营销策略。
|
2天前
|
数据库 Python
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
【YashanDB知识库】python驱动查询gbk字符集崖山数据库CLOB字段,数据被驱动截断
|
16天前
|
存储 JSON API
Python测试淘宝店铺所有商品接口的详细指南
本文详细介绍如何使用Python测试淘宝店铺商品接口,涵盖环境搭建、API接入、签名生成、请求发送、数据解析与存储、异常处理等步骤。通过具体代码示例,帮助开发者轻松获取和分析淘宝店铺商品数据,适用于电商运营、市场分析等场景。遵守法规、注意调用频率限制及数据安全,确保应用的稳定性和合法性。
|
22天前
|
关系型数据库 数据库 数据安全/隐私保护
云数据库实战:基于阿里云RDS的Python应用开发与优化
在互联网时代,数据驱动的应用已成为企业竞争力的核心。阿里云RDS为开发者提供稳定高效的数据库托管服务,支持多种数据库引擎,具备自动化管理、高可用性和弹性扩展等优势。本文通过Python应用案例,从零开始搭建基于阿里云RDS的数据库应用,详细演示连接、CRUD操作及性能优化与安全管理实践,帮助读者快速上手并提升应用性能。
|
1月前
|
API 文件存储 数据安全/隐私保护
python 群晖nas接口(一)
这段代码展示了如何通过群晖NAS的API获取认证信息(SID)并列出指定文件夹下的所有文件。首先,`get_sid()`函数通过用户名和密码登录NAS,获取会话ID(SID)。接着,`list_file(filePath, sid)`函数使用该SID访问FileStation API,列出给定路径`filePath`下的所有文件。注意需替换`yourip`、`username`和`password`为实际值。
112 18
|
9天前
|
SQL 关系型数据库 数据库连接
|
1月前
|
API Python
python泛微e9接口开发
通过POST请求向指定IP的API注册设备以获取`secrit`和`spk`。请求需包含`appid`、`loginid`、`pwd`等头信息。响应中包含状态码、消息及`secrit`(注意拼写)、`secret`和`spk`字段。示例代码使用`curl`命令发送请求,成功后返回相关信息。
51 5
|
1月前
|
API 文件存储 Python
python 群晖nas接口(二)
这段代码展示了如何通过API将文件上传到群晖NAS。它使用`requests`库发送POST请求,指定文件路径、创建父级目录及覆盖同名文件的参数,并打印上传结果。确保替换`yourip`和`sid`为实际值。
73 2

热门文章

最新文章