Windows 10家庭中文版,MySQL 5.7.20 for Win 64,Python 3.6.4,PyMySQL 0.8.1,2018-05-08

----

使用Python访问MySQL数据库,自己写包?当然可以,但已经有一些很好用的包可以使用了,在PYPI可以找到。

通过搜索“mysql”关键字,找到了1000+的推荐,可是,要选择哪些呢?怎么选?打开各个包的页面可以找到一些

参考标准。不过,在搜索页面的首页没有看到PyMySQL包,在Order by下拉列表框中选择Date last updated,此

时可以看到PyMySQL排在第9位。~~怎么说呢,通过PYPI来找需要的包挺麻烦的,除非你熟悉所有Python包。

怎么办?怎么高效地找到最合适的包呢?百度!通过百度,你可以知道“大家”都在使用什么包在做什么工作,然

后,再去PYPI找相应的包,再决定是否使用它。

我这里为什么会使用PyMySQL包呢?因为我看到教程(菜鸟)里面提到了它,打开PyMySQL的页面后,发现其热

度还挺高的,在GitHub上有3930颗星星,再看了一些其它PyMySQL博文,发现其挺适合自己使用的,于是,就选

它了。

PyMySQL的首页

本文使用的PyMySQL版本是0.8.1,它Python 2.7和3.4及更高版本,支持版本号大于5.5的MySQL和MariaDB。

----

安装PyMySQL

pip3 install pymysql

安装完毕后,可以使用pip3 list查看到PyMySQL包已经安装了。

编写PyMySQL程序

说明,在编程之前看完PyMySQL的相关教程会避免一些陷阱。

按照PyMySQL的首页给出的Example,编写一个程序读取自己的数据库表(上一篇博文中介绍的数据库earth下的表area)。

其实,就是抄抄抄,抄完还不是完全懂,然后还是要读PyMySQL的文档、资料。

主要开发、测试工具:IDLE、Notepad++

代码如下:

 import pymysql.cursors

 # Connect to the database
conn = pymysql.connect(host='localhost',
user='root',
password='',
db='earth',
charset='utf8mb4',
cursorclass=pymysql.cursors.DictCursor) print(conn.get_server_info()) print(conn.get_host_info()) try:
with conn.cursor() as cursor:
# Create a new record
sql = "INSERT INTO area (name_cn, parent_id, name_en) VALUES (%s, %s, %s)"
cursor.execute(sql, ('中国', , 'China')) # conn is not autocommit by default.
# so you must commit to save these changes.
conn.commit() with conn.cursor() as cursor:
# read a single record
sql = "SELECT id, parent_id, name_cn, name_en, create_t, update_t FROM area"
cursor.execute(sql)
result = cursor.fetchone()
print(result) with conn.cursor() as cursor:
# read all records
sql = 'select id,parent_id,name_cn,name_en from area'
cursor.execute(sql)
results = cursor.fetchall()
for row in results:
rid = row.get('id')
rpid = row.get('parent_id')
rcnn = row.get('name_cn')
renn = row.get('name_en') print("id = %d, pid = %d, name_cn = %s, name_en = %s" % \
(rid, rpid, rcnn, renn)) finally:
conn.close()

测试结果:

本代码执行了以下操作:

建立连接、获取数据库和主机信息、插入一条记录、读取一条记录、读取所有记录、关闭数据库连接。

注意1:

在插入数据时,sql语句中即便是要更换的数据类型是整数,其格式化字符串也必须上“%s”,否则,会出现错误。

因为这个问题,浪费了不少时间,最终查到一些网友也有同样的遭遇。

注意2:

使用IDLE编辑Python程序时,会出现很多错误,进而出现下面这些警告框并阻止程序执行:

此时,你在IDLE中看到的代码是完全没有问题的!你会很困惑!

怎么办?

使用其它工具(Notepad++、Eclipse)打开程序看看,此时你会发现程序的缩进等的确有问题,修改后再用IDLE打开,此时

问题就没有了,程序就可以正常运行了。

注意3:

获取查询到的一条记录里面的一个字段的数据无法使用row[1]得到,必须使用row.get(字段名),否则报错。

注意下图中左边的红框和右边的蓝框中的部分。

05-09更新:

上午看了参考链接1的文档,发现这个注意3出现的原因是,我在连接建立时使用了cursorclass=pymysql.cursors.DictCursor参数。

这会导致查询语句返回的结果是字典格式,而默认返回的是元组。

下图展示了取消参数后测试的结果:依次打印每一行

初次使用PyMySQL,请多关照,该好好看看它的文档了。

在其官方文档中,API Reference里面的两个对象Objects很重要:

参考链接:

1.https://www.cnblogs.com/wt11/p/6141225.html (博主推荐)

2.http://www.runoob.com/python3/python3-mysql.html

Python访问MySQL(1):初步使用PyMySQL包的更多相关文章

  1. python访问mysql和redis

    1. 修改mysql配置文件 修改bind-address=0.0.0.0(允许通过远程网络连接) 2. 修改redis配置文件 修改bind-address=0.0.0.0(允许通过远程网络连接), ...

  2. 利用Python访问Mysql数据库

    首先要明确一点,我们在Python中需要通过第三方库才能访问Mysql. 有这样几种方式:Mysql-python(即MySQLdb).pymysql.mysql-connector.Mysql-py ...

  3. python访问mysql

    1,下载mysql-connector-python-2.0.4  pythoin访问mysql需要有客户端,这个就是连接mysql的库 解压后如下图: 双击lib 以windows为例 把mysql ...

  4. Python访问MySQL数据库并实现其增删改查功能

    概述:对于访问MySQL数据库的操作,我想大家也都有一些了解.不过,因为最近在学习Python,以下就用Python来实现它.其中包括创建数据库和数据表.插入记录.删除记录.修改记录数据.查询数据.删 ...

  5. Python 42 mysql用户管理 、pymysql模块

    一:mysql用户管理 什么是mysql用户管理 mysql是一个tcp服务器,应用于操作服务器上的文件数据,接收用户端发送的指令,接收指令时需要考虑到安全问题, ATM购物车中的用户认证和mysql ...

  6. python访问mysql将返回的表转化为json

    ## Licensed to the Apache Software Foundation (ASF) under one or more# contributor license agreement ...

  7. Python访问MySQL数据库

    #encoding: utf-8 import mysql.connector __author__ = 'Administrator' config={'host':'127.0.0.1',#默认1 ...

  8. 【数据库】python访问mysql

    import MySQLdb 所有的数据库遵循相同的python database API 需要建立connection对象连接数据库,之后建立cursor对象处理数据. conn = MySQLdb ...

  9. fedora python访问mysql

    1 下载驱动库 http://sourceforge.net/projects/mysql-python/ 2, yum install mysql-dev* yum install python-d ...

随机推荐

  1. Mybatis笔记六:Mybatis中SqlSessionFactoryBuilder/SqlSessionFactory/SqlSession/映射器实例的作用域(Scope)和生命周期

    SqlSessionFactoryBuilder 这个类可以被实例化.使用和丢弃,一旦创建了 SqlSessionFactory,就不再需要它了.因此 SqlSessionFactoryBuilder ...

  2. 使用IDEA远程部署tomcat和调试

    环境: CentOS 7 Tomcat 9.0.1 jdk-9.0.1 IntelliJ IDEA 2017.3 Tomcat中的配置 在catalina.sh文件中加入以下的配置 CATALINA_ ...

  3. C#基础-代码部署数据库及IIS站点

    一.前言        最近忙里偷闲,做了一个部署数据库及IIS网站站点的WPF应用程序工具. 二.内容        此工具的目的是: 根据.sql文件在本机上部署数据库 在本机部署IIS站点,包括 ...

  4. Linux及安全实践四——ELF文件格式分析

    Linux及安全实践四——ELF文件格式分析 一.ELF文件格式概述 1. ELF:是一种对象文件的格式,用于定义不同类型的对象文件中都放了什么东西.以及都以什么样的格式去放这些东西. 二.分析一个E ...

  5. java堆溢出

    java堆是用来存储对象实例的:只要不断创建对象,GC Roots到对象之间有可达路径来避免垃圾回收机制清除这些对象,当对象数量达到最大堆的容量限制的时候就会产生内存溢出异常.异常对战信息为OutOf ...

  6. Java的容器类

    程序总是根据运行时才知道的某些条件去创建新对象.需要在任意时刻和任意位置创建任意数量的对象. 如果你想保存一组基本数据类型数据,建议使用数组,但是数组有固定的尺寸. 一般情况下,你在写程序时并不知道将 ...

  7. 解题: SDOI 2011 染色

    题面 强行把序列问题通过树剖套在树上...算了算是回顾了一下树剖的思想=.= 每次树上跳的时候注意跳的同时维护当前拼出来的左右两条链的靠上的端点,然后拼起来的时候讨论一下拼接点,最后一下左右两边的端点 ...

  8. fzyzojP3580 -- [校内训练-互测20180315]小基的高智商测试

    题目还有一个条件是,x>y的y只会出现一次(每个数直接大于它的只有一个) n<=5000 是[HNOI2015]实验比较 的加强版 g(i,j,k)其实可以递推:g(i,j,k)=g(i- ...

  9. Hadoop部署方式-本地模式(Local (Standalone) Mode)

    Hadoop部署方式-本地模式(Local (Standalone) Mode) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. Hadoop总共有三种运行方式.本地模式(Local ...

  10. day13 类的补充

    访问修饰符                          同包                          不同包 本类         子类         非子类        子类   ...