python之操作数据库
一、操作mysql
首先,python3操作mysql.需要安装第三方模块pymysql,在python2中则使用的是pysqldb。这里使用pymysql.
直接使用pip install pymysql或python3 setup.py install安装。
1.1连接mysql
import pymysql
#数据库连接信息
host='127.0.0.1'
user='db'
password='' #密码只能是字符串
db='db'
port=3306#端口号只能写int类型
charset='utf8'#只能写utf8,不能写utf-8
conn = pymysql.connect(host=host,password=psassword,
user=user,db=db,port=port,
charset=charset,autocommit=True
)#建立连接
#autocommit=True往数据库写数据时,需要commit下,这个参数表示自动提交。
cur=conn.cursor#创建游标
sql='select * from app_users limit 5;'
cur.execute(sql)#只是执行sql语句,并不返回执行sql的结果
print(cur.fetchall())#执行上述mysql语句,把结果放到cur,通过fetchall将执行sql后的结果取出来,默认返回的是二维元组
print(cur.description())#获取这个表里所有字段的属性信息
cur.close()#关闭游标
conn.close()#关闭连接
#创建游标,操作设置为字典类型,返回结果为字典格式!不写默认是元组格式!
cur=conn.cursor(cursor=pymysql.cursors.DictCursor)
#接收数据有三种方式:
res = cursor.fetchone() #接收返回的第一行数据
ret = cursor.fetchmany(n) #接收返回的前n行数据,数组格式
req = cursor.fetchall() #接收返回的所有数据,数组格式
#获取最新的自增ID
new_id=cursor.lastrowid
print(new_id)
conn.rollback()#回滚当前游标的所有操作
1.2创建数据库表
import pymysql
host='127.0.0.1'
user='jxz'
password='' #密码只能是字符串
db='jxz'
port=3306#端口号只能写int类型
charset='utf8'#只能写utf8,不能写utf-8
conn = pymysql.connect(host=host,password=password,
user=user,db=db,port=port,
charset=charset,autocommit=True
)#建立连接
#autocommit=True往数据库写数据时,需要commit下,这个表示自动提交。
cur= conn.cursor() #建立游标
sql='create table LYH (username char(20),age int,sex char(20))'
cur.execute(sql)
print(cur.fetchall())
cur.close()
conn.close()
1.3插入数据
import pymysql
host='127.0.0.1'
user='jxz'
password='' #密码只能是字符串
db='jxz'
port=3306#端口号只能写int类型
charset='utf8'#只能写utf8,不能写utf-8
conn = pymysql.connect(host=host,password=password,
user=user,db=db,port=port,
charset=charset,autocommit=True
)#建立连接
#autocommit=True往数据库写数据时,需要commit下,这个表示自动提交。 cur= conn.cursor() #建立游标
sql='insert into LYH (username,age,sex) VALUES ("liuyihan",18,"女")'
cur.execute(sql)
cur.close()
conn.close()
二、操作redis
redis是一种nosql数据库,是一种高性能的key-value数据库。其特点有以下三个:
- 数据可持久化地保存在磁盘中,重启时可再次加载使用
- value可存储string,list,set,hash等数据结构
- 支持master-slave数据备份
通过redis desktop manager连接工具,也操作redis数据库。具体方法如图:

通过python操作redis,首先安装redis模块。
import redis
import random
ip='127.0.0.1'
password='******'
r=redis.Redis(host=ip,password=password,port=6379,db=1)
#操作string类型的值
# res=r.get('liuyihan')
# print(res)
# s='ss'
# print(s.encode())#将字符串变成bytes类型,二进制类型
# print(res.decode())#将二进制类型转变成字符串类型
# r.flushdb()#清空所有表
# r.set('lyh','ftt',50)#50指定key50S后失效
# r.delete('gta')#删除指定的key
# r.setex('lyh','233',40)#40是指定value40S后失效
# token:lyh#冒号前的表示文件夹
r.set('message:lyh','excel,word')#冒号:前的是文件夹,冒号:后的是key,‘excel,word'是values
# print(r.keys())#获取数据库中的所有key,返回一个列表
#hash类型,二层字典
# token={'lyh':{'age':'18','firm':'DJ'}}
r.hset('Message','LYH',"Shenzen")
print(r.hget('jnz_stus','cm'))
# res=r.hgetall('jnz_stus')
# print(res)
# new={}
# for key,value in enumrate(res):
# new[key.decode()]=value.decode()
# print(new)
python之操作数据库的更多相关文章
- MySQL---连接器(python如何操作数据库媒介,基于python语言)
MySQL — 连接器 连接器的概念 它们往往是一类Python包,或者是一类已经写好的Python库.这些库提供了我们Python去连接数据库服务器的基本功能. 既然它是一个包,那么我们首先学会 ...
- Python:操作数据库
(一) 前言 本文说明如何连接Oracle.MySQL.sqlserver,以及执行sql.获取查询结果等. (二) DB-API DB-API阐明一系列所需对象和数据库 ...
- Python连接操作数据库
步骤: 1.创建与数据库的连接对象: 2.创建游标: 3.通过游标执行语句 4.增删改需要提交(commit)数据 5.关闭连接 如: import MySQLdb # Python通过MySQL ...
- python中操作数据库
python中要操作数据库,要使用该数据库在python中对应的驱动库,本文介绍python操作mysql数据库 1.首先安装pymysql 2.导入库 3.建立连接 4.建立游标 5.发起请求 6. ...
- python 连接操作数据库(二)
一.我们接着上期的博客继续对ORM框架进行补充,顺便把paramiko模块也给大家讲解一下: 1.ORM框架: 在连接操作数据库的第一个博客中也已经说了,sqlalchemy是一个ORM框架,总结就是 ...
- python 多线程操作数据库
如果使用多线程操作数据库,容易引起多用户操作锁表 OperationalError: (2013, 'Lost connection to MySQL server during query') 使用 ...
- python 连接操作数据库(一)
一.下面我们所说的就是连接mysql的应用: 1.其实在python中连接操作mysql的模块有多个,在这里我只给大家演示pymysql这一个模块(其实我是感觉它比较好用而已): pymysql是第三 ...
- python redis操作数据库方法
Redis redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorte ...
- Python——连接操作数据库
1.安装MySQL驱动程序.下载自动安装包,双击安装即可,非常简单. 2.连接MySQL,下面是Python示例代码. import MySQLdbconn=MySQLdb.connect(host= ...
随机推荐
- Android aar同步Failed to resolve: :nuisdk:
在app.gradle中android.dependencies同一级别下加入: repositories { flatDir { dirs 'libs' } }
- 白痴级教程,新手看过来,具详细实操文档 (word图片复制不过来,0202年了还有这样的不便利,下回研究一下,图片下次补)
一.环境配置(win10): 1.配置cmd的python环境为arcmap10.2 自带的python解释器(2.7.3)(自带arcpy库) 具体操作: 1我的电脑右击属性,打开 (选中path点 ...
- GaussDB数据dump实现完全同步
问题背景:搭建服务后端容灾集群,服务正常时容灾DB需要从业务DB完全同步数据,服务异常时,容灾DB停止抽取数据,自动从探针采集业务数据. 解决方案:常用的有两种思路,一是从服务后端定时每天拉取业务DB ...
- 视图家族之mixins视图工具类与generics工具视图类
视图家族之mixins视图工具类与generics工具视图类 一.mixins视图工具类 作用: 提供了几种后端视图(对数据资源进行曾删改查)处理流程的实现,如果需要编写的视图属于这五种,则视图可以通 ...
- 86.QuerySet API常用的方法详解:get方法
get方法的查询条件只能有一条数据满足,如果匹配到多条数据都满足,就会报错:如果没有匹配到满足条件的数据,也会报错. 示例代码如下: from django.http import HttpRespo ...
- vzray上网教程
1.首先按照之前的教程在chrome里安装插件-Proxy-SwitchyOmega-Chromium-2.5.15 2.打开 vzray-v3.11-windows-64,打开 3.在chrome ...
- nvm安装教程
nvm是一个nodejs的版本管理工具 默认安装位置 C:\Users\userName\AppData\Roaming\nvm x 1 C:\Users\userName\AppData\Ro ...
- 吴裕雄--天生自然TensorFlow2教程:Tensor数据类型
list: [1,1.2,'hello'] ,存储图片占用内存非常大 np.array,存成一个静态数组,但是numpy在深度学习之前就出现了,所以不适合深度学习 tf.Tensor,为了弥补nump ...
- Java 10按钮设计(awt)
/** * 2019年8月9日08:03:41 * 目的:利用Java设计10个按钮 * @author 张涛 * */ //导入awt包 import java.awt.*; import java ...
- Maven--Maven 安装最佳实践
1.设置 MAVEN_OPTS 环境变量 运行 mvn 命令实际上是执行了 Java 命令,既然是运行 Java,那么运行 Java 命令可用的参数当然也应该在运行 mvn 命令时使用.这个时候,MA ...