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("增加字段成功")
相关推荐
invicinble18 小时前
对于后端要和linux打交道要掌握的点
linux·运维·python
喵手18 小时前
Python爬虫零基础入门【第三章:Requests 静态爬取入门·第4节】列表页→详情页:两段式采集(90%项目都这样)!
爬虫·python·python爬虫实战·python爬虫工程化实战·python爬虫零基础入门·requests静态爬取·两段式采集
zzZ··*18 小时前
自动登录上海大学校园
python·网络协议·selenium
weisian15118 小时前
进阶篇-4-数学篇-3--深度解析AI中的向量概念:从生活到代码,一文吃透核心逻辑
人工智能·python·生活·向量
写代码的【黑咖啡】18 小时前
Python中的Msgpack:高效二进制序列化库
开发语言·python
MistaCloud18 小时前
Pytorch进阶训练技巧(二)之梯度层面的优化策略
人工智能·pytorch·python·深度学习
AIFQuant18 小时前
2026 全球股市实时行情数据 API 对比指南
python·websocket·金融·数据分析·restful
爱吃肉的鹏18 小时前
使用Flask在本地调用树莓派摄像头
人工智能·后端·python·flask·树莓派
2501_9445264218 小时前
Flutter for OpenHarmony 万能游戏库App实战 - 主题切换实现
android·开发语言·javascript·python·flutter·游戏·django
深蓝电商API18 小时前
Selenium处理iframe嵌套页面实战
爬虫·python·selenium