python链接数据库mysql

前提工作:

1、先在win10上安装好mysql,教程可以参考:

【精选】windows10上安装mysql(详细步骤)_win10安装mysql-CSDN博客

2、在PyCharm上安装对应的pymysql库:

可以用pip安装:python -m pip install pymysql

都进行好之后,直接上代码,只要链接成功,就可以随心所欲的操作数据库了:

python 复制代码
#引入库文件
import pymysql
#封装数据库链接的函数
def db_con(user='root',password='123456',host='localhost',port=3306,db='won105',charset='utf8'):
    #如果数据库服务器和Web服务器都运行在同一台机器上,则可以使用localhost作为服务器名称
    try:
        conn=pymysql.connect(user=user,password=password,host=host,port=port,db=db,charset=charset)
        cursor=conn.cursor()
        return conn,cursor
    except:
        print("链接异常")
        pass
#封装执行dml命令的函数
def exec_dml(conn,cursor,sqlstr):
    try:
        cursor.execute(sqlstr)
        conn.commit()
        return True
    except:
        conn.rollback()
        cursor.close()
        conn.close()
        return False
#封装执行DQL(select)命令函数,查找函数不会报错所以不需要try except
def exec_dql(conn,cursor,sqlstr):
    cursor.execute(sqlstr)
    rs=cursor.fetchall()#通过这个才能拿到数据
    return rs
#封装关闭数据库操作   关闭游标和链接
def closedb(conn,cursor):
    cursor.close()
    conn.close()

def regist_by_db():
    username=input('username>>')
    password=input('password>>')
    sqlstr=f'select username from game_users where username="{username}"'
    print(sqlstr)
    conn,cursor=db_con()
    rs=exec_dql(conn,cursor,sqlstr)
    if len(rs)>0:
        print('存在')
        return None
    else:
        sqlstr=f'insert into game_users(username,passwd) values("{username}","{password}")'
        if exec_dml(conn,cursor,sqlstr):
            print('插入成功')
            return True
        else:
            print('插入结果异常')
            return False

regist_by_db()

补充知识:

❁链接数据库:pymysql.connect()函数

con=pymysql.connect(user=None,password=None,host=None,db=None,port=None,charset=None)

♢user:数据库用户名

♢password:数据库用户密码

♢host:数据库服务器地址

♢db:要链接的database,如果需要新建database,则db=None

♢port:端口号

♢charset:字符集

❀数据库连接对象常用方法:

♢cursor():创建游标

☞游标对象常用方法

execute(sql):执行指定sql语句(执行成功要提交事务,执行失败要回滚事务,select语句

要有接受返回值的参数)

fetchone():从查询结果中获取一条记录

fetchmany(size=None):从查询结果中获取指定数量的记录

fetchall():从查询结果中获取所有记录

close():关闭游标

♢commit():提交事务

♢rollback():回滚事务

♢close():关闭数据库连接

相关推荐
q***718537 分钟前
开源数据同步中间件(Dbsyncer)简单玩一下 mysql to mysql 的增量,全量配置
mysql·中间件·开源
Wang's Blog1 小时前
MySQL: 基准测试全流程指南:原理、工具(mysqlslap/sysbench)与实战演示
数据库·mysql
q***06291 小时前
如何在 Windows 上安装 MySQL(保姆级教程2024版)
数据库·windows·mysql
百***06941 小时前
MySQL 创建新用户及授予权限的完整流程
数据库·mysql
全栈工程师修炼指南1 小时前
奇技淫巧 | 巧用阿里云免费 ESA:获取用户真实IP地址与地理位置
数据库·阿里云·云计算
碰大点2 小时前
数据库“Driver not loaded“错误,单例模式重构方案
数据库·sql·qt·单例模式·重构
武子康2 小时前
Java-173 Neo4j + Spring Boot 实战:从 Driver 到 Repository 的整合与踩坑
java·数据库·spring boot·后端·spring·nosql·neo4j
哥哥还在IT中2 小时前
深入理解MySQL事务隔离级别与锁机制(从ACID到MVCC的全面解析)
数据库·mysql
李慕婉学姐3 小时前
Springboot智慧旅游管理系统6w63eon8(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·旅游