python开发 数据库编程

yumo6663个月前 (03-20)技术文章20

python db api 介绍

在pytohn api之前是使用对应数据库接口来进行与数据库交互的很麻烦,而python db api建立了统一的api接口,可以对接不同的数据库。

python db api包括哪些内容呢?

首先有一个python程序,和我们的数据库服务器,然后两者建立连接的通道就叫做数据库连接对象connection,在通道之上又有很多的数据进行传输叫做数据库交互对象cursor,最后在通道建立过程中也会出现异常现象,叫做数据库异常类exceptions。

以上除程序和服务器以外的三块内容是我们最长使用的。

python db api 访问数据库的流程,我就以文字形式进行描述了,不过其实也很简单,可以根据我的描述去画一张图来加深一下印象。

首先我们创建connection建立连接,获取cursor用来交互对象,然后就可以执行各种命令 ,处理完毕之后就可以关闭cursor,关闭connection,这样一次完整的数据库访问就结束了。

python开发过程中,与mysql数据库交互,需要安装第三方库mysql for pytohn

下面来用python代码来实现一下与mysql数据库的交互

创建数据库连接对象connection

连接对象:建立python客户端与数据库的网络连接

创建方法: mysqldb.connect(参数)

在安装mysqldb时要注意在python3上需要自己去下安装包安装,python可以直接pip install安装


import MySQLdb
conn = MySQLdb.connect( #设置连接参数
host = '127.0.0.1',
port = 3306,
user = 'xiaowang',
passwd ='123321',
)

cus = conn.cursor() #输入sql执行语句
sql = 'select version()'
cus.execute(sql) #执行
print(cus.fetchone()) #查看相关返回信息
cus.close()
conn.close() #关闭连接


这样就完成了与mysql数据库的一次完整的连接并且执行了sql语句返回相关信息,关闭连接。

在python爬虫的时候,我们要将爬取下来的结果放入数据库,就很容易保存或者查找,所以下面让我们来看一下,怎么将python爬取的数据保存到数据库当中,python的简单爬虫我已经发过了一篇文章,大家可以去看一下。

我把之前写的代码给截图放一下

那么我们今天的数据库编程,应该要怎么和爬虫代码连接起来,应该要放在哪?

遇到问题python 显示无异常,但是数据库并没有内容存入,使用

cus = conn.commit()进行数据的提交,完整代码如下。

好了,很高兴能和大家一起分享,谢谢。

相关文章

10分钟教你写一个数据库

今天教大家借助一款框架快速实现一个数据库,这个框架就是Calcite,下面会带大家通过两个例子快速教会大家怎么实现,一个是可以通过 SQL 语句的方式可以直接查询文件内容,第二个是模拟 Mysql 查...

从自建到云端,数据库迁移全攻略

一、引言在数字化浪潮席卷而来的今天,数据库作为数据存储与管理的核心,其管理和运维显得尤为重要。随着业务规模的持续扩展,为了规避性能瓶颈、安全隐患和扩展性不足等问题,不少用户选择将数据库和应用分开部署。...

值得一看的PG数据库query流程

概述今天主要分享一个PG数据库的QUERY处理流程,建议掌握,后面做优化还是有用的。流程图:流程解析第一步:客户端程序可以是任何符合 PostgreSQL 协议规范的程序,如 JDBC 驱动。Post...

详细教程:SQL2008数据库备份与还原全流程!

数据的安全性至关重要,无论是操作系统、重要文件、磁盘存储,还是企业数据库,备份都是保障其安全和完整性的关键手段。拥有备份意味着即使发生误删、系统崩溃或病毒攻击等问题,也能迅速通过恢复功能解决,避免数据...

flowable入门-创建第一个flowable流程

一、flowable定义flowable 是一个使用Java编写的轻量级业务流程引擎。基于BPMN2.0协议,实现对流程的创建、查询、流转、报结等操作的管理。二、创建一个flowable流程创建一个f...

物流产品经理入门:如何搭建一套高效的零售行业物流TMS系统?一张图搞懂系统流程

许多从业者对TMS的理解仍停留在表面,未能充分挖掘其背后全流程的逻辑与价值。本文将通过一张清晰的流程图,结合九大核心环节的深度解析,带你全面了解TMS系统如何实现从运输计划到财务核算的闭环管理,并分享...