当前位置: 首页 > news >正文

python---数据库操作

在python中,使用第三方库pymysql来执行数据库操作

命令行窗口输入 :pip install pymysql,下载第三方库

数据库查询操作

Python查询Mysql使用 fetchone() 方法获取单条数据, 使用fetchall() 方法获取多条数据。

  • fetchone(): 该方法获取下一个结果行
  • fetchall():接收全部的返回结果行,
  • rowcount: 这是一个只读属性,并返回执行execute()方法后影响的行数。
#1、从第三方库 导入数据库连接
from pymysql import Connection

#2、连接数据库
con=Connection(
    host="localhost",  #主机地址
    port=3306,         #端口号 mysql的默认端口3306
    user="root",        #用户名
    password="1234" #密码
)

#3、选择数据库
con.select_db("products")

#4、获取游标对象
cursion=con.cursor()

#5、通过游标对象操作数据库
sql="select * from user"
rowcount=cursion.execute(sql) #执行sql语句
print("受到影响的条数",{rowcount})
result=cursion.fetchone() #查询单条数据
print(result)

#6、关闭数据库
con.close()


#1、从第三方库 导入数据库连接
from pymysql import Connection

#2、连接数据库
con=Connection(
    host="localhost",  #主机地址
    port=3306,         #端口号 mysql的默认端口3306
    user="root",        #用户名
    password="1234" #密码
)

#3、选择数据库
con.select_db("products")

#4、获取游标对象
cursion=con.cursor()

#5、通过游标对象操作数据库
sql="select * from user"
rowcount=cursion.execute(sql) #执行sql语句
print("受到影响的条数",{rowcount})

result=cursion.fetchall() #查询所有数据
for x in  result:
    print(x)

#6、关闭数据库
con.close()

 数据库插入操作

pymysql默认要手动提交修改,需要自己提交

在Python数据库编程中,当游标建立之时,就自动开始了一个隐形的数据库事务。

commit()方法游标的所有更新操作,rollback()方法回滚当前游标的所有操作。


#1、从第三方库 导入数据库连接
from pymysql import Connection

#2、连接数据库
con=Connection(
    host="localhost",  #主机地址
    port=3306,         #端口号 mysql的默认端口3306
    user="root",        #用户名
    password="1234" #密码
)

#3、选择数据库
con.select_db("products")

#4、获取游标对象
cursor=con.cursor()

#5、通过游标对象操作数据库
sql="insert user values(%s,%s)" % ("'汪汪'","'123'")   #传入内容是字符串 需要携带引号 
print(sql)
try:
   # 执行sql语句
   cursor.execute(sql)
   # 提交到数据库执行
   con.commit()
except:
   # 发生错误时回滚
   con.rollback()

rowcount=cursor.execute(sql) #执行sql语句
print("受到影响的条数",{rowcount})
#6、关闭数据库
con.close()


除了手动提交之外,还可以在创建连接时直接说明自动提交

con=Connection(
    host="localhost",  #主机地址
    port=3306,         #端口号 mysql的默认端口3306
    user="root",        #用户名
    password="1234", #密码
    autocommit=True #设置自动提交
)

动态传参

使用占位符来占位,动态填入参数


from pymysql import Connection
class A:
    age=0
#1、从第三方库 导入数据库连接
    def a(self,name,age):
      # 2、连接数据库
      con = Connection(
          host="localhost",  # 主机地址
          port=3306,  # 端口号 mysql的默认端口3306
          user="root",  # 用户名
          password="1234",  # 密码
          autocommit=True  # 设置自动提交
      )
      # 3、选择数据库
      con.select_db("products")
      # 4、获取游标对象
      cursor = con.cursor()
      #5、通过游标对象操作数据库
      sql = "insert user values('%s','%s')" % (name,age)  # 传入内容是字符串 需要携带引号
      print(sql)
      try:
          # 执行sql语句
          cursor.execute(sql)
          # 提交到数据库执行
          con.commit()
      except:
          # 发生错误时回滚
          con.rollback()
      rowcount = cursor.execute(sql)  # 执行sql语句
      print("受到影响的条数", {rowcount})
      # 6、关闭数据库
      con.close()

A().a("糖豆","喵喵")


相关文章:

  • 膜结构行业做网站/免费建网站软件哪个好
  • 北京网站建设优选平台/网站推广沈阳
  • 网站维护建设需要什么花费/独立站seo建站系统
  • salient wordpress 下载/短视频营销常用平台有
  • 网站代码优化的内容有哪些/百度一下你就知道首页
  • 潍坊专业网站建设哪家好/百度一下网址是多少
  • 面试题题review
  • Android studio配置大内存,编译速度更快!
  • 20-Mysql内核查询优化规则详解
  • 训练yolo系列+deepsort模式的跟踪器(一):训练deepsort
  • Shape详解
  • 修改主机名和ip地址之后需重新reconfigure GI
  • 开源项目-OA自动化管理系统
  • spring-boot如何自行写一个starter并且使用
  • 轻松入门基因表达式编程 (GEP)
  • SpringBoot任务调度(官方案例)
  • 408 考研《操作系统》第三章第一节:内存
  • matlab 功率谱分析