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("增加字段成功")
相关推荐
rosmis5 分钟前
复杂工程拆解:自顶向下设计,自底向上实现
人工智能·python·机器人·自动化·自动驾驶·硬件工程·制造
njidf6 分钟前
Python上下文管理器(with语句)的原理与实践
jvm·数据库·python
郝学胜-神的一滴6 分钟前
深入理解Python生成器:从基础到斐波那契实战
开发语言·前端·python·程序人生
2301_7644413311 分钟前
python与Streamlit构建的旅游行业数据分析Dashboard项目
python·数据分析·旅游
人工智能AI技术15 分钟前
GitHub Trending榜首:Python Agentic RAG企业级落地指南
人工智能·python
喵手15 分钟前
Python爬虫实战:解构 CLI 工具命令参考文档树!
爬虫·python·爬虫实战·cli·零基础python爬虫教学·工具命令参考文档采集·数据采集实战
进击的雷神29 分钟前
多展会框架复用、Next.js结构统一、北非网络优化、参数差异化配置——阿尔及利亚展爬虫四大技术难关攻克纪实
javascript·网络·爬虫·python
ZTLJQ30 分钟前
网络通信的基石:Python HTTP请求库完全解析
开发语言·python·http
华科大胡子37 分钟前
爬虫对抗:ZLibrary反爬机制实战分析
python
进击的小头38 分钟前
第17篇:卡尔曼滤波器之概率论初步
python·算法·概率论