Python连接MYSQL数据库的两种方式

1.常规连接 :pymysql,pandas

import pymysql as mysql
import pandas as pd
con = mysql.connect(host="数据库地址",port=端口号,user="用户名",passwd="密码",db="数据库名称",charset="utf8mb4")
mycursor = con.cursor()
print("连接成功")

# 查询
sql = "select * from 数据库表名 where 字段名=xx and .."
result = pd.read_sql(sql,con=con)
print(result)
#删除
sql = "delete from 数据库表名"
mycursor.execute(sql)
print("删除数据长度:",mycursor.rowcount)
con.commit()

2.导入sqlalchemy

from sqlalchemy import create_engine
from urllib.parse import quote_plus as urlquote
pymysql.install_as_MySQLdb()

conn = create_engine('mysql+mysqldb://root:/密码@数据库地址:端口号/数据库名称?charset=utf8')
#插入数据
data.to_sql(name=数据库表名, con=conn, if_exists='append', index=False)  # append增加

2.1 当遇到数据库密码包含“@”字符时(查了很多博客)

userName = "用户名"
password ="@123456"
dbHost =" 数据库地址"
dbPort = 端口号
dbName = "数据库名称"
DB_CONNECT = f'mysql+pymysql://{userName}:{urlquote(password)}@{dbHost}:{dbPort}/{dbName}?charset=utf8'

conn = create_engine(DB_CONNECT,max_overflow=50,  # 超过连接池大小外最多创建的连接
        pool_size=50,  # 连接池大小
        pool_timeout=60,  # 池中没有线程最多等待的时间,否则报错
        pool_recycle=3600,  # 多久之后对线程池中的线程进行一次连接的回收(重置)
        encoding='utf-8',
        echo=False,
        pool_pre_ping=True
    )
  • 1
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值