Python之操作MySQL数据库
一、操作步骤
1、导入pymysql模块
2、建立连接(ip、用户名、密码、数据库名、端口号、字符集、(自动提交参数))
3、建立游标
4、执行sql语句
(4、需要提交的提交)
5、关闭游标
6、关闭连接
import pymysql host='xxx.xxx.xxx.xxx'
user='abc'
password='' #密码只能是字符串
db='database_name'
port=3306 #端口号只能写int类型
charset='utf8' #只能写utf8,不能写utf-8 #建立连接
conn=pymysql.connect(host=host,password=password,user=user,db=db,
port=port,charset=charset) #建立游标
cur=conn.cursor() res=cur.execute('show tables;') #只是帮你执行sql语句,不会返回执行结果
#print(res) #结果为执行语句的指针序列号
print(cur.fetchall()) #获取数据库里面的所有表,返回的是一个二维数组,一个大数组,里面是每个表 #关闭游标
cur.close() #关闭连接
conn.close()
二、执行sql语句
1)cur.execute('sql语句')
cur.execute('select * from app_myuser limit 5;') #获取一张表中的所有信息
print(cur.fetchall())
2)insert、update、delete都需要在.execute()之后执行提交后才可以将数据写入数据库
(1)conn.commit()
sql='insert into app_mysuer(username,passwd,is_admin) values("lrx","123456",1)'
cur.execute(sql) #这样执行完数据库中无数据
#insert、update、delete都需要在.execute()之后执行.commit()才可以将数据写入数据库
conn.commit() #提交
(2)将提交参数直接写在连接语句中,可以自动提交
autocommit=True
#建立连接
conn=pymysql.connect(host=host,password=password,user=user,db=db,
port=port,charset=charset,autocommit=True)
#conn.commit() #加入自动提交参数后就不需要再执行单独提交语句了
3)获取表里的所有字段的信息
res=cur.execute('select *from app_myuser ;')#不执行这条的话,cur.description打印的结果为None
print(cur.description) #获取表里的所有字段的信息
#结果为:
#(('id', 3, None, 11, 11, 0, False), ('username', 253, None, 32, 32, 0, False), ('passwd', 253, None, 32, 32, 0, False), ('is_admin', 2, None, 6, 6, 0, False))
4)获取表结构信息
sql2='describe app_myuser'
res=cur.execute(sql2)
print(cur.fetchall())
#结果为:
#(('id', 'int(11)', 'NO', 'PRI', None, 'auto_increment'), ('username', 'varchar(32)','NO', 'UNI', None, ''), ('passwd', 'varchar(32)', 'NO', '', None, ''), ('is_admin','smallint(6)', 'NO', '', None, ''))
三、返回sql语句执行结果
- print(cur.fetchall())
- print(cur.fetchone())
print(cur.fetchall())
print(cur.fetchone()) #返回结果为空,因为上面已经执行到最后了,游标到尾了,类似于文件指针 #先注释掉.fetchall()再运行即可
print(cur.fetchone()) #每次取一行数据
.fetchall()和.fetchone()的区别:
- 在不知道一共多少条的情况下,只能使用.fetchall()
- .fetchall()返回的是二维数组,取字段时不方便
- .fetchone()返回的是一维数组,当结果只有一条时,使用.fetchone()比较方便
四、具体实现
1、传入任意数据库信息,执行sql语句并返回结果:
#传入sql语句,返回sql执行结果
def my_db(ip,user,password,db,sql,port=3306,charset='utf8'):
conn=pymysql.connect(
host=ip,user=user,password=password,db=db,port=port,
charset=charset,autocommit=True) #连接数据库,自动提交sql
cur=conn.cursor() #建立游标
cur.execute(sql) #执行sql语句
res=cur.fetchall() #返回sql执行结果
cur.close() #关闭游标
conn.close() #关闭连接
return res #返回执行结果
2、使用固定数据库,执行sql语句并返回结果:
def my_db2(sql):
conn=pymysql.connect(
host='xxx.xxx.xxx.xxx',user='abc',password='',db='dbname',port=3306,
charset='utf8',autocommit=True)
cur=conn.cursor()
cur.execute(sql)
res=cur.fetchall()
cur.close()
conn.close()
return res
Python之操作MySQL数据库的更多相关文章
- python 之操作mysql 数据库实例
对于python操作mysql 数据库,具体的步骤应为: 1. 连接上mysql host 端口号 数据库 账号 密码2. 建立游标3. 执行sql(注意,如果是update,insert,delet ...
- Python之 操作 MySQL 数据库
什么是MySQLdb? MySQLdb 是用于Python链接Mysql数据库的接口,它实现了 Python 数据库 API 规范 V2.0,基于 MySQL C API 上建立的. 安装 Pytho ...
- python实现操作mysql数据库
实现代码如下: #mysql数据库的查询等 import pymysql from xctest_tools.xc_ReadFile.get_ReadTxt import * class mysql: ...
- python 安装操作 MySQL 数据库.
以ubuntu和mysql为例 检查自己的机器上面有没有安装数据库 xpower@xpower-CW65S:~$ sudo service mysql start [sudo] xpower 的密码: ...
- python 连接操作mysql数据库
开发数据库程序流程: 1.创建connection对象,获取cursor 2.使用cursor执行SQL 3.使用cursor获取数据.判断执行状态 4.提交事务 或者 回滚事务 import: 数据 ...
- python,java操作mysql数据库,数据引擎设置为myisam时能够插入数据,转为innodb时无法插入数据
今天想给数据库换一个数据引擎,mysiam转为 innodb 结果 python 插入数据时失败,但是自增id值是存在的, 换回mysiam后,又可以插入了~~ 想换php插入试试,结果php数据引擎 ...
- python 3 操作mysql数据库的方法
参考:http://www.cnblogs.com/txw1958/archive/2012/07/22/python3-mysql.html http://www.jb51.net/article/ ...
- python接口自动化(三十八)-python操作mysql数据库(详解)
简介 现在的招聘要求对QA人员的要求越来越高,测试的一些基础知识就不必说了,来说测试知识以外的,会不会一门或者多门开发与语言,能不能读懂代码,会不会Linux,会不会搭建测试系统,会不会常用的数据库, ...
- Python操作MySQL数据库(步骤教程)
我们经常需要将大量数据保存起来以备后续使用,数据库是一个很好的解决方案.在众多数据库中,MySQL数据库算是入门比较简单.语法比较简单,同时也比较实用的一个.在这篇博客中,将以MySQL数据库为例,介 ...
随机推荐
- 操作系统常用调度算法(转载https://www.cnblogs.com/kxdblog/p/4798401.html)
操作系统常用调度算法 在操作系统中存在多种调度算法,其中有的调度算法适用于作业调度,有的调度算法适用于进程调度,有的调度算法两者都适用.下面介绍几种常用的调度算法. 先来先服务(FCFS)调度算法 ...
- Linux 小知识翻译 - 「/proc 文件夹」
这次聊聊 「/proc 文件夹」. /proc 文件夹用来保管系统状态相关的文件的特殊文件夹,这个文件夹中有的文件只是内存上的虚拟文件. /proc 文件夹下有些文件可以反映各个进程的运行状态.所以说 ...
- CSS 简介、 选择器、组合选择器
#CSS 装饰器引入<!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...
- 常用Dockerfile举例
FROM ubuntu:14.04 MAINTAINER sss ENV JAVA_HOME /opt/jdk RUN \ echo 'export PATH=$JAVA_HOME/bin:$PATH ...
- 如何给30台centos7服务器分别增加相同的用户
老大直接给了30台新鲜的生产服务器,要给每一台服务器增加一个用户,密码相同 难道我们要部署一个工具吗?这样对生产环境可能会产生影响,为了保证服务器的新鲜以及节约时间,研究了小半天,终于研究出一个不是很 ...
- (二 -3-3) 天猫精灵接入Home Assistant-自动发现Mqtt设备-自动生成配置信息
http://www.hassmart.com/products/switches/#tab=config switch: - platform: mqtt name: keting state_to ...
- 输出1-100 , 奇数偶数分别添加标识(for循环语句嵌套if-else语句)
package com.summer.cn; /** * @author Summer * 输出1-100 , 奇数偶数分别添加标识 */ public class Test041518 { publ ...
- echart自定义浮窗 增加点击事件
一:情景 做一个柱状图,需要在柱状图显示lable,并且浮窗上每个条目可以被点击或者跳转. 我使用的做图插件是echarts,但是echart的浮窗是图片,而且不可以被点击,不能识别html,而且这个 ...
- 洛谷 P2404 自然数的拆分问题
题目链接 https://www.luogu.org/problemnew/show/P2404 题目背景 木有...... 题目描述 任何一个大于1的自然数n,总可以拆分成若干个小于n的自然数之和. ...
- router-link 绑定事件的方式
实现方法如下 使用.native 实现原生事件 <router-link to="" @click.native="dialogWithdraw=true&quo ...