MySQL_pymysql模块
安装:pip install pymysql
基本操作
import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='lary',charset='utf8') #链接
cursor=conn.cursor() #执行完毕返回的结果集默认以元组显示 游标
#cursor=conn.cursor(cursor=pymysql.cursors.DictCursor)
sql='select * from userinfo where name=%s and password=%s '
cursor.execute(sql,params) #执行sql语句,返回sql查询成功的记录数目
#fetchone()/fetchmany()/fetchall() #针对查询语句
#conn.commit() #针对增、删、改语句
cursor.close()
conn.close()
pymysql操作数据库类
#!/usr/bin/env python
#coding:utf-8 import pymysql
import config class MysqlHelper():
def __init__(self):
self.conn = config.conn_dict def get_one(self, sql, params):
'''
查询并获取一条记录
:param sql:
:param params:
:return:
'''
conn = pymysql.connect(**self.conn)
cur = conn.cursor(cursor=pymysql.cursors.DictCursor)
retCount = cur.execute(sql, params)
data = cur.fetchone()
cur.close()
conn.close()
return data def get_many(self, sql, params):
'''
查询并获取所有记录
:param sql:
:param params:
:return:
'''
conn = pymysql.connect(**self.conn)
cur = conn.cursor(cursor=pymysql.cursors.DictCursor)
retCount = cur.execute(sql, params)
data = cur.fetchall()
cur.close()
conn.close()
return data def insert_one(self, sql, params):
'''
插入一条数据
:param sql:
:param params:
:return:
'''
conn = pymysql.connect(**self.conn)
cur = conn.cursor()
cur.execute(sql, params)
conn.commit()
cur.close()
conn.close()
return 'insert success' def insert_many(self,sql,params):
'''
插入多条数据
:param sql:
:param params:
:return:
'''
conn = pymysql.connect(**self.conn)
cur = conn.cursor()
cur.executemany(sql, params)
conn.commit()
cur.close()
conn.close()
return 'insert success' def update_one(self,sql,params):
'''
修改一条数据
:param sql:
:param params:
:return:
'''
conn = pymysql.connect(**self.conn)
cur = conn.cursor(cursor=pymysql.cursors.DictCursor)
cur.execute(sql, params)
conn.commit()
cur.close()
conn.close()
return 'update success' def delete_one(self,sql,params):
'''
删除一条数据
:param sql:
:param params:
:return:
'''
conn = pymysql.connect(**self.conn)
cur = conn.cursor(cursor=pymysql.cursors.DictCursor)
cur.execute(sql, params)
conn.commit()
cur.close()
conn.close()
return 'delete success' pymysql操作数据库类
config文件配置
#!/usr/bin/env python
#coding:utf-8 conn_dict=dict(host='127.0.0.1',user='root',passwd='',db='db1')
获取插入的最后一条数据的自增ID
import pymysql
conn=pymysql.connect(host='localhost',user='root',password='',database='db1')
cursor=conn.cursor() sql='insert into userinfo(name,password) values("xxx","123");'
rows=cursor.execute(sql)
print(cursor.lastrowid) #在插入语句后查看 conn.commit() cursor.close()
conn.close() 获取插入的最后一条数据的自增ID
MySQL_pymysql模块的更多相关文章
- npm 私有模块的管理使用
你可以使用 NPM 命令行工具来管理你在 NPM 仓库的私有模块代码,这使得在项目中使用公共模块变的更加方便. 开始前的工作 你需要一个 2.7.0 以上版本的 npm ,并且需要有一个可以登陆 np ...
- node.js学习(三)简单的node程序&&模块简单使用&&commonJS规范&&深入理解模块原理
一.一个简单的node程序 1.新建一个txt文件 2.修改后缀 修改之后会弹出这个,点击"是" 3.运行test.js 源文件 使用node.js运行之后的. 如果该路径下没有该 ...
- ES6模块import细节
写在前面,目前浏览器对ES6的import支持还不是很好,需要用bable转译. ES6引入外部模块分两种情况: 1.导入外部的变量或函数等: import {firstName, lastName, ...
- Python标准模块--ContextManager
1 模块简介 在数年前,Python 2.5 加入了一个非常特殊的关键字,就是with.with语句允许开发者创建上下文管理器.什么是上下文管理器?上下文管理器就是允许你可以自动地开始和结束一些事情. ...
- Python标准模块--Unicode
1 模块简介 Python 3中最大的变化之一就是删除了Unicode类型.在Python 2中,有str类型和unicode类型,例如, Python 2.7.6 (default, Oct 26 ...
- Python标准模块--Iterators和Generators
1 模块简介 当你开始使用Python编程时,你或许已经使用了iterators(迭代器)和generators(生成器),你当时可能并没有意识到.在本篇博文中,我们将会学习迭代器和生成器是什么.当然 ...
- 自己实现一个javascript事件模块
nodejs中的事件模块 nodejs中有一个events模块,用来给别的函数对象提供绑定事件.触发事件的能力.这个别的函数的对象,我把它叫做事件宿主对象(非权威叫法),其原理是把宿主函数的原型链指向 ...
- 理解nodejs模块的scope
描述 原文档地址:https://docs.npmjs.com/misc/scope 所有npm模块都有name,有的模块的name还有scope.scope的命名规则和name差不多,同样不能有ur ...
- nodejs模块发布及命令行程序开发
前置技能 npm工具为nodejs提供了一个模块和管理程序模块依赖的机制,当我们希望把模块贡献出去给他人使用时,可以把我们的程序发布到npm提供的公共仓库中,为了方便模块的管理,npm规定要使用一个叫 ...
随机推荐
- 将项目上传到Github之使用git命令上传
1,先从GitHub网页上建立一个数据仓库 2,安装git 下载地址:https://www.git-scm.com/download/win 3,找到本地要上传的项目目录,右键点击Git Bash ...
- fzu 2087并查集的运用求最小生成树的等效边
//对数组排序后,对于边相同并且边的两端不在一个集合内的一定是等效边或者必加边, //第一数数,第二合并集合 #include<stdio.h> #include<stdlib.h& ...
- JS代码引用位置问题-转
看到很多JS代码全部放在head中的情况,其实这是个细节问题.转载一个知乎用户于江水的答案: 作者:于江水链接:https://www.zhihu.com/question/34147508/answ ...
- 基于DPI(深度报文解析)的应用识别2------实际分析
新浪微博的分析 早上刚刚起床先刷微博,打算就分析一下新浪微博.登陆之后抓取公布微博的数据包.进行分析. 1.抓包的要点: 1.关闭其它网络应用,保证本机网络流量的干净,便于分析. 2.先开启wires ...
- Centos6.2中配置tomcat
这里我使用的是tomcat6, 我使用的是server版本号的Centos, 前提是安装而且配置好了JDK. 首先通过samba把我的tomcat压缩包, 复制到了共享的文件夹.然后移动到./usr文 ...
- Hibernate单表操作(一)——单一主键
assigned由java应用程序负责生成.(手工赋值) native由底层数据库自己主动生成标识符,假设是MySQL就是increment,假设是oracle就是sequence.等等.
- Mybatis结合Spring注解自己主动扫描源代码分析
作为一个想做架构师的程序猿,必须是一个优秀的程序猿.在引入某一个框架的时候,必需要研究源代码,将新的开源框架的风险变为可控性. 1.Spring结合Mybatis最经常使用的配置. <!--理论 ...
- SQLServer 多点及时备份技巧
为了保证数据库的安全性,我们都会规划数据库的容灾策略,包含本地备份.异地备份.raid.或者使用高可用性(如 日志传送.镜像.复制等)进行异地容灾.因为 SqlServer 数据库的备份仅仅有一个备份 ...
- Linux命令(九)——系统监视和进程控制
与windows系统一样,linux系统中也有很多进程在同时运行,每个进程都有一个识别码PID,它是进程的唯一识别标志. 一.进程的类型 1.系统进程 在操作系统启动后,系统环境平台运行所加载的进程, ...
- oracel表的分区
1,创建表及分区 create table test ( ID VARCHAR2(32), MONTHS VARCHAR2(40), USERID VARCHAR2(20) ) partition b ...