MySQL 之 pymysql
MySQL 之 pymysql
一、概述
pymysql是python用来连接mysql的工具,安装方式:pip install pymysql -i https://pypi.douban.com/simple
这里使用豆瓣的镜像安装,可能会快点
二、使用
pymysql内置非常多的方式来操作mysqlServer
1. 连接
首先还是剖其源码查看
def __init__(self, host=None, user=None, password="",
database=None, port=0, unix_socket=None,
charset='', sql_mode=None,
read_default_file=None, conv=None, use_unicode=None,
client_flag=0, cursorclass=Cursor, init_command=None,
connect_timeout=10, ssl=None, read_default_group=None,
compress=None, named_pipe=None,
autocommit=False, db=None, passwd=None, local_infile=False,
max_allowed_packet=16*1024*1024, defer_connect=False,
auth_plugin_map=None, read_timeout=None, write_timeout=None,
bind_address=None, binary_prefix=False, program_name=None,
server_public_key=None):
通常在项目中,数据库的连接的信息一般写在config.py文件中,然后调用即可
pysql.connect(host="", user="", password="", database="", charset="utf8md4")
以上connect的参数不必赘述
2. 执行SQL
先建一张表,用来测试数据
create database run default character set utf8mb4 collate utf8mb4_general_ci;
create table info(
id int primary key auto_increment,
name varchar(20) not null,
age int not null
)charset=utf8mb4;
创建一个配置文件,用来存放数据库的连接信息
'''
数据库连接信息
'''
HOST = "xxx.xxx.xxx.xxx"
USER = "root"
PASSWORD = "Asd.1234"
DATABASE = "run"
PORT = 3306
使用OOP思想来写基本框架
import pymysql
from config import HOST,USER, PASSWORD, DATABASE, PORT
class ConnectToMysql(object):
def __init__(self):
self.db = pymysql.connect(host=HOST, user=USER, password=PASSWORD, database=DATABASE, port=PORT)
self.cursor = self.db.cursor() # 执行完毕返回的结果集默认以元组显示
def insert_to_db(self):
'''
数据的插入操作
'''
pass
def query(self):
'''
数据的查询操作
'''
pass
def upate(self):
'''
数据的更新操作
'''
pass
def delete(self):
'''
数据的删除操作
'''
pass
def main(self):
pass
if __name__ == "__main__":
mysql = ConnectToMysql()
mysql.main()
一下的代码只展示需要填充的方法
以上代码中,cursor为游标,而在执行SQL语句使用
cursor.execute(SQL),当然,还有cusor.executemany(SQL)以执行多条SQL语句,其中的main函数需根据自身编写
2.1 插入数据
这里牵扯一个游标的问题,游标就是一个数据集合的指针,用来指向一条特定的数据行
通俗的讲,关系型数据库是面向集合的,在写sql 语句时,逻辑上也是面向集合的。而游标是面向行的,可以想象它是一个指针,逐行读取数据。
可以认为,通常的查询,就好像去提款机取款,例如,取1000,就是一次取1000;而游标是每次取100,取10次(假设100是最小单位)。
所以,通常游标是有“害” 的,会造成更多的I/O,消耗更多的资源,一般不建议使用游标。
存在即合理,有时候不得不使用游标,可能旧代码的写法,可能是业务复杂,而不得不使用游标;总之,它只是作为一种补充手段存在。
def insert_to_db(self):
'''
数据插入的操作:编写SQL、执行SQL、提交、关闭连接(当然,该实验中在最后关闭游标和连接)
'''
sql = "insert into info (name, age) values ('chancey', 18)"
self.cursor.execute(sql)
self.db.commit()
self.cursor.close()
self.db.close()
在插入数据之后必须提交才能将数据提交到数据库,现在查询一下数据库
mysql> select * from run.info;
+----+---------+-----+
| id | name | age |
+----+---------+-----+
| 1 | chancey | 18 |
+----+---------+-----+
1 row in set (0.00 sec)
执行多条SQL语句
def insert_to_db(self):
sql = "insert into info (name, age) values (%s, %s)"
data = [("waller", 21), ("mary", 25)]
self.cursor.executemany(sql, data)
self.db.commit()
self.cursor.close()
self.db.close()
查看数据库
mysql> select * from run.info;
+----+---------+-----+
| id | name | age |
+----+---------+-----+
| 1 | chancey | 18 |
| 2 | waller | 21 |
| 3 | mary | 25 |
+----+---------+-----+
3 rows in set (0.00 sec)
2.2 查询数据
同样的,执行SQL语句,但是在想要返回查询结果,则需要用fet函数来接收
- cursor.fetall() # 接收所有返回的查询结果
- cursor.fetone() # 接收第一条返回的查询结果
- cursor.fetmany() # 接收指定数量返回的查询结果,如果参数为空,则默认第一条
def query(self):
sql = "select name,age from info"
self.cursor.execute(sql)
info1 = self.cursor.fetchone() # 返回第一条结果
info2 = self.cursor.fetchmany(2) # 返回剩下结果的前两条
info3 = self.cursor.fetchall() # 返回剩下的所有结果
print(info1)
print(info2)
print(info3)
self.cursor.close()
self.db.close()
需要注意的是,第一次提取的数据在第二次提取的集合中是没有的,所以,提取结果的次数直接影响提取的结果
另外,该方法返回的是元组
2.3 更新数据
话不多说,直接代码
def upate(self):
sql = "update info set age=%s where name=%s"
self.cursor.execute(sql, [14, "waller"]) # 传多个参数需要用列表传参
self.db.commit()
self.cursor.close()
self.db.close()
查询一下数据库
mysql> select * from run.info;
+----+---------+-----+
| id | name | age |
+----+---------+-----+
| 1 | chancey | 18 |
| 2 | waller | 14 |
| 3 | mary | 25 |
+----+---------+-----+
3 rows in set (0.00 sec)
2.4 删除数据
def delete(self):
sql = "delete from info where name=%s"
self.cursor.execute(sql, "waller")
self.db.commit()
self.cursor.close()
self.db.close()
查询数据库
mysql> select * from run.info;
+----+---------+-----+
| id | name | age |
+----+---------+-----+
| 1 | chancey | 18 |
| 3 | mary | 25 |
+----+---------+-----+
2 rows in set (0.00 sec)
MySQL 之 pymysql的更多相关文章
- Python中操作mysql的pymysql模块详解
Python中操作mysql的pymysql模块详解 前言 pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x而后者不支持 ...
- MySQL之pymysql模块
MySQL之pymysql模块 import pymysql #s链接数据库 conn = pymysql.connect( host = '127.0.0.1', #被连接数据库的ip地址 po ...
- 第二百七十九节,MySQL数据库-pymysql模块操作数据库
MySQL数据库-pymysql模块操作数据库 pymysql模块是python操作数据库的一个模块 connect()创建数据库链接,参数是连接数据库需要的连接参数使用方式: 模块名称.connec ...
- Python3操作MySQL基于PyMySQL封装的类
Python3操作MySQL基于PyMySQL封装的类 在未使用操作数据库的框架开发项目的时候,我们需要自己处理数据库连接问题,今天在做一个Python的演示项目,写一个操作MySQL数据库的类, ...
- python成长之路【第十三篇】:Python操作MySQL之pymysql
对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎 ...
- mysql、pymysql、SQLAlchemy
1.MySQL介绍 http://www.cnblogs.com/wupeiqi/articles/5699254.html,基础操作参见此文章,此处不赘述. 安装:yum install mysql ...
- python操作mysql之pymysql
pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同.但目前pymysql支持python3.x而后者不支持3.x版本. 本文测试python版本:2.7.11.mys ...
- Python操作MySQL -即pymysql/SQLAlchemy用法
本节介绍Python对于MySQL的一些操作用法 模块1:pymysql(等同于MySQLdb) 说明:pymysql与MySQLdb模块的使用基本相同,学会pymysql,使用MySQLdb也就不是 ...
- Python自动化运维之18、Python操作 MySQL、pymysql、SQLAchemy
一.MySQL 1.概述 什么是数据库 ? 答:数据的仓库,和Excel表中的行和列是差不多的,只是有各种约束和不同数据类型的表格 什么是 MySQL.Oracle.SQLite.Access.MS ...
随机推荐
- 自定义SWT控件五之自定义穿梭框
5.自定义穿梭框 package com.view.control.shuttlebox; import java.util.ArrayList; import java.util.HashMap; ...
- tab选项卡代码
$('.case_header ul li').click(function(){ $(this).addClass('active').siblings().removeClass('active' ...
- Hadoop 系列(二)—— 集群资源管理器 YARN
一.hadoop yarn 简介 Apache YARN (Yet Another Resource Negotiator) 是 hadoop 2.0 引入的集群资源管理系统.用户可以将各种服务框架部 ...
- macOS 安装配置yaf框架 生成yaf项目
macOS 安装配置yaf框架 Yaf只支持PHP5.2及以上的版本. 并支持最新的PHP5.3.3 Yaf需要SPL的支持. SPL在PHP5中是默认启用的扩展模块 Yaf需要PCRE的支持. PC ...
- Dialog 使用详解
极力推荐文章:欢迎收藏 Android 干货分享 阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android 本篇文章主要介绍 Android 开发中的部分知识点,通过阅读本篇文章,您将收获以 ...
- 完全零基础在Linux中安装 JDK
完全零基础在Linux中安装 JDK 总体思路:先确定没有Java程序了 — 然后创建相应路径文件夹 — 下载JDK — 解压到当前路径 — 自定义文件名称 — 配置环境变量 — 检查是否安装成功 第 ...
- PythonDay05
第五章 今日内容 字典 字典 语法:{'key1':1,'key2':2} 注意:dict保存的数据不是按照我们添加进去的顺序保存的. 是按照hash表的顺序保存的. ⽽hash表 不是连续的. 所以 ...
- WPF中ComboBox控件绑定键值对操作
WPF中下拉框将键值对作为其数据源的具体操作.本实例以枚举类型以及枚举特性描述字符串生成键值对来进行. namespace ViewC { /// <summary> /// View.x ...
- 从输入URL到浏览器显示页面发生了哪些事情---个人理解
经典面试题:从输入URL到页面显示发生了哪些事情 以前一直都记不住,这次自己理解了一下 用自己的话总结了一次,不对的地方希望大佬给我指出来 1.主机通过DHCP协议获取客户端的IP地址.子网掩码和DN ...
- 《机器学习技法》---线性SVM
(本文内容和图片来自林轩田老师<机器学习技法>) 1. 线性SVM的推导 1.1 形象理解为什么要使用间隔最大化 容忍更多的测量误差,更加的robust.间隔越大,噪声容忍度越大: 1.2 ...