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

news2025/1/16 3:19:46

 专栏导读 

专栏订阅地址: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')

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

 

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

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

相关文章

Android AOSP源码编译——AOSP下载(一)

一、电脑配置 Ubuntu16.04 16G,硬盘的大小最好大于300G (我这边是找了个win电脑装了双系统 没有使用虚拟机的方式) 二、基础环境配置 1、安装git sudo apt install git配置git email和name git config --global user.email "youexample.com" git conf…

大环境下,企业如何找到大数据传输解决方案

随着网络技术的进步和智能设备的普及,大数据成为了当下社会的热点话题。但是,大数据的传输和处理仍然存在着很多的困难和挑战。在大数据传输中,如何解决数据量巨大、网络带宽不足、传输时间过长和数据安全等问题,是当前亟待破解的…

zmibra ssl证书替换

一、阿里云上申请证书 选择其他证书 二、证书上传及制作 首先当然要去阿里云申请的ssl证书下载其他类型证书,解压缩后有两个文件上传到相应目录, 文件名类似18131-mail.xxx.comkey和181111-mail.xxx.com.pem 创建目录 /opt/zimbra/ssl/aliyunssl/ 上传这两个文件 以上是…

JVM 查看配置 jinfo 及使用 jstat,查看堆栈jstack及GC

1. Jinfo 查看正在运行的Java应用程序的扩展参数: 包含 JVM 参数与 java 系统参数 命令: jinfo pid 2 jstat 查看堆内存使用情况及 GC 回收频率等: jstat [-命令选项] [vmid] [间隔时间(毫秒)] [查询次数] 2.1 jstat -gc pid 最常用,可…

多区域平台lazada,虾皮电商商品详情API接口返回值说明

Lazada和虾皮(Shopee)都是知名的电商平台,主要在东南亚地区运营。以下是关于它们的一些信息: Lazada(来赞达): Lazada成立于2012年,起初是一个全球性的电子商务平台,后来…

如何使用Mac终端给树莓派pico构建C/C++程序进行开发,以及遇到各种问题该怎么处理,不使用任何IDE或编辑器(例如VS Code)

写本文的原因是官方的教程已经过时了,如果你现在按照官方教程来在 Mac 上进行配置,那么会遇到一堆问题,比如我几乎把能踩的“雷”都踩了。所以这里记录了完整过程,以及各种错误的原因和处理方法,不然以后换 Mac 了或者…

CH-87——矿井水除氟的技术汇总

矿井水除氟的要求一般是处理后水中的含氟量≤1.0mg/L。氟化物含量高的原水往往呈偏碱性,pH值常大于7.5。利用阴离子交换树脂上的可交换阴离子,去交换水中的氟离子,达到除氟目的。氟离子的选择交换性较大,树脂上的SO42-、Cl-等阴离…

回收站删除的文件怎么恢复?文件恢复方法就看这3个!

回收站是什么呢?一般来说,在我们使用电脑时,如果在电脑上进行删除操作,被删除的文件会被系统自动放入回收站中。这实际上也是在给电脑用户一个思考的时间,如果是误操作,可以通过回收站对文件进行还原&#…

在矩池云安装使用 PaddleHub 和 PaddlePaddle

在安装 PaddleHub 导入的时候我们常常会遇到各种错误,不是这个包没这个模块,就是哪个包没这个属性,每次遇到都会很头痛,网上也没有 PaddleHub 和 PaddlePaddle 对应的版本,只能自己慢慢尝试,通过不断查错误…

Nacos Server 安装

Nacos Server 安装 版本说明 查看方式 进入Spring Cloud Alibaba wiki查看版本对应关系,下载相应的版本。 组件版本关系 Spring Cloud Alibaba VersionSentinel VersionNacos VersionRocketMQ VersionDubbo VersionSeata Version2.2.6.RELEASE1.8.11.4.24.4.02…

论文讲解——TPU-MLIR: A Compiler For TPU Using MLIR

论文讲解——TPU-MLIR: A Compiler For TPU Using MLIR https://arxiv.org/pdf/2210.15016.pdf概览模型转换TranslationCanonicalizeLoweringLayerGroup BufferizationCalibration QuantizationCorrectness Check相关资料 https://arxiv.org/pdf/2210.15016.pdf 本文将对TPU…

Canal+Kafka实现Mysql数据同步

Canal介绍 canal [kənl],译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费 canal可以用来监控数据库数据的变化,从而获得新增数据,或者修改的数据。 canal是应阿里巴巴存在杭…

什么是NVME

1. 概念 NVM Express(NVMe),或称非易失性内存主机控制器接口规范(Non-Volatile Memory express),,是一个逻辑设备接口规范。他是与AHCI类似的、基于设备逻辑接口的总线传输协议规范(相当于通讯协议中的应用层&#xf…

全开源跨境电商一键铺货货源平台--后台数据采集功能

数据库设计在设计数据库时,需要考虑到以下信息: 货源信息:包括货源标题、价格、描述、图片等信息。 用户信息:包括用户名、密码、邮箱、电话等信息。 订单信息:包括订单号、用户信息、货源信息、支付信息等。 支付信息…

磁盘的管理

一、磁盘的分区 查看磁盘 lsblk fdisk -l 2、分区 没有e扩展,则都是主分区,已经有三个主分区了,剩下的全设置为扩展 查看分区结果: 二、格式化 三、挂载

Nginx1.24源码安装与部署

环境依赖包 zlib zlib-devel pcre pcre-devel 下载nginx安装包 1、下载nginx [rootnode01 ~]# wget http://nginx.org/download/nginx-1.24.0.tar.gz --2023-07-18 16:49:00-- http://nginx.org/download/nginx-1.24.0.tar.gz Resolving nginx.org (nginx.org)... 3.125.19…

Games101学习笔记1

2023-08-10开始接触图形学 Lecture 01--Overview of Computer Graphics Lecture 02 Review of Linear Algebra

UBIFS文件系统

https://blog.csdn.net/shichaog/article/details/45932339 引言 什么是UBIFS文件系统 UBIFS是UBI file system的简称,用于裸的flash设备,作为jffs2的后继文件系统之一。UBIFS通过UBI子系统处理与MTD设备之间动作。UBIFS文件系统更适合MLCNAND FLASH。…

第三章 图论 No.9有向图的强连通与半连通分量

文章目录 定义Tarjan求SCC1174. 受欢迎的牛367. 学校网络1175. 最大半连通子图368. 银河 定义 连通分量是无向图的概念,yxc说错了,不要被误导 强连通分量:在一个有向图中,对于分量中的任意两点u,v,一定能从…

ASP.NET Core中间件记录管道图和内置中间件

管道记录 下图显示了 ASP.NET Core MVC 和 Razor Pages 应用程序的完整请求处理管道 中间件组件在文件中添加的顺序Program.cs定义了请求时调用中间件组件的顺序以及响应的相反顺序。该顺序对于安全性、性能和功能至关重要。 内置中间件记录 内置中间件原文翻译MiddlewareDe…