python操作mysql数据库系列-操作MySql数据库(五)
2023-09-11 14:19:05 时间
当自动化测试过程中有需要用到数据库这部分的时候,我们应该怎么办呢?有没有什么好的方法呢?本篇教程会给大家讲解一下数据库的三层架构的案例应用。比如我们都知道这样一个场景。用户一般登录时候首先要输入账号和秘密,然后点击登录,通过发送request给数据库,数据库这时候需要做的两个事情,一个是检查有没有这个用户,第二个检查用户信息是否正确。我们接下来针对这个应用场景结合mysql去了解一下三层架构的处理逻辑,,,,
第一层:数据库的查询层 我们先把操作数据查询这部分,我们写一个类:
class MySQLHeper(object):
def __init__(self):
self.conn = conn()
def get_one(self,sql,params): #我们查询一条语句,返回一条语句
'''查询数据返回'''
cur = self.conn.cursor()
cur.execute(sql,params) # 执行语句
return cur.fetchone()
cur.close() # 关闭游标连接池
self.conn.close() # 关闭数据库连接池
her = MySQLHeper() #实例化
sql = "select * from USER WHERE id=%s"
params = (1,)
print(her.get_one(sql,params))
返回结果:
C:\Python27\python2.exe D:/project/JieKou/page/mysqTests.py
(1L, 'fighter', 'admin', 'sanpang')
或者我们调用时这样去写,
class MySQLHeper(object):
def __init__(self):
self.conn = conn()
def get_one(self,sql,params):
'''查询数据返回'''
cur = self.conn.cursor()
cur.execute(sql,params) # 执行语句
return cur.fetchone()
cur.close() # 关闭游标连接池
self.conn.close() # 关闭数据库连接池
her = MySQLHeper() #实例化
sql = "select * from user WHERE username=%s and passsword=%s"
params = ('fighter','admin')
print(her.get_one(sql,params))
返回结果:
(1L, 'fighter', 'admin', 'sanpang')
首先用户输入账号和密码发送请求给数据库去查询,1.检查数据在不在,2.数据对不对。要经过数据层的处理,,,
第二层:检查数据是否存在
然后我们定义一个类 CheckUserinfo 去检查数据库中是否存在这个用户名和密码这一部分。
class CheckUserinfo(MySQLHeper): def __init__(self): self.__helper = MySQLHeper() #继承类 def userinfo(self,sql,params): return self.__helper.get_one(sql,params)
sql = "select * from user WHERE username=%s and passsword=%s"
params = ('fighter','admin')
her = CheckUserinfo() #实例化
print (her.userinfo(sql,params))
返回结果:
(1L, 'fighter', 'admin', 'sanpang')
第三层:交互层代码如下,如web上面的表单 输入信息 看到的东西输入账号和密码 界面给我们的一些信息的返回
def info():
check = CheckUserinfo()
username = raw_input('请输入您的账号:')
password = raw_input('请输入您的密码:')
sql = "select * from user WHERE username=%s and passsword=%s"
params = (username,password)
# print (check.userinfo(sql,params))
result = check.userinfo(sql,params)
print (result)
print (result[1])
if result:
print ('恭喜你!{} 登录成功!'.format(result[1]))
else:
print ('sorry!您的用户名或者密码错误!请检查!')
info()
查询结果:
请输入您的账号:fighter
请输入您的密码:admin
(1L, 'fighter', 'admin', 'sanpang')
fighter
恭喜你!fighter 登录成功!
输入正确的用户名和错误的密码:
def info():
check = CheckUserinfo()
username = raw_input('请输入您的账号:')
password = raw_input('请输入您的密码:')
sql = "select * from user WHERE username=%s and passsword=%s"
params = (username,password)
# print (check.userinfo(sql,params))
result = check.userinfo(sql,params)
if result:
print ('恭喜你!{} 登录成功!'.format(result[1]))
else:
print ('sorry!您的用户名或者密码错误!请检查!')
info()
输入结果如下:
C:\Python27\python2.exe D:/project/JieKou/page/mysqTests.py
请输入您的账号:fighter
请输入您的密码:1231
sorry!您的用户名或者密码错误!请检查!
Mysql的三层架构的实例完整代码如下:
#第三层:数据库的查询层 查询数据
class MySQLHeper(object):
def __init__(self):
self.conn = conn()
def get_one(self,sql,params):
'''查询数据返回'''
cur = self.conn.cursor()
cur.execute(sql,params) # 执行语句
return cur.fetchone()
cur.close() # 关闭游标连接池
self.conn.close() # 关闭数据库连接池
#第二层:数据库检查数据
class CheckUserinfo(MySQLHeper):
def __init__(self):
self.__helper = MySQLHeper() #继承类
def userinfo(self,sql,params):
return self.__helper.get_one(sql,params)
#第一层:交互层
def info():
check = CheckUserinfo()
username = raw_input('请输入您的账号:')
password = raw_input('请输入您的密码:')
sql = "select * from user WHERE username=%s and passsword=%s"
params = (username,password)
# print (check.userinfo(sql,params))
result = check.userinfo(sql,params)
if result:
print ('恭喜你!{} 登录成功!'.format(result[1]))
else:
print ('sorry!您的用户名或者密码错误!请检查!')
info()
相关文章
- Mysql加锁过程详解(3)-关于mysql 幻读理解
- MySQL Binlog Digger 4.28 【mysql日志分析工具】
- Python 操作 MySQL 数据库
- Python初学者如何系统的学习python————Python入门学习指南--内附学习路径
- 如何快速学习python,学好python?能通过Python赚到的第一笔钱,有哪些经验可以分享吗?
- Python零基础入门,2分钟带你了解python
- MySQL使用初步—mysql数据库的基本命令
- mysql数据库提示本地无法连接远程服务器(Host is not allowed to connect to this MySQL server)解决办法
- 【MySQL】如何向mysql数据库插入当前时间
- python学习之OpenCV-Python模块的部分应用示例(生成素描图和动漫图)
- Python 操作 mysql 数据库,并使用连接池
- 转 Python 访问数据库(SQLite、MySQL、SQLAlchemy)
- python操作mysql数据库系列-操作MySql数据库(四)
- python操作mysql数据库系列-操作MySql数据库(二)
- python操作mysql数据库系列-操作MySql数据库(一)
- python操作mysql数据库系列-安装MySql
- idea 社区版连接mysql数据库教程,Cannot connect to “MySQL-5.1.43“. CLIENT_PLUGIN_AUTH is required
- Python 操作 MySQL 之 pysql 与 ORM(转载)
- liunux mysql MySQL表名不区分大小写的设置方法
- 【Python基础】逐行读取文件并打印
- mac环境Python连mysql
- Python 常见问题 之 python 安装包下载安装速度慢 的 快速解决方法(之一)
- Python 基础 之 python 中 进程、线程、协程对比 区别和联系
- Python 基础 之 python 线程知识点整理,并实现一个简单多线程 udp 聊天应用
- Unity 工具 之 报错 Jenkins 执行/调用 Python 脚本,报错提示 ‘python‘ 不是内部或外部命令,也不是可运行的程序或批处理文件
- python操作mysql数据库
- Python使用DB-API操作MySQL数据库
- MySQL协议-python版密码解密
- 【ChatGPT】python fastapi mysql 实现 增删改查的代码
- MySQL 安装mysql数据库
- python构建web界面实现MySQL数据库的操作