安装: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模块的更多相关文章

  1. npm 私有模块的管理使用

    你可以使用 NPM 命令行工具来管理你在 NPM 仓库的私有模块代码,这使得在项目中使用公共模块变的更加方便. 开始前的工作 你需要一个 2.7.0 以上版本的 npm ,并且需要有一个可以登陆 np ...

  2. node.js学习(三)简单的node程序&&模块简单使用&&commonJS规范&&深入理解模块原理

    一.一个简单的node程序 1.新建一个txt文件 2.修改后缀 修改之后会弹出这个,点击"是" 3.运行test.js 源文件 使用node.js运行之后的. 如果该路径下没有该 ...

  3. ES6模块import细节

    写在前面,目前浏览器对ES6的import支持还不是很好,需要用bable转译. ES6引入外部模块分两种情况: 1.导入外部的变量或函数等: import {firstName, lastName, ...

  4. Python标准模块--ContextManager

    1 模块简介 在数年前,Python 2.5 加入了一个非常特殊的关键字,就是with.with语句允许开发者创建上下文管理器.什么是上下文管理器?上下文管理器就是允许你可以自动地开始和结束一些事情. ...

  5. Python标准模块--Unicode

    1 模块简介 Python 3中最大的变化之一就是删除了Unicode类型.在Python 2中,有str类型和unicode类型,例如, Python 2.7.6 (default, Oct 26 ...

  6. Python标准模块--Iterators和Generators

    1 模块简介 当你开始使用Python编程时,你或许已经使用了iterators(迭代器)和generators(生成器),你当时可能并没有意识到.在本篇博文中,我们将会学习迭代器和生成器是什么.当然 ...

  7. 自己实现一个javascript事件模块

    nodejs中的事件模块 nodejs中有一个events模块,用来给别的函数对象提供绑定事件.触发事件的能力.这个别的函数的对象,我把它叫做事件宿主对象(非权威叫法),其原理是把宿主函数的原型链指向 ...

  8. 理解nodejs模块的scope

    描述 原文档地址:https://docs.npmjs.com/misc/scope 所有npm模块都有name,有的模块的name还有scope.scope的命名规则和name差不多,同样不能有ur ...

  9. nodejs模块发布及命令行程序开发

    前置技能 npm工具为nodejs提供了一个模块和管理程序模块依赖的机制,当我们希望把模块贡献出去给他人使用时,可以把我们的程序发布到npm提供的公共仓库中,为了方便模块的管理,npm规定要使用一个叫 ...

随机推荐

  1. 36.分页及deep paging

    主要知识点 1.es分页 2.deep paging     一.es分页语法 size,from 这两个关键字 GET /_search?size=10 指定每页10条数据 GET /_search ...

  2. jQuery cxCalendar 日期选择器

    简介 cxCalendar 是基于 jQuery 的日期选择器插件. 它灵活自由,你可以自定义外观,日期的范围,返回的格式等. 版本: jQuery v1.7+ jQuery cxCalendar v ...

  3. 重新学习html和css

    当初学习前端的时候,属于快速入门那种,没有好好深入学习html和css.如今,在空闲时间重新拿起基础书学习,都会写到一些新的知识. 1.css实现圆角.渐变功能.使用border-radius以及li ...

  4. python第十周:进程、协程、IO多路复用

    多进程(multiprocessing): 多进程的使用 multiprocessing是一个使用类似于线程模块的API支持产生进程的包. 多处理包提供本地和远程并发,通过使用子进程而不是线程有效地侧 ...

  5. Sperner定理及其证明

    额,最近看到了一个十分有趣的定理--Sperner定理.其实这个定理在OI中没什么用处,因此我都没把这篇文章放到我的OI标签里(不知道在MO中是否有用?)但是觉得它很有趣于是就过来写一下. 由于博主太 ...

  6. Spring Cloud-Ribbon实现客户端的服务均衡(三)

    客户端负载均衡与服务端负载均衡 服务端负载均衡 通过服务端负载均衡设备维护的服务清单根据算法(轮训 权重负载 流量负载)取出服务地址 进行转发 客户端负载 将指定服务的服务清单订单(注册中心)下来 在 ...

  7. 洛谷 P2412 查单词

    P2412 查单词 题目背景 滚粗了的HansBug在收拾旧英语书,然而他发现了什么奇妙的东西. 题目描述 udp2.T3如果遇到相同的字符串,输出后面的 蒟蒻HansBug在一本英语书里面找到了一个 ...

  8. java反射并不是什么高深技术,面向对象语言都有这个功能,而且功能也很简单,就是利用jvm动态加载时生成的class对象

    java反射并不是什么高深技术,面向对象语言都有这个功能. 面向对象语言都有这个功能,而且功能也很简单,就是利用jvm动态加载时生成的class对象,去获取类相关的信息 2.利用java反射可以调用类 ...

  9. RubyMine快捷键

    RubyMine快捷键 ctrl+shift+up/down 向上/向下移动代码段 alt+shift+up/down 向上/向下移动代码行 ctrl+y 删除一行 ctrl+shift+f10 运行 ...

  10. Item 8:析构函数不要抛出异常 Effective C++笔记

    Item 8: Prevent exceptions from leaving destructors. 析构函数不要抛出异常 因为析构函数经常被自己主动调用,在析构函数中抛出的异常往往会难以捕获,引 ...