MySQL ddl语句的使用

MySQL中DDL语句是指用于定义数据库、表、列、索引等各种对象的语句,包括创建、删除、修改等操作。下面我们将从以下几个方面详细讲解MySQL DDL语句的使用。

创建数据库

创建数据库的语句如下所示:

CREATE DATABASE IF NOT EXISTS mydb;

其中,IF NOT EXISTS为可选参数,如果指定则表示只有当该数据库不存在时才会创建。

创建表

创建表的语法如下所示:

CREATE TABLE IF NOT EXISTS stu_info (
  id INT UNSIGNED AUTO_INCREMENT,
  name VARCHAR(20) NOT NULL,
  age TINYINT UNSIGNED NOT NULL,
  gender ENUM('男','女') NOT NULL,
  PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

该语句创建了一个名为stu_info的表,包含id、name、age、gender等列,其中id为主键。可选参数IF NOT EXISTS、ENGINE和DEFAULT CHARSET分别表示如果表已经存在则不再重新创建、使用InnoDB引擎存储,并采用utf8mb4字符集。

修改表

修改表的语法比较复杂,常见的修改操作包括增加列、修改列属性、删除列、重命名列等,示例如下:

--增加列
ALTER TABLE stu_info ADD COLUMN email VARCHAR(50) NOT NULL DEFAULT '';
--修改列属性
ALTER TABLE stu_info MODIFY COLUMN name VARCHAR(30) NOT NULL DEFAULT '';
--删除列
ALTER TABLE stu_info DROP COLUMN email;
--重命名列
ALTER TABLE stu_info CHANGE COLUMN gender sex ENUM('男','女','不详') NOT NULL;

删除表

删除表的语句如下所示:

DROP TABLE IF EXISTS stu_info;

其中,IF EXISTS为可选参数,如果指定则表示只有当表存在时才会删除。

创建索引

创建索引的语句如下所示:

CREATE INDEX idx_name ON stu_info (name);

其中,idx_name为索引名称,stu_info为表名,name为要创建索引的列名。

示例

下面我们通过一个示例来演示DDL语句的使用。假设我们要创建一个名为mydb的数据库,并在其中创建一个名为stu_info的表,表包含id、name、age、gender等列。我们可以通过以下代码来实现:

CREATE DATABASE IF NOT EXISTS mydb;
USE mydb;
CREATE TABLE IF NOT EXISTS stu_info (
  id INT UNSIGNED AUTO_INCREMENT,
  name VARCHAR(20) NOT NULL,
  age TINYINT UNSIGNED NOT NULL,
  gender ENUM('男','女') NOT NULL,
  PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;

假设我们要向stu_info表中增加email列并创建相应的索引。我们可以通过以下代码来实现:

ALTER TABLE stu_info ADD COLUMN email VARCHAR(50) NOT NULL DEFAULT '';
CREATE INDEX idx_email ON stu_info (email);

以上就是MySQL DDL语句的使用攻略。通过学习和掌握DDL语句,我们可以灵活地对数据库的结构进行管理,并有效提升数据库的性能和安全性。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:MySQL ddl语句的使用 - Python技术站

(0)
上一篇 2023年5月18日
下一篇 2023年5月18日

相关文章

  • 一文讲透 Redis 事务 (事务模式 VS Lua 脚本)

    准确的讲,Redis 事务包含两种模式 : 事务模式 和 Lua 脚本。 先说结论: Redis 的事务模式具备如下特点: 保证隔离性; 无法保证持久性; 具备了一定的原子性,但不支持回滚; 一致性的概念有分歧,假设在一致性的核心是约束的语意下,Redis 的事务可以保证一致性。 但 Lua 脚本更具备实用场景,它是另一种形式的事务,他具备一定的原子性,但脚…

    2023年4月10日
    00
  • AlaSQL 和 AnzoGraph 的区别

    AlaSQL和AnzoGraph是两种不同类型的数据库,它们的设计理念和技术架构有所不同。 AlaSQL是一种JavaScript数据库,它被设计用于在浏览器或Node.js上执行查询和数据操作。AlaSQL支持各种数据源,包括关系型数据库、CSV文件、JSON文件等等。此外,AlaSQL还具有非常灵活的查询功能,允许使用SQL语言或JavaScript A…

    database 2023年3月27日
    00
  • Linux中更改转移mysql数据库目录的步骤

    要在Linux中更改转移MySQL数据库目录,需要完成以下步骤: 停止MySQL服务:可以使用如下命令停止MySQL服务: sudo systemctl stop mysql 备份MySQL数据库:移动MySQL目录可能会导致数据丢失,因此在移动之前最好对其进行备份。可以使用如下命令备份MySQL数据库: sudo mysqldump -u root -p …

    database 2023年5月22日
    00
  • redis 解决key的乱码问题,并清理详解

    下面是关于如何解决Redis中键名乱码问题以及相应的清理方法的完整攻略。 1. 问题背景 在Redis中,键名可能会出现乱码的情况,这种情况一般是由于Redis服务器和客户端之间采用的不同字符集导致的。如果在Redis键名中包含有非ASCII字符(如中文),在某些情况下,这些字符会被转换为乱码。这样会导致我们无法通过键名查询到相应的键值,造成数据访问的问题。…

    database 2023年5月22日
    00
  • 一篇文章看懂MySQL主从复制与读写分离

    1. 什么是MySQL主从复制和读写分离? 在MySQL中,主从复制(Master-Slave Replication)和读写分离(Read-Write Separation)都是常见的数据库解决方案。主从复制是指将数据库的主库数据同步到从库中,从而实现主从数据库的数据一致性和备份,它可以提高数据库的可靠性和可用性;而读写分离则是将读请求和写请求分别分配到不…

    database 2023年5月22日
    00
  • 一条SQL语句查询多个数据库

    一条SQL语句查询多个数据库,通常可以通过在SQL语句中使用全路径表名或者跨库查询来实现。下面分别对这两种方式进行详细讲解。 全路径表名 全路径表名(Fully qualified table name)指的是表名中包含了数据库名称前缀的方式,这样可以通过一条SQL语句查询多个数据库的表。 语法格式 SELECT column_name(s) FROM da…

    database 2023年5月21日
    00
  • Oracle之SQL语句性能优化(34条优化方法)

    接下来我会详细解释“Oracle之SQL语句性能优化(34条优化方法)”的攻略。 一、 索引优化 使用WHERE子句过滤非匹配的记录。如果表中有很多行,但是你只需要其中的一部分时,使用WHERE子句来过滤非匹配的记录,这样可以大大提高查询速度。 为经常使用到的WHERE子句中的列建索引。索引是优化查询速度的一种方式,建立索引可以提高检索的速度,但是建立过多的…

    database 2023年5月21日
    00
  • Python实现Linux命令xxd -i功能

    实现Linux命令xxd -i功能,可以使用Python的binascii模块和os模块,具体实现步骤如下: 1.读取文件内容 使用os模块打开文件,按照二进制方式读取文件内容,并将其保存在一个bytes对象中。代码示例: import os with open(‘hello.txt’, ‘rb’) as f: content = f.read() 其中,h…

    database 2023年5月21日
    00
合作推广
合作推广
分享本页
返回顶部