pymysql执行DDL语句

pymysql对操作MySQL DDL数据库模式定义语言提供了很好的支持。

连接MySQL数据库后,可以使用cursor()方法创建一个游标对象。游标对象用于执行MySQL语句并返回结果。

基本用法

创建数据库、表:

复制代码
import pymysql

connection = None

try:
    # 建立数据库连接
    connection = pymysql.connect(
        host='localhost',
        user='root',
        password='root',
        database='test_db',
    )

    #游标对象
    cursor = connection.cursor()

    #创建数据库
    create_db_sql = "CREATE DATABASE IF NOT EXISTS mydatabase"
    cursor.execute(create_db_sql)
    print("数据库创建成功")

     # 选择数据库
    cursor.execute("USE mydatabase")

    # 创建表
    create_table_sql = """
         CREATE TABLE IF NOT EXISTS users (
             id INT AUTO_INCREMENT PRIMARY KEY,
             username VARCHAR(50) NOT NULL UNIQUE,
             email VARCHAR(100) NOT NULL,
             age INT,
             created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
             INDEX idx_username (username),
             INDEX idx_email (email)
         )
         """
    cursor.execute(create_table_sql)
    print("表创建成功")


except Exception as e:
    print(e)
finally:
    if connection:
        connection.close()

修改表结构:

复制代码
#向表中添加字段:alter table 表名 add [column] 字段名 字段类型:

alter table users add phone VARCHAR(20);

#删除表中的字段:alter table 表名 drop [column] 字段名:

alter table users drop phone;

#修改字段的名字:alter table 表名 change [column] 旧字段名 新字段名 字段类型:

alter table users change column username username2 varchar(20);

#修改字段的类型:alter table 表名 modify [column] 字段名 字段类型;

alter table users modify id varchar(20);

#修改表的名字:alter table 旧表名 rename to 新表名:
alter table users rename to users2;

增加字段代码示例:

复制代码
  #游标对象
    cursor = connection.cursor()

    alter_table_sql = """
           ALTER TABLE users 
           ADD COLUMN phone VARCHAR(20)
           """
    cursor.execute(alter_table_sql)
    print("增加字段成功")
相关推荐
用户8356290780515 小时前
Python 实现 PDF 文件加密与解密方法
后端·python
用户8356290780515 小时前
使用 Python 冻结与拆分 Excel 窗格教程
后端·python
你好潘先生13 小时前
别再记命令了,用 yeero do 说句人话就能跑脚本,而且不烧 token
服务器·python·命令行
Agent_大师13 小时前
WebSocket 行情重连成功,K线缺口不会自动消失
python
荣码13 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
copyer_xyf13 小时前
FastAPI 如何连接 MySQL
后端·python
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
用户8356290780511 天前
使用 Python 在 PDF 中创建与管理书签
后端·python
MeixianAgent1 天前
Python 回测数据入口怎么验?历史 K 线入库前先做 5 个检查
后端·python
咕白m6252 天前
用 Python 实现一键批量查找与替换 Excel 数据
后端·python