详解Python的数据库操作(pymysql)
作者:东小东 发布时间:2024-01-15 20:49:22
标签:python,pymysql,数据库
使用原生SQL语句进行对数据库操作,可完成数据库表的建立和删除,及数据表内容的增删改查操作等。其可操作性很强,如可以直接使用“show databases”、“show tables”等语句进行表格之外的部分操作。
Centos7远程操作数据库时需要关闭防火墙,否则会连接不上
安装:
pip3 install pymysql
数据查询:
import pymysql
#建立数据库连接
conn=pymysql.connect(host="192.168.1.175",port=3306,user="root2",passwd="proot2",db="dongdb")
#得到数据库操作游标
cur=conn.cursor()
#查询数据
resdata=cur.execute("select * from tb_dong")
print("总条数为:",resdata)
#一行一行输出数据,以元组形式
print("取出第一条数据:",cur.fetchone())
print("取出第二条数据:",cur.fetchone()[3])
#输出剩下的所有数据,以元组嵌套形式
print("取出剩下的数据:",cur.fetchall())
print("------ 完成操作 -------")
#关闭连接
conn.close()
数据插入:
也可以使用 execute() 进行操作
import pymysql
#建立数据库连接
conn=pymysql.connect(host="192.168.1.175",port=3306,user="root2",passwd="proot2",db="dongdb")
#得到数据库操作游标
cur=conn.cursor()
#插入数据
datax=[
("DXD1","M","东小东1"),
("DXD2","F","东小东2")
]
#返回影响行数
rescoun=cur.executemany("insert into tb_dong(namex,sex,otherxxx) values(%s,%s,%s)",datax)
print(rescoun)
#进行数据修改,必须提交事物
conn.commit()
print("------ 完成操作 -------")
#关闭数据库连接
conn.close()
数据修改:
#返回影响行数,如果值未进行任何修改则返回0
rescoun=cur.execute("update tb_dong set namex='%s',sex='%s' where id>%d"%("dongdong","F",16))
print(rescoun)
#进行数据修改,必须提交事物
conn.commit()
数据删除:
#返回影响行数
rescoun=cur.execute("delete from tb_dong where id>%d"%(16))
conn.commit() #提交事物
部分封装:
import pymysql
#建立数据库连接
conn=pymysql.connect(host="192.168.1.175",port=3306,user="root2",passwd="proot2",db="dongdb")
#得到数据库操作游标
cur=conn.cursor()
#删除
def dongdel(tablex,idx):
try:
rescoun = cur.execute("delete from %s where id=%d" % (tablex,idx))
conn.commit() #提交事物
return rescoun
except Exception as e:
print("删除出现错误", e)
return e
#插入
def donginsert(tablex,listx):
try:
rescoun = cur.executemany("insert into "+tablex+"(namex,sex,otherxxx) values(%s,%s,%s)",listx)
conn.commit()
return rescoun
except Exception as e:
print("插入出现错误",e)
return e
#查询,参数为表名和id值
def dongselect(tablex,idx=0):
try:
if idx==0:
resdata = cur.execute("select * from %s"%tablex)
else:
resdata = cur.execute("select * from %s where id=%d" %(tablex,idx))
return resdata
except Exception as e:
print("查询出现错误",e)
return e
#修改
def dongupdate(tablex,idx,namex):
try:
rescoun = cur.execute("update %s set namex='%s' where id=%d" % (tablex,namex,idx))
conn.commit()
return rescoun
except Exception as e:
print("更新出现错误", e)
return e
#删除数据
resdel=dongdel("tb_dong",6)
print("删除的条数为:",resdel)
#插入数据
datax=[
("dongxiaodong","M","东小东1")
]
resinsert=donginsert("tb_dong",datax)
print("插入的条数为:",resinsert)
#修改数据
resupdate=dongupdate("tb_dong",7,"dongxiaodong7")
print("修改的条数为:",resupdate)
#查询数据
resselect=dongselect("tb_dong",0)
print("查询的总条数为:",resselect)
print("全部数据为:",cur.fetchall())
#关闭数据库连接
conn.close()
总结
以上所述是小编给大家介绍的详解Python的数据库操作(pymysql),希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
来源:104.116.116.112.58.47.47.119.119.119.46.99.110.98.108.111.103.115.46.99.111.109.47.100.111.110.103.120.105.97.111.100.111.110.103.47.112.47.49.48.52.57.53.53.55.51.46.104.116.109.108.


猜你喜欢
- 本文实例为大家分享了python绘制高斯曲线的具体代码,供大家参考,具体内容如下源码:import numpy as npimport ma
- 进行NodeJs开发时偶然发现的一个雷点正常情况下从JSON文件读取到字符后再通过JSON.parse没什么问题,只要格式不出错有时在确保J
- 本文实例讲述了Python获取任意xml节点值的方法。分享给大家供大家参考。具体实现方法如下:# -*- coding: utf-8 -*-
- 这篇文章主要介绍了通过Kettle自定义jar包供javascript使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参
- Redo LogREDO LOG称为重做日志 ,当MySQL服务器意外崩溃或者宕机后,保证已经提交的事务持久化到磁盘中(持久性)。InnoD
- Numpy支持大量的维度数组和矩阵运算,对数组运算提供了大量的数学函数库!Numpy比Python列表更具优势,其中一个优势便是速度。在对大
- 1. 项目背景视频传输: 在一台电脑上播放视频(捕捉摄像头画面),同局域网内另一台电脑上实时播放,尽量不卡顿。先放最后的照片,和用gif展示
- Flask是一个用Python编写的Web应用程序框架,Flask是python的web框架,最大的特征是轻便,让开发者自由灵活的兼容要开发
- Function content_Code(Str) dim ary_String,i,n,n_pos&nbs
- sql2000的服务器版本是8.0,sql2005是9.0首先要读安装必须配置(见后记)1.我是先装2000的,安装好后打上sp4补丁,(s
- 个人认为python的paramiko模块是运维人员必学模块之一,其ssh登录功能是旅行居家必备工具。安装paramiko很简单,pip i
- 我就废话不多说了,大家还是直接看代码吧!# 在setting设置外键'OPTIONS': { "in
- 前言可扩展标记语言,是一种简单的数据存储语言,XML被设计用来传输和存储数据存储,可用来存放配置文件,例:java配置文件传输,网络传输以这
- 这是我以前发表在经典论坛的帖子,现在转贴回来。仿淘宝网站的导航效果。此方法有几个优点:根据字数自适应项目长度不同的项目使用不同的颜色来区分无
- 本文实例为大家分享了python实现ftp文件传输的具体代码,供大家参考,具体内容如下主要步骤可以分为以下几步:1.读取文件名2.检测文件是
- 写文的原因学习 Python 的过程中,经常会使用 pip 命令去安装第三方模块,但细细琢磨下来,我真的掌握这款工具了吗?本文为你全面揭示一
- 目录前言redo log的产生redo log 的提交redo log 的落盘及通知通知用户线程总结前言最开始
- Windows 10 x64macOS Sierra 10.12.4Python 2.7准备好装哔~了么,来吧,做个真正意义上的绿色小软件W
- 概述介绍触发器,就是一种特殊的存储过程。触发器和存储过程一样是一个能够完成特定功能、存储在数据库服务器上的SQL片段,但是触发器无需调用,当
- 本文实例为大家分享了Vue.js框架实现购物车的具体代码,供大家参考,具体内容如下<!DOCTYPE html><html