python学习笔记(十)完善数据库操作
1.cur = coon.cursor(cursor=pymysql.cursors.DictCursor)的用法
建立游标,指定cursor类型返回的是字典,如果不指定类型,返回的是元组类型数据
- import flask,pymysql,hashlib,json,redis
- def mydb(sql,port=,charset='utf8'):
- host,user,passwd,db='118.24.3.40','jxz','','jxz'
- coon = pymysql.connect(user=user,host=host,port=port,passwd=passwd,db=db,charset=charset)
- cur = coon.cursor(cursor=pymysql.cursors.DictCursor)#建立游标,指定cursor类型返回的是字典
- cur.execute(sql)
- if sql.strip()[:].upper()=='SELECT':
- res = cur.fetchall()
- else:
- coon.commit()
- res='ok'
- cur.close()
- coon.close()
- return res
- print(mydb('select * from users_info' ))
- 指定游标的输出类型为字典,输出如下:
- [{'passwd': '', 'username': 'zhaoxian', 'id': ''}, {'passwd': 'e10adc3949ba59abbe56e057f20f883e', 'username': 'xiaohei', 'id': ''}, {'passwd': 'ab56b4d92b40713acc5af89985d4b786', 'username': 'lily', 'id': ''}]
- 未指定游标输出类型,输出如下:
- (('', 'zhaoxian', ''), ('', 'xiaohei', 'e10adc3949ba59abbe56e057f20f883e'), ('', 'lily', 'ab56b4d92b40713acc5af89985d4b786'))
2.cur.fetchone()与cur.fetchall(),cur.fetchmany()的区别
- cur.fetchone()
- #获取到这个sql执行的一条结果,它返回就只是一条数据
- cur.fetchall()
- #获取到这个sql执行的全部结果,它把数据库表里面的每一行数据放到一个list里面
- cur.fetchmany()
- #能传入一个数,指定返回多少条数据,如上就是指定返回5条数据
- 如果sql语句执行的结果是多条数据的时候,那就用fetchall()
如果你能确定sql执行的结果就只有一条,那么就用fetchone()
3.cur.description可以动态获取到数据库中表的字段
- import flask,pymysql,hashlib,json,redis
- def mydb(sql,port=,charset='utf8'):
- host,user,passwd,db='118.24.3.40','jxz','','jxz'
- coon = pymysql.connect(user=user,host=host,port=port,passwd=passwd,db=db,charset=charset)
- cur = coon.cursor()#建立游标,指定cursor类型返回的是字典
- cur.execute(sql)
- if sql.strip()[:].upper()=='SELECT':
- fields = []
- #print(cur.description)输出为:(('id', 253, None, 40, 40, 0, True), ('username', 253, None, 40, 40, 0, True), ('passwd', 253, None, 40, 40, 0, True))
- for field in cur.description: #循环cur.descriptin中的元素
- fields.append(field[]) #取cur.descriptin中的每个元素是一个元组,然后取第一个元素添加到fields列表中
- print(fields)
- else:
- coon.commit()
- cur.close()
- coon.close()
- mydb('select * from users_info' )
- fields = []
- for field in cur.description: #循环cur.descriptin中的元素
- fields.append(field[])
- 这三行代码可以用列表生成式代替,使代码更简洁更有逼格,作用效果是完全一样的
- fields = [field[] for field in fields]
python学习笔记(十)完善数据库操作的更多相关文章
- python学习笔记(十 二)、操作数据库
每一种语言都少不了多数据库进行各种操作. python支持多种数据库.有关python支持的数据库清单,请参阅:https://wiki.python.org/moin/DatabaseInterfa ...
- Python学习笔记六:数据库操作
一:Python操作数据库的流程 二:开发环境准备 1:开发工具PyCharm 2:Python操作mysql的工具:需要安装Python-Mysql Connector,网址:https://sou ...
- [Python] 学习笔记之MySQL数据库操作
1 Python标准数据库接口DB-API介绍 Python标准数据库接口为 Python DB-API,它为开发人员提供了数据库应用编程接口.Python DB-API支持很多种的数据库,你可以选择 ...
- Python学习笔记21:数据库操作(sqlite3)
Python自带一个轻量级的关系型数据库SQLite.这一数据库使用SQL语言. SQLite作为后端数据库,能够搭配Python建站点,或者制作有数据存储需求的工具. SQLite还在其他领域有广泛 ...
- python学习笔记(十)、文件操作
在前面我们了解到了没得模块,其中有一个模块为fileinput,为文件操作模块,不知道小伙伴们是否还记得? 1 打开文件 要打开文件,可以使用fileinput中的fileinput.input函数进 ...
- python3.4学习笔记(十五) 字符串操作(string替换、删除、截取、复制、连接、比较、查找、包含、大小写转换、分割等)
python3.4学习笔记(十五) 字符串操作(string替换.删除.截取.复制.连接.比较.查找.包含.大小写转换.分割等) python print 不换行(在后面加上,end=''),prin ...
- python学习笔记(二)、字符串操作
该一系列python学习笔记都是根据<Python基础教程(第3版)>内容所记录整理的 1.字符串基本操作 所有标准序列操作(索引.切片.乘法.成员资格检查.长度.最小值和最大值)都适用于 ...
- Python学习笔记(十二)—Python3中pip包管理工具的安装【转】
本文转载自:https://blog.csdn.net/sinat_14849739/article/details/79101529 版权声明:本文为博主原创文章,未经博主允许不得转载. https ...
- python 学习笔记十六 django深入学习一 路由系统,模板,admin,数据库操作
django 请求流程图 django 路由系统 在django中我们可以通过定义urls,让不同的url路由到不同的处理函数 from . import views urlpatterns = [ ...
随机推荐
- 集中精力的重要性(The Importance of Focus)
集中精力的重要性(The Importance of Focus) 在当今激烈竞争的经济中,你需要集中精力使得你公司的独特方面精益求精.并且你需要每天将精力集中在改进你的公司上.通过终极外包,单干型企 ...
- java为安全起见对Applet有所限制
Applet消亡的原因: ①java为安全起见对Applet有所限制:Applet不允许访问本地文件信息.敏感信息,不能执行本地指令(比如FORMAT),不能访问初原服务器之外的其他服务器. ① IE ...
- java---同步与并发概念
Java中并发的形式无非是多线程和多进程两种形式.这两种形式都是可以利用多核来发挥计算能力的. 先说并发: 多进程意味着同时运行多个JVM,这个代价通常比多线程高,每个JVM都有自己的堆栈.都要分别加 ...
- thinkPHP隐藏url地址栏中的index.php方法
http://localhost/workSpace/First/index.php/Home/Index/index隐藏上面url中的index.php方法如下: 第一步.删除apache配置文件( ...
- char[]与TCHAR[]互相转换引发的一个问题!
软件的一个驱动由于开发的年代比较久一些,使用的是非Unicode编码,而当前新的软件使用的是Unicode编码,于是将非Unicode驱动用于Unicode软件上时,就出现了问题! 问题就出现在非 ...
- STL容器:list双向链表学习
list是一个双向列表容器,完成了标准C++数据结构中链表的所有功能; list与vector和deque类似,只不过其中的对象提供了对元素的随机访问. STL以双向链表的方式实现list,访问需要从 ...
- 编程之美 海量数据寻找 K 大数
1. 使用最小堆, 设置最小堆的大小为K, 仅需遍历一遍即可 2. 寻找最大的 K 个数实质上是寻找第 K 大的数. 通过二分法在区间内不断校正 mid 的值来找到 pivot, 时间复杂度为 o(N ...
- AsyncTask--远程图片获取与本地缓存
对于客户端——服务器端应用,从远程获取图片算是经常要用的一个功能,而图片资源往往会消耗比较大的流量,对应用来说,如果处理不好这个问题,那会让用户很崩溃,不知不觉手机流量就用完了,等用户发现是你的应用消 ...
- 【BZOJ3790】神奇项链 Manacher+贪心
[BZOJ3790]神奇项链 Description 母亲节就要到了,小 H 准备送给她一个特殊的项链.这个项链可以看作一个用小写字 母组成的字符串,每个小写字母表示一种颜色.为了制作这个项链,小 H ...
- LeetCode 笔记系列16.3 Minimum Window Substring [从O(N*M), O(NlogM)到O(N),人生就是一场不停的战斗]
题目:Given a string S and a string T, find the minimum window in S which will contain all the characte ...