安装:pip install pymysql

  基本操作

  1. import pymysql
  2. conn=pymysql.connect(host='localhost',user='root',password='',database='lary',charset='utf8') #链接
  3. cursor=conn.cursor() #执行完毕返回的结果集默认以元组显示 游标
  4. #cursor=conn.cursor(cursor=pymysql.cursors.DictCursor)
  5. sql='select * from userinfo where name=%s and password=%s '
  6. cursor.execute(sql,params) #执行sql语句,返回sql查询成功的记录数目
  7. #fetchone()/fetchmany()/fetchall() #针对查询语句
  8. #conn.commit() #针对增、删、改语句
  9. cursor.close()
  10. conn.close()

  pymysql操作数据库类

  1. #!/usr/bin/env python
  2. #coding:utf-8
  3.  
  4. import pymysql
  5. import config
  6.  
  7. class MysqlHelper():
  8. def __init__(self):
  9. self.conn = config.conn_dict
  10.  
  11. def get_one(self, sql, params):
  12. '''
  13. 查询并获取一条记录
  14. :param sql:
  15. :param params:
  16. :return:
  17. '''
  18. conn = pymysql.connect(**self.conn)
  19. cur = conn.cursor(cursor=pymysql.cursors.DictCursor)
  20. retCount = cur.execute(sql, params)
  21. data = cur.fetchone()
  22. cur.close()
  23. conn.close()
  24. return data
  25.  
  26. def get_many(self, sql, params):
  27. '''
  28. 查询并获取所有记录
  29. :param sql:
  30. :param params:
  31. :return:
  32. '''
  33. conn = pymysql.connect(**self.conn)
  34. cur = conn.cursor(cursor=pymysql.cursors.DictCursor)
  35. retCount = cur.execute(sql, params)
  36. data = cur.fetchall()
  37. cur.close()
  38. conn.close()
  39. return data
  40.  
  41. def insert_one(self, sql, params):
  42. '''
  43. 插入一条数据
  44. :param sql:
  45. :param params:
  46. :return:
  47. '''
  48. conn = pymysql.connect(**self.conn)
  49. cur = conn.cursor()
  50. cur.execute(sql, params)
  51. conn.commit()
  52. cur.close()
  53. conn.close()
  54. return 'insert success'
  55.  
  56. def insert_many(self,sql,params):
  57. '''
  58. 插入多条数据
  59. :param sql:
  60. :param params:
  61. :return:
  62. '''
  63. conn = pymysql.connect(**self.conn)
  64. cur = conn.cursor()
  65. cur.executemany(sql, params)
  66. conn.commit()
  67. cur.close()
  68. conn.close()
  69. return 'insert success'
  70.  
  71. def update_one(self,sql,params):
  72. '''
  73. 修改一条数据
  74. :param sql:
  75. :param params:
  76. :return:
  77. '''
  78. conn = pymysql.connect(**self.conn)
  79. cur = conn.cursor(cursor=pymysql.cursors.DictCursor)
  80. cur.execute(sql, params)
  81. conn.commit()
  82. cur.close()
  83. conn.close()
  84. return 'update success'
  85.  
  86. def delete_one(self,sql,params):
  87. '''
  88. 删除一条数据
  89. :param sql:
  90. :param params:
  91. :return:
  92. '''
  93. conn = pymysql.connect(**self.conn)
  94. cur = conn.cursor(cursor=pymysql.cursors.DictCursor)
  95. cur.execute(sql, params)
  96. conn.commit()
  97. cur.close()
  98. conn.close()
  99. return 'delete success'
  100.  
  101. pymysql操作数据库类

  config文件配置

  1. #!/usr/bin/env python
  2. #coding:utf-8
  3.  
  4. conn_dict=dict(host='127.0.0.1',user='root',passwd='',db='db1')

  获取插入的最后一条数据的自增ID

  1. import pymysql
  2. conn=pymysql.connect(host='localhost',user='root',password='',database='db1')
  3. cursor=conn.cursor()
  4.  
  5. sql='insert into userinfo(name,password) values("xxx","123");'
  6. rows=cursor.execute(sql)
  7. print(cursor.lastrowid) #在插入语句后查看
  8.  
  9. conn.commit()
  10.  
  11. cursor.close()
  12. conn.close()
  13.  
  14. 获取插入的最后一条数据的自增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. JavaSE 学习笔记之Java语法基础(二)

    1,关键字:其实就是某种语言赋予了特殊含义的单词. 保留字:其实就是还没有赋予特殊含义,但是准备日后要使用过的单词. 2,标示符:其实就是在程序中自定义的名词.比如类名,变量名,函数名.包含 0-9. ...

  2. java IO(BIO)、NIO、AIO

    IO 服务端ServerSocket 客户端Socket 缺点每次客户端建立连接都会另外启一个线程处理.读取和发送数据都是阻塞式的. 如果1000个客户端建立连接将会产生1000个线程 Server端 ...

  3. js 跨浏览器获取事件信息模块

    var EventUtil = { addHandler: function(element, type, handler) { if (element.addEventListener) { ele ...

  4. 洛谷 P1948 [USACO08JAN]电话线Telephone Lines

    P1948 [USACO08JAN]电话线Telephone Lines 题目描述 Farmer John wants to set up a telephone line at his farm. ...

  5. sublime text 插件emmet快捷命令

    原文链接:http://www.17yaobai.com/?p=255 语法: 后代:> 缩写:nav>ul>li <nav> <ul> <li> ...

  6. ReentrantLock公平锁与非公平锁lock()方法去竞争锁的不同点

  7. 关于Java特种兵下冊

    <Java特种兵 下冊>这本书一直没出.至上冊出版近1年以来,每周会有非常多小伙伴发私信或邮件问起我下冊出版的事情,纵使眼下有非常多无奈,小胖还是初步决定准备写下冊. 下冊内容(下冊的内容 ...

  8. CentOS 7通过yum安装fcitx五笔输入法

    CentOS 7通过yum安装fcitx五笔输入法 下面通过了亲測: 1.设置源 Posted in Linux at 三月 5th, 2015 / No Comments ? 增加EPEL源 EPE ...

  9. 第一个关于selenium项目

    1.创建一个简单的Python工程 在主菜单中,选择File | New Project ,并指定Python解释器版本 2.创建python类,快捷键alt+insert 3.编写打开浏览器的代码, ...

  10. ubuntu清华源【转】

    https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/ 可以选择ubuntu的版本更新源.