python中web应用与mysql数据库交互
7使用数据库
具体使用python的DB-API,这一章里介绍如何编写代码与MYSQL数据库技术交互,这里使用一个通用的数据库API,名为DB-API。
7.1基于数据库的web应用
之前我们把日志数据存放在一个文本文件中,无法得知第六章最开始的请求:已经响应了多少个请求?最常用的字母列表是什么?请求来自哪个IP地址?哪个浏览器用的最多?
现使用mysql数据库存放日志数据:
- 安装mysql服务器。
- 为Python安装一个mysql数据库驱动程序。
- 为web应用创建数据库和表。
- 创建代码来处理这个web应用的数据库和表。
任务1:安装mysql服务器。
网站:http://dev.mysql.com/downloads/mysql/
千万不要选择最新版本的8.0.12我整了一下午的教训,grant按照正常方式创建用户会一直报语法错误。
问了老师说可能是版本的原因,建议下载5.6版,雷区我已经踩了
即使你没有用过mysql,不过没关系,我也接触较少(我主要对oracle了解多一些)
下载之后发现是一个zip文件,这是我的解压路径:
D:\mysql\mysql-5.6.41-winx64
安装步骤:https://blog.csdn.net/u012896719/article/details/80428493
安装完成之后mysql -uroot -p新密码(我的密码是112233)
就进入了mysql> quit退出
任务2:为Python安装一个mysql数据库驱动程序。
python解释器对于数据库提供了一个标准数据库API(应用编程接口),称为DB-API,可以用来处理基于SQL的数据库,还需要一个用来连接DB-API的驱动程序——oracle提供了一个MYSQL-Connector/python驱动。下来手动安装这个驱动,访问https://dev.mysql.com/downloads/connector/python/
在这个页面选择之前的版本最少是2.1.3,将下拉选项改为Platform Independent(平台独立):
下载之后解压,然后使用管理员打开cmd切换到这个目录下输入
py -3 setup.py install
看到下图的路径说明成功:
任务3:为web应用创建数据库和表
登录mysql:
mysql -u root -p112233
创建一个数据库存储日志数据:
create database vsearchlogDB;
下来专门为web应用创建一个数据库用户的ID和口令,以便在于mysql交互时使用,而不是一直使用根用户root。
grant all on vsearchlogDB.* to 'vsearch' identified by '112233';
退出:quit
创建一个表,字段:短语,字母,IP地址,浏览器以及结果值,还需要每个请求的唯一ID和记录消息的时间戳。
用vsearch用户登录数据库
mysql -u vsearch -p 112233
我遇到了一个问题,登录不上去,报错error 1045 access denied for user
所以分享一个解决的方案
https://www.cnblogs.com/summertime-wu/p/7466160.html
使用创建的数据库
use vsearchlogdb
创建表
create table log(
id int auto_increment primary key,
ts timestamp default current_timestamp,
phrase varchar(128) not null,
letters varchar(32) not null,
ip varchar(16) not null,
browser_string varchar(256) not null,
results varchar(64) not null);
查看表的结构
desc log;
为了让日志的记录自动加入到这个表中,而不是我们输入insert命令一行一行的插入数据,需要在Python和SQL进行交互,相应的用到DB-API更多知识。
DB-API
使用它的好处是可以轻松替换驱动程序/数据库组合,而只对Python代码进行非常小的改动。
步骤1:定义连接属性
连接到mysql需要三个信息:
l 运行mysql服务器的计算机主机的IP地址/主机名;
l 用户ID和口令;
l 这个用户想要交互的数据库名。
驱动程序允许将这些链接属性放在一个Python字典中,下来在>>>窗口进行测试
dbconfig = { 'host': '127.0.0.1',
'user': 'vsearch',
'password': '112233',
'database':'vsearchlogdb', }
步骤2:导入数据库驱动程序
>>> import mysql.connector
导入之后就可以使用mysql特定的驱动程序了
步骤3:建立与服务器的一个连接
>>> conn = mysql.connector.connect(**dbconfig)
**告诉connect函数用一个变量提供了一个参数字典,在connect函数中使用这些参数来建立连接。
步骤4:打开一个游标
把游标理解为数据库中的文件句柄。
>>> cursor = conn.cursor()
步骤5:完成SQL查询
首先向mysql请求连接数据库的表名,将show tables查询赋至_SQL变量(变量名可以使用别的),然后调用cursor.execute函数,并传入_SQL作为参数:
>>> _SQL = """show tables"""
>>> cursor.execute(_SQL)
执行后SQL查询会发送到SQL服务器执行这个查询,不过不会立即显示,请求才会得到结果。
可以使用下列三个方法获得请求结果:
- cursor.fetchone获取一行结果。
- cursor.fetchmany获取指定的任意行结果。
- cursor.fetchall获取所有数据行结果。
>>> res = cursor.fetchall()
>>> res
[('log',)]
这个结果是数据库中的表log(只有这一个表),作为元组去显示()。
换一个SQL语句查询desc log:
得到结果中的各行:
python允许在查询串中放置“数据占位符”,用%s指定
数据库系统会缓存insert,之后再一次应用全部的insert,所以有可能现在使用select查询不到数据。需要commit提交,使用conn.commit
数据已经插入
步骤6:关闭游标和连接
>>> cursor.close()
True
>>> conn.close()
任务4:创建代码处理web应用的数据库和表
调整web应用的代码,让它把web请求的数据记录到mysql数据库系统中。
def log_request(req: 'falsk请求', res: str) -> None:
dbconfig = { 'host': '127.0.0.1',
'user': 'vsearch',
'password': '112233',
'database':'vsearchlogdb', }
import mysql.connector
conn = mysql.connector.connect(**dbconfig)
cursor = conn.cursor()
_SQL = """ insert into log
(phrase, letters, ip, browser_string, results)
values
(%s, %s, %s, %s, %s)"""
cursor.execute(_SQL, (req.form['phrase'],
req.form['letters'],
req.remote_addr,
req.user_agent.browser,
res, ))
conn.commit()
cursor.close()
conn.close()
测试新的代码
py -3 vsearch_for_web.py
打开浏览器输入http://127.0.0.1:5000像之前一样测试
不过这次/viewlog不能查看最新的日志记录,现在的数据在数据库中。
窗口的大小在菜单栏右键属性中调整。
这一部分的内容已经完成了,不过别忘了函数view_the_log,后面会更新这个函数让它从数据库的log表中获取数据,而不是从文件中获取。
python中web应用与mysql数据库交互的更多相关文章
- 48.Python中ORM模型实现mysql数据库基本的增删改查操作
首先需要配置settings.py文件中的DATABASES与数据库的连接信息, DATABASES = { 'default': { 'ENGINE': 'django.db.backends.my ...
- android开发 如何通过web服务器访问MYSQL数据库并且使其数据同步到android SQLite数据库?
通过web服务器访问MYSQL数据库有以下几个过程: 1.在MySql下创建自己的数据库和自己的表单 2.连接数据库. 3.访问数据库 1.创建web工程 (服务器端) 在Myeclipse下新建一个 ...
- linux自动定时备份web程序和mysql数据库
前些天受朋友说linux定时备份不知道怎么搞,叫帮忙处理一下.由于这段时间正闲着,所以也就欣然答应.由于朋友对linux不懂也希望我将操作的过程记录下来,也就是越详细越好.所以写得比较$%^& ...
- 在Eclipse中使用JDBC访问MySQL数据库的配置方法
在Eclipse中使用JDBC访问MySQL数据库的配置方法 分类: DATABASE 数据结构与算法2009-10-10 16:37 5313人阅读 评论(10) 收藏 举报 jdbcmysql数据 ...
- Python搭建Web服务器,与Ajax交互,接收处理Get和Post请求的简易结构
用python搭建web服务器,与ajax交互,接收处理Get和Post请求:简单实用,没有用框架,适用于简单需求,更多功能可进行扩展. python有自带模块BaseHTTPServer.CGIHT ...
- Java Web工程连接MySQL数据库及Tomcat服务器页面中文乱码
Java Web工程连接MySQL数据库 一. 准备工作 1.下载连接MySQL数据库的JDBC (可以去官网下,也可以去百度云找) 2.将下载的jar文件复制到Tomcat的lib目录下 3.新建一 ...
- shell编程系列22--shell操作数据库实战之shell脚本与MySQL数据库交互(增删改查)
shell编程系列22--shell操作数据库实战之shell脚本与MySQL数据库交互(增删改查) Shell脚本与MySQL数据库交互(增删改查) # 环境准备:安装mariadb 数据库 [ro ...
- python web.py操作mysql数据库,实现对数据库的增删改查操作
使用web.py框架,实现对mysql数据库的增删改查操作: 该示例代码中连接的是本地数据库testdb,user表,表结构比较简单,只有两个字段:mobile和passwd,类型均为字符型 实际应用 ...
- 使用python读取配置文件并从mysql数据库中获取数据进行传参(基于Httprunner)
最近在使用httprunner进行接口测试,在传参时,用到了三种方法:(1)从csv文件中获取:(2)在config中声名然后进行引用:(3)从函数中获取.在测试过程中,往往有些参数是需要从数据库中获 ...
随机推荐
- 3223. 文艺平衡树【平衡树-splay】
Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 2 3 ...
- 【bzoj 3252】攻略
题意 我们想到一个贪心,就是每次找到根路径前缀和最大的一个点,取走这条路径,同时把这条路径上的点权变成\(0\) 正确性显然 进一步发现我们需要从树上选择\(m\)条链使得链的总和最大 于是我们考虑换 ...
- select、poll 和epoll区别
阻塞 I/O(blocking IO) 当用户进程调用了recvfrom这个系统调用,kernel就开始了IO的第一个阶段:准备数据(对于网络IO来说,很多时候数据在一开始还没有到达.比如,还没有收到 ...
- 生产环境mysql数据库主从恢复从数据库
故障:系统硬盘损坏,完全重装 故障机器:172.16.100.32 恢复根据的主机器:172.16.100.31 1. 重装完成后,把master主库vs/program目录拷贝过来,然后把数据库的d ...
- C库函数重定向问题
C库函数重定向用户能定义自己的C语言库函数,连接器在连接时自动使用这些新的功能函数.这个过程叫做重定向C语言库函数,如下图所示.举例来说,用户有一个I/O设备(如UART).本来库函数fputc()是 ...
- 02_Docker在CentOS 6和CentOS 7下的安装
CentOS 7 环境下安装docker 安装Docker 检查系统内核是否高于Linux3.10版本 uname -r 使用root权限操作,确保yum包是最新版本 sudo yum update ...
- 早上出现的zabbix启动错误
之前根据教程安装好zabbix,MySQL的版本是5.1. 昨天无聊想升级成5.6.不过升级比较麻烦.我就直接把5.1删了再装5.6. 安装中途zabbix挂了一次.把5.6装上启动后就好了. 早上z ...
- angularjs compile vs link
https://docs.angularjs.org/guide/directive https://docs.angularjs.org/api/ng/service/$compile https: ...
- spark练习--由IP得到所在地
今天我们就来介绍,如何根据一个IP来求出这个IP所在的地址是什么,首先我们如果要做这个内容,那么我们要有一个IP地址的所在地字典,这个我们可以在网上购买,形如: 1.0.1.0|1.0.3.255|1 ...
- Caused by: java.lang.IllegalArgumentException: Modifying queries can only use void or int/Integer as return type!
Caused by: java.lang.IllegalArgumentException: Modifying queries can only use void or int/Integer as ...