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("糖豆","喵喵")


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值