SQL中常见的DDL操作及示例,数据库操作及表操作

目录

一、数据库操作

1、创建数据库

2、查看所有数据库

3、使用数据库

4、删除数据库

二、表操作:

1、创建表

2、查看表结构

3、修改表结构

[3.1 添加列](#3.1 添加列)

[3.2 修改列数据类型](#3.2 修改列数据类型)

[3.3 修改列名](#3.3 修改列名)

[3.4 删除列](#3.4 删除列)

[3.5 修改表名](#3.5 修改表名)

[3.6 删除表](#3.6 删除表)

注意:


在数据库中,DDL(Data Definition Language,数据定义语言)主要用于定义或改变表结构、数据类型、表之间的链接和约束等初始化工作。

以下是DDL的一些常用操作及示例:

一、数据库操作

1、创建数据库

sql 复制代码
CREATE DATABASE 数据库名;

示例:创建一个名为mydb的数据库:

sql 复制代码
CREATE DATABASE mydb;

如果需要创建数据库时指定字符集,可以这样做:

sql 复制代码
CREATE DATABASE mydb CHARACTER SET utf8;

2、查看所有数据库

sql 复制代码
SHOW DATABASES;

3、使用数据库

sql 复制代码
USE 数据库名;

示例:使用上面创建的mydb数据库:

sql 复制代码
USE mydb;

4、删除数据库

sql 复制代码
DROP DATABASE 数据库名;

示例:删除mydb数据库

sql 复制代码
DROP DATABASE mydb;

二、表操作:

1、创建表

sql 复制代码
CREATE TABLE 表名 (  
    列名1 数据类型1,  
    列名2 数据类型2,  
    ...  
);

示例:创建一个名为students的表,包含idnameage字段

sql 复制代码
CREATE TABLE students (  
    id INT PRIMARY KEY,  
    name VARCHAR(50),  
    age INT  
);

2、查看表结构

sql 复制代码
DESC 表名;

示例:查看students表的结构

sql 复制代码
DESC students;

3、修改表结构

3.1 添加列

sql 复制代码
ALTER TABLE 表名 ADD 列名 数据类型;

示例:添加列 爱好(hobbies)

sql 复制代码
ALTER TABLE students ADD hobbies varchar(50);

3.2 修改列数据类型

sql 复制代码
ALTER TABLE 表名 MODIFY 列名 新数据类型;

示例:修改 爱好(hobbies)长度为100

sql 复制代码
ALTER TABLE students MODIFY hobbies varchar(100);

3.3 修改列名

sql 复制代码
ALTER TABLE 表名 CHANGE 旧列名 新列名 数据类型;

示例:修改列名 hobbies 为 love,且长度改为100

sql 复制代码
ALTER TABLE students CHANGE hobbies love varchar(255);

3.4 删除列

sql 复制代码
ALTER TABLE 表名 DROP COLUMN 列名;

示例: 删除列 hobbies

sql 复制代码
ALTER TABLE students DROP COLUMN hobbies;

3.5 修改表名

sql 复制代码
ALTER TABLE 旧表名 RENAME TO 新表名;

示例:修改表students 为 student

sql 复制代码
ALTER TABLE students RENAME TO student;

3.6 删除表

sql 复制代码
DROP TABLE 表名;

示例:删除表 student

sql 复制代码
DROP TABLE student;

注意:

DDL操作是直接对数据库结构进行操作的,因此在执行这些操作时应该特别小心(特别是线上环境),以免对数据库造成不可逆的损害。在实际应用中,建议在执行DDL操作前备份数据库,并先在测试环境中进行测试,确认无误后在操作。

相关推荐
星星点点洲23 分钟前
【缓存与数据库结合最终方案】伪从技术
数据库·缓存
小黑屋的黑小子25 分钟前
【MySQL】MySQL索引与事务
数据库·mysql·oracle
OK_boom3 小时前
Dapper的数据库操作备忘
数据库
艺杯羹3 小时前
JDBC之ORM思想及SQL注入
数据库·sql·jdbc·orm·sql注入
blackA_4 小时前
数据库MySQL学习——day4(更多查询操作与更新数据)
数据库·学习·mysql
极限实验室5 小时前
Easysearch 迁移数据之 Reindex From Remote
数据库
朴拙数科5 小时前
基于LangChain与Neo4j构建企业关系图谱的金融风控实施方案,结合工商数据、供应链记录及舆情数据,实现隐性关联识别与动态风险评估
数据库·langchain·neo4j
小李学不完6 小时前
Oracle--SQL事务操作与管理流程
数据库
qq_441996056 小时前
为何 RAG 向量存储应优先考虑 PostgreSQL + pgvector 而非 MySQL?
数据库·mysql·postgresql
Ivan陈哈哈6 小时前
Redis是单线程的,如何提高多核CPU的利用率?
数据库·redis·缓存