Python操作Mysql之基本操作

时间:2022-08-27 11:15:50

pymysql

python操作mysql依赖pymysql这个模块

下载安装

pip3 install pymysql

操作mysql

python操作mysql的时候,是通过”游标”来进行操作的。

1、创建链接

conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='123', db='t1')

分析:

  • host:表示链接的域名
  • port:链接的额端口
  • user:链接的数据库用户
  • passwd:数据库密码
  • db:要链接的表

2、创建游标

cursor = conn.cursor()

3、执行SQL,并返回影响的行数

effect_row = cursor.execute("mysql语句")

说明:

1、括号中接收的是纯mysql语句。

2、返回的你执行的sql语句在数据库中影响的行数

例子:

effect_row = cursor.execute("update hosts set host = '1.1.1.2'")

使用占位符:

 effect_row = cursor.execute("insert into tb1(nid,name,...) values(%s,%s,...)",(1,'haha',...))

使用占位符,同时支持多条数据增加:

  • execute改为executemany
  • 后面格式化数据的时候,使用列表的方式,里面每次的操作用元组的方式包裹,每项数据间用逗号”,”;隔开。
 effect_row = cursor.executemany("insert into tb1(nid,name)values(%s,%s)", [(1,'haha'),(2,'xxx')])

4、提交数据

conn.commit()

注意:

数据必须提交,不然无法被保存。

5、关闭游标

cursor.close()

6、关闭链接

conn.close()

操作mysql补充

当数据库表打开了自动递增,我们增加的数据可以不用填写编号,数据库为我们每次添加的数据添加一个id;二这个id我们在增加数据操作的时候,是可以获取的。

代码:

new_id = cursor.lastrowid

说明:

获取的代码要写在commit()后面,在关闭操作的前面。

问题:上面的操作是一条,获取的是对应的id,但是当增加的数据多条的时候,获取的结果?

当有多条数据的时候,获取的id是最后一条数据的

获取mysql数据

因为是获取数据,并不对数据进行改动,所以此时可以不用执行,commit()

1、获取单条数据

row_1 = cursor.fetchone()

2、获取所有的数据

row_3 = cursor.fetchall()

3、获取前n行数据

row_2 = cursor.fetchmany(3)

说明:

1、python获取数据的时候,也是通过游标来进行数据定位的。

2、这里的单条数据获取,和我们迭代器中的next很像。

特殊:

我们操作单数数据,操作一条数据,游标就会往后移一位,执行多条fetchone()的话,获取数据库的数据,是依次往下获取的。

执行取前n行数据的时候,比如:fetchmany(3)就相当于执行了3条fetchone()

注:在fetch数据时按照顺序进行,可以使用cursor.scroll(num,mode)来移动游标位置

    • cursor.scroll(1,mode='relative')  # 相对当前位置移动
    • cursor.scroll(1,mode=’absolute’)  # 相对绝对位置移动

4、fetch的数据类型

关于默认获取的数据是元祖类型,如果想要或者字典类型的数据,即

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import pymysql conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', passwd='123', db='t1') # 游标设置为字典类型,注意括号中的代码。
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
r = cursor.execute("call p1()") result = cursor.fetchone() cursor.close()
conn.close()

Python操作Mysql之基本操作的更多相关文章

  1. 06 python操作MySQL和redis(进阶)

    python操作mysql.redis 阶段一.mysql事务 主要用于处理操作量大,复杂度高的数据.比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息, ...

  2. 利用Python操作MySQL数据库

    前言 在工作中,我们需要经常对数据库进行操作,比如 Oracle.MySQL.SQL Sever 等,今天我们就学习如何利用Python来操作 MySQL 数据库. 本人环境:Python 3.7.0 ...

  3. Python(九) Python 操作 MySQL 之 pysql 与 SQLAchemy

    本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...

  4. 练习:python 操作Mysql 实现登录验证 用户权限管理

    python 操作Mysql 实现登录验证 用户权限管理

  5. Python操作MySQL

    本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...

  6. python成长之路【第十三篇】:Python操作MySQL之pymysql

    对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎 ...

  7. python操作mysql数据库的相关操作实例

    python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...

  8. Python 操作 MySQL 之 pysql 与 ORM(转载)

    本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...

  9. Python开发【第十九篇】:Python操作MySQL

    本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...

随机推荐

  1. mysql 内存相关文章

    简单计算:http://www.mysqlcalculator.com/ 相关文档:http://mingxinglai.com/cn/2016/04/mysql-memory-usage-formu ...

  2. Symfony2 学习笔记之插件格式

    一个bundle类似于其它框架中的插件,但是比插件表现更好.它跟其它框架最主要的不同是在Symfony2中所有东西都是bundle,包括核心框架功能和你写的所有应用程序代码.Symfony2中,bun ...

  3. cplusplus系列>algorithm>std::for_each

    http://www.cplusplus.com/reference/algorithm/for_each/ 对一个序列应用函数.可以是函数指针,或者是functor. // for_each exa ...

  4. SharePoint 2013 error The given assembly name or codebase System.ServiceModel.dll was invalid

    笔者近期在 SharePoint 2013 的环境中遇到一个奇怪的问题,前一天 SharePoint 2013 站点还是好好的.可是突然站点就报page can't display 500 错误: T ...

  5. Oracle SQL函数之聚组函数

    AVG([distinct|all]x) [功能]统计数据表选中行x列的平均值. [参数]all表示对所有的值求平均值,distinct只对不同的值求平均值,默认为all 如果有参数distinct或 ...

  6. c语言,enum

    在设置错误代号时,使用enum比宏更好看. #include <stdio.h> typedef enum { retOK = 0, errComInterruption = 0x1000 ...

  7. JS限制 获取动太ID,播放视频

    JS限制textarea字数 function textdown(e) {textevent = e ; ) { return; } ) { alert("大侠,我手机屏幕小,先输入这么多字 ...

  8. &lpar;10&rpar;集合之双列集合Map,HashMap,TreeMap

    Map中的元素是两个对象,一个对象作为键,一个对象作为值.键不可以重复,但是值可以重复. 看顶层共性方法找子类特有对象. Map与Collection在集合框架中属并列存在 Map存储的是键值对 Ma ...

  9. 2017noip普及组赛前注意事项总结

    petr 大神镇场 距人生第一场noip只差4天半了(好紧张) 总结几下四道题的做题策略 NO1 第一题一般是送分的,认真读题,别太草率,多想几遍再动手,把重要的地方圈一圈.画一画,自己找几个数据多试 ...

  10. windows下使用Play框架

         play类似于Spring这里的web框架.特点:MVC.函数编程. 版本:play 2.1.3 一.play命令 #play ~compile 功能:持续编译.在cmd中运行这个命令,只要 ...