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("增加字段成功")
相关推荐
m0_51452057几秒前
CSS如何解决Less与CSS兼容性问题_通过配置文件实现平滑过渡与混合开发
jvm·数据库·python
HHHHH1010HHHHH7 分钟前
JavaScript中利用IIFE创建私有命名空间的经典方案
jvm·数据库·python
干洋芋果果12 分钟前
前端学python
开发语言·前端·python
YJlio13 分钟前
1 1.2 Windows 账户的分类:管理员 / 标准 / 来宾 + 微软账户 vs 本地账户
人工智能·python·microsoft·ai·chatgpt·openai·agent
篮子里的玫瑰21 分钟前
Python与网络爬虫——列表与元组
开发语言·爬虫·python
knight_9___25 分钟前
RAG面试篇8
人工智能·python·面试·agent·rag
2301_7965885026 分钟前
Go语言如何压缩文件_Go语言gzip压缩教程【基础】
jvm·数据库·python
m0_6178814228 分钟前
c++如何通过重定向rdbuf来捕获第三方库的日志输出到文件【详解】
jvm·数据库·python
Greyson137 分钟前
mysql查询执行过程中如何追踪耗时_使用PROFILE分析指令周期
jvm·数据库·python
Anesthesia丶40 分钟前
Qwen2.5-1.5b 模型部署与LORA训练笔记
pytorch·python·lora·llm·qwen·vllm