文档章节

python操作mysql

weidedong
 weidedong
发布于 2016/12/12 18:47
字数 819
阅读 31
收藏 0
点赞 0
评论 0

1.安装pymysql

pip install PyMySQL

2.开启记录log,在mysqlserver的my_cnf中添加如下

general_log=1
general_log_file=/tmp/log_sql_query.log   #此处要指定目录有可写权限,如果指定目录无可写权限,则会写入失败

重启mysql服务

systemctl restart mysqld

3.创建表

create database test  #创建test库
CREATE TABLE `users` (   #创建users表
    `id` int(11) NOT NULL AUTO_INCREMENT,
    `email` varchar(255) COLLATE utf8_bin NOT NULL,
    `password` varchar(255) COLLATE utf8_bin NOT NULL,
    PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
AUTO_INCREMENT=1 ;

4.CRUD代码如下

#!/usr/bin/env python
# -*- encoding:utf-8 -*-
import pymysql.cursors

# Connect to the database
connection = pymysql.connect(host='192.168.152.137',
                             user='root',
                             password='MyNewPass4!',
                             db='test',
                             charset='utf8mb4',
                             cursorclass=pymysql.cursors.DictCursor)

try:
    # 插入4条数据
    with connection.cursor() as cursor:
        # Create a new record
        sql = "INSERT INTO `users` (`email`, `password`) VALUES (%s, %s)"
        cursor.execute(sql, ('webmaster@python.org', u'中华人民共和国'))

        sql = "INSERT INTO `users` (`email`, `password`) VALUES (%s, %s)"
        cursor.execute(sql, ('webmaster@python.org', 'Owen is a good man!'))

        sql = "INSERT INTO `users` (`email`, `password`) VALUES (%s, %s)"
        cursor.execute(sql, ('webmaster@python.org', u'丽江,大丽,我想要去的地方'))

        sql = "INSERT INTO `users` (`email`, `password`) VALUES (%s, %s)"
        cursor.execute(sql, ('webmaster@python.org', u'Hello,World!'))

        connection.commit()

    # 打印出所有添加的数据
    with connection.cursor() as cursor:
        sql = "select id,password from users"
        cursor.execute(sql)
        result = cursor.fetchall()
        print result

    # 更新所有数据都为Hello
    with connection.cursor() as cursor:
        sql = "update users set password = %s;"
        cursor.execute(sql, ('Hello',))
        connection.commit()

    # 打印出所有更新的数据
    with connection.cursor() as cursor:
        sql = "select id,password from users"
        cursor.execute(sql)
        result = cursor.fetchall()
        print result

    # 删除id=1的数据
    with connection.cursor() as cursor:
        sql = "delete from users where id = %s"
        cursor.execute(sql, (1,))
        connection.commit()

    # 打印出所有更新的数据
    with connection.cursor() as cursor:
        sql = "select count(1) from users"
        cursor.execute(sql)
        result = cursor.fetchone()
        print result
finally:
    connection.close()

5.控制台输出信息

[{u'password': u'\u4e2d\u534e\u4eba\u6c11\u5171\u548c\u56fd', u'id': 1}, {u'password': u'Owen is a good man!', u'id': 2}, {u'password': u'\u4e3d\u6c5f\uff0c\u5927\u4e3d\uff0c\u6211\u60f3\u8981\u53bb\u7684\u5730\u65b9', u'id': 3}, {u'password': u'Hello,World!', u'id': 4}]
[{u'password': u'Hello', u'id': 1}, {u'password': u'Hello', u'id': 2}, {u'password': u'Hello', u'id': 3}, {u'password': u'Hello', u'id': 4}]
{u'count(1)': 3}

6.查看我们执行的sql

cat /tmp/log_sql_query.log # 查看sql log
2016-12-09T13:17:50.161104Z         2 Statistics
2016-12-09T13:18:23.192378Z         2 Query     #general_logselect @@global.general_log

use test
2016-12-09T13:18:23.219917Z         2 Query     CREATE TABLE `users` (   #创建users表
    `id` int(11) NOT NULL AUTO_INCREMENT,
    `email` varchar(255) COLLATE utf8_bin NOT NULL,
    `password` varchar(255) COLLATE utf8_bin NOT NULL,
    PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
AUTO_INCREMENT=1
2016-12-09T13:18:27.916975Z         2 Query     SHOW DATABASES
2016-12-09T13:18:28.965329Z         2 Query     SELECT `DEFAULT_COLLATION_NAME` FROM `information_schema`.`SCHEMATA` WHERE `SCHEMA_NAME`='test'
2016-12-09T13:18:28.977337Z         2 Query     SHOW TABLE STATUS FROM `test`
2016-12-09T13:18:28.989998Z         2 Query     SHOW FUNCTION STATUS WHERE `Db`='test'
2016-12-09T13:18:29.008819Z         2 Query     SHOW PROCEDURE STATUS WHERE `Db`='test'
2016-12-09T13:18:29.024187Z         2 Query     SHOW TRIGGERS FROM `test`
2016-12-09T13:18:29.037922Z         2 Query     SELECT *, EVENT_SCHEMA AS `Db`, EVENT_NAME AS `Name` FROM information_schema.`EVENTS` WHERE `EVENT_SCHEMA`='test'
2016-12-09T13:18:43.282916Z         5 Connect   root@192.168.152.1 on test using TCP/IP
2016-12-09T13:18:43.283691Z         5 Query     SET AUTOCOMMIT = 0
2016-12-09T13:18:43.285891Z         5 Query     INSERT INTO `users` (`email`, `password`) VALUES ('webmaster@python.org', '中华人民共和国')
2016-12-09T13:18:43.287053Z         5 Query     INSERT INTO `users` (`email`, `password`) VALUES ('webmaster@python.org', 'Owen is a good man!')
2016-12-09T13:18:43.288674Z         5 Query     INSERT INTO `users` (`email`, `password`) VALUES ('webmaster@python.org', '丽江,大丽,我想要去的地方')
2016-12-09T13:18:43.289810Z         5 Query     INSERT INTO `users` (`email`, `password`) VALUES ('webmaster@python.org', 'Hello,World!')
2016-12-09T13:18:43.291124Z         5 Query     COMMIT
2016-12-09T13:18:43.294547Z         5 Query     select id,password from users
2016-12-09T13:18:43.297104Z         5 Query     update users set password = 'Hello'
2016-12-09T13:18:43.298150Z         5 Query     COMMIT
2016-12-09T13:18:43.300400Z         5 Query     select id,password from users
2016-12-09T13:18:43.302220Z         5 Query     delete from users where id = 1
2016-12-09T13:18:43.303092Z         5 Query     COMMIT
2016-12-09T13:18:43.306127Z         5 Query     select count(1) from users
2016-12-09T13:18:43.307315Z         5 Quit

© 著作权归作者所有

共有 人打赏支持
weidedong
粉丝 1
博文 40
码字总数 18744
作品 0
深圳

暂无相关文章

Spring | IOC AOP 注解 简单使用

写在前面的话 很久没更新笔记了,有人会抱怨:小冯啊,你是不是在偷懒啊,没有学习了。老哥,真的冤枉:我觉得我自己很菜,还在努力学习呢,正在学习Vue.js做管理系统呢。即便这样,我还是不...

Wenyi_Feng ⋅ 今天 ⋅ 0

博客迁移到 https://www.jianshu.com/u/aa501451a235

博客迁移到 https://www.jianshu.com/u/aa501451a235 本博客不再更新

为为02 ⋅ 今天 ⋅ 0

win10怎么彻底关闭自动更新

win10自带的更新每天都很多,每一次下载都要占用大量网络,而且安装要等得时间也蛮久的。 工具/原料 Win10 方法/步骤 单击左下角开始菜单点击设置图标进入设置界面 在设置窗口中输入“服务”...

阿K1225 ⋅ 今天 ⋅ 0

Elasticsearch 6.3.0 SQL功能使用案例分享

The best elasticsearch highlevel java rest api-----bboss Elasticsearch 6.3.0 官方新推出的SQL检索插件非常不错,本文一个实际案例来介绍其使用方法。 1.代码中的sql检索 @Testpu...

bboss ⋅ 今天 ⋅ 0

informix数据库在linux中的安装以及用java/c/c++访问

一、安装前准备 安装JDK(略) 到IBM官网上下载informix软件:iif.12.10.FC9DE.linux-x86_64.tar放在某个大家都可以访问的目录比如:/mypkg,并解压到该目录下。 我也放到了百度云和天翼云上...

wangxuwei ⋅ 今天 ⋅ 0

PHP语言系统ZBLOG或许无法重现月光博客的闪耀历史[图]

最近在写博客,希望通过自己努力打造一个优秀的教育类主题博客,名动江湖,但是问题来了,现在写博客还有前途吗?面对强大的自媒体站点围剿,还有信心和可能型吗? 至于程序部分,我选择了P...

原创小博客 ⋅ 今天 ⋅ 0

IntelliJ IDEA 2018.1新特性

工欲善其事必先利其器,如果有一款IDE可以让你更高效地专注于开发以及源码阅读,为什么不试一试? 本文转载自:netty技术内幕 3月27日,jetbrains正式发布期待已久的IntelliJ IDEA 2018.1,再...

Romane ⋅ 今天 ⋅ 0

浅谈设计模式之工厂模式

工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。 在工厂模式中,我们在创建对象时不会对客户端暴露创建逻...

佛系程序猿灬 ⋅ 今天 ⋅ 0

Dockerfile基础命令总结

FROM 指定使用的基础base image FROM scratch # 制作base image ,不使用任何基础imageFROM centos # 使用base imageFROM ubuntu:14.04 尽量使用官方的base image,为了安全 LABEL 描述作...

ExtreU ⋅ 昨天 ⋅ 0

存储,对比私有云和公有云的不同

导读 说起公共存储,很难不与后网络公司时代的选择性外包联系起来,但尽管如此,它还是具备着简单和固有的可用性。公共存储的名字听起来也缺乏专有性,很像是把东西直接堆放在那里而不会得到...

问题终结者 ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部