数据库基础篇 《10.创建和管理表DDL》

news2024/11/24 14:22:21

目录

1. 基础知识

1.1 一条数据存储的过程

1.2 标识符命名规则

​1.3 MySQL中的数据类型

​ 2. 创建和管理数据库 

2.1 创建数据库

2.2 使用数据库

2.3 修改数据库

2.4 删除数据库

3. 创建表

3.1 创建方式1

3.2 创建方式2  

​3.3 查看数据表结构

4. 修改表

4.1 追加一个列

4.2 修改一个列

​4.3 重命名一个列

​4.4 删除一个列 

5. 重命名表

6. 删除表  

7. 清空表

8. 内容拓展

9. 课后练习

9.1 练习1

1. 创建数据库test01_office,指明字符集为utf8。并在此数据库下执行下述操作

2. 创建表dept01

3. 将表departments中的数据插入新表dept02中

4. 创建表emp01

5. 将列last_name的长度增加到50

6. 根据表employees创建emp02

7. 删除表emp01

8. 将表emp02重命名为emp01

9.在表dept02和emp01中添加新列test_column,并检查所作的操作

10.直接删除表emp01中的列 department_id

9.2 练习2

1 创建数据库 test02_market

2 创建数据表 customers

3 将 c_contact 字段移动到 c_birth 字段后面

4 将 c_name 字段数据类型改为 varchar(70)

5 将c_contact字段改名为c_phone

6 增加c_gender字段到c_name后面,数据类型为char(1) 

7 将表名改为customers_info

8 删除字段c_city

9.2 练习3

1 创建数据库test03_company

2 创建表offices

3 创建表employees 

4 将表employees的mobile字段修改到code字段后面

5 将表employees的birth字段改名为birthday

6 修改sex字段,数据类型为char(1)

7 删除字段note

8 增加字段名favoriate_activity,数据类型为varchar(100)

9 将表employees的名称修改为 employees_info


1. 基础知识

1.1 一条数据存储的过程

1.2 标识符命名规则

1.3 MySQL中的数据类型

 其中,常用的几类类型介绍如下:

 2. 创建和管理数据库 

2.1 创建数据库

方式1:创建数据库

CREATE DATABASE 数据库名;

方式2:创建数据库并指定字符集

CREATE DATABASE 数据库名 CHARACTER SET 字符集;

方式3:判断数据库是否已经存在,不存在则创建数据库( 推荐
 

CREATE DATABASE IF NOT EXISTS 数据库名;

2.2 使用数据库

查看当前所有的数据库

SHOW DATABASES; #有一个S,代表多个数据库

查看当前正在使用的数据库

SELECT DATABASE(); #使用的一个 mysql 中的全局函数

查看指定库下所有的表

SHOW TABLES FROM 数据库名;

查看数据库的创建信息

SHOW CREATE DATABASE 数据库名;
或者:
SHOW CREATE DATABASE 数据库名\G

使用/切换数据库

USE 数据库名;
注意:要操作表格和数据之前必须先说明是对哪个数据库进行操作,否则就要对所有对象加上“数据库名.”

2.3 修改数据库

更改数据库字符集
ALTER DATABASE 数据库名 CHARACTER SET 字符集; #比如:gbk、utf8等

2.4 删除数据库

方式 1 :删除指定的数据库
DROP DATABASE 数据库名;
方式 2 :删除指定的数据库( 推荐
DROP DATABASE IF EXISTS 数据库名;

3. 创建表

3.1 创建方式1

-- 创建表
CREATE TABLE emp (
-- int类型
emp_id INT,
-- 最多保存20个中英文字符
emp_name VARCHAR(20),
-- 总位数不超过15位
salary DOUBLE,
-- 日期类型
birthday DATE
);
DESC emp;

CREATE TABLE dept(
-- int类型,自增
deptno INT(2) AUTO_INCREMENT,
dname VARCHAR(14),
loc VARCHAR(13),
-- 主键
PRIMARY KEY (deptno)
);
DESCRIBE dept;

3.2 创建方式2  

CREATE TABLE emp1 AS SELECT * FROM employees;
CREATE TABLE emp2 AS SELECT * FROM employees WHERE 1=2; -- 创建的emp2是空表
CREATE TABLE dept80
AS
SELECT employee_id, last_name, salary*12 ANNSAL, hire_date
FROM employees
WHERE department_id = 80;
DESCRIBE dept80;

3.3 查看数据表结构

SHOW CREATE TABLE 表名\G

使用SHOW CREATE TABLE语句不仅可以查看表创建时的详细语句,还可以查看存储引擎和字符编码。

4. 修改表

4.1 追加一个列

语法格式如下:
ALTER TABLE 表名 ADD 【COLUMN】 字段名 字段类型 【FIRST|AFTER 字段名】;
举例
ALTER TABLE dept80
ADD job_id varchar(15);

4.2 修改一个列

可以修改列的数据类型,长度、默认值和位置
修改字段数据类型、长度、默认值、位置的语法格式如下
ALTER TABLE 表名 
MODIFY 【COLUMN】 字段名1 字段类型 【DEFAULT 默认值】【FIRST|AFTER 字段名2】;

4.3 重命名一个列

4.4 删除一个列 

5. 重命名表

6. 删除表  

7. 清空表

SET autocommit = FALSE;
DELETE FROM emp2;
#TRUNCATE TABLE emp2;
SELECT * FROM emp2;
ROLLBACK;
SELECT * FROM emp2;
阿里开发规范:
【参考】 TRUNCATE TABLE DELETE 速度快,且使用的系统和事务日志资源少,但 TRUNCATE 无事务且不触发 TRIGGER ,有可能造成事故,故不建议在开发代码中使用此语句。
说明: TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同。  

8. 内容拓展

CREATE DATABASE mytest;
USE mytest;
CREATE TABLE book1(
book_id INT ,
book_name VARCHAR(255)
);
SHOW TABLES;

9. 课后练习

9.1 练习1

1. 创建数据库test01_office,指明字符集为utf8。并在此数据库下执行下述操作

CREATE DATABASE IF NOT EXISTS test01_office CHARACTER SET 'utf-8';

2. 创建表dept01

/*
字段 类型
id INT(7)
NAME VARCHAR(25)
*/
USE test01_office;
CREATE TABLE dept01(
    id INT(7),
    NAME VARCHAR(26)
);

3. 将表departments中的数据插入新表dept02

CREATE TABLE dept02
AS SELECT *
FROM atguigudb.departments;

4. 创建表emp01

/*
字段 类型
id INT(7)
first_name VARCHAR (25)
last_name VARCHAR(25)
dept_id INT(7)
*/
CREATE TABLE emp1(
    id INT(7),
    first_name VARCHAR(25),
    last_name VARCHAR(25),
    dept_id INT(7)
);

5. 将列last_name的长度增加到50

ALTER TABLE emp1
MODIFY last_name VARCHAR(50);

6. 根据表employees创建emp02

CREATE TABLE emp02
AS SELECT *
FROM atguigudb.employees;

7. 删除表emp01

DROP TABLE IF EXISTS emp01;

8. 将表emp02重命名为emp01

RENAME TABLE emp02 TO emp01;

9.在表dept02emp01中添加新列test_column,并检查所作的操作

ALTER TABLE dept02 
    ADD test_column VARCHAR(10);
ALTER TABLE emp01 
    ADD test_column VARCHAR(10);
DESC dept02;
DESC emp01;

10.直接删除表emp01中的列 department_id

ALTER TABLE emp01
    DROP COLUMN department_id;

9.2 练习2

创建数据库 test02_market

CREATE DATABASE IF NOT EXISTS test02_market CHARACTER SET 'utf8';
USE test02_market;

创建数据表 customers

CREATE TABLE IF NOT EXISTS customers(
    c_num INT,
    c_name VARCHAR(50),
    c_contact VARCHAR(50),
    c_city VARCHAR(50),
    c_birth DATE
);

c_contact 字段移动到 c_birth 字段后面

ALTER TABLE customers
    MODIFY c_contact VARCHAR(50) After c_birth;

c_name 字段数据类型改为 varchar(70)

ALTER TABLE customers
    MODIFY c_name VARCHAR(70);

c_contact字段改名为c_phone

ALTER TABLE customers
    CHANGE c_contact c_phone VARCHAR(50);

增加c_gender字段到c_name后面,数据类型为char(1) 

ALTER TABLE customers
    ADD c_gender CHAR(1) AFTER c_name;

7 将表名改为customers_info

RENAME TABLE customers
    TO customers_info;

删除字段c_city

ALTER TABLE customers_info
    DROP COLUMN c_city;

9.2 练习3

创建数据库test03_company

CREATE DATABASE IF NOT EXISTS test03_company CHARACTER SET 'utf8';
USE test03_company;

创建表offices

CREATE TABLE offices(
    offices INT,
    city VARCHAR(30),
    address VARCHAR(50),
    county VARCHAR(50),
    postalCode VARCHAR(25)
);

3、创建表employees 

CREATE TABLE employees(
    empNum INT,
    lastName VARCHAR(50),
    firstName VARCHAR(50),
    mobile VARCHAR(25),
    code INT,
    jobTitle VARCHAR(50),
    birth DATE,
    note VARCHAR(255),
    sex VARCHAR(5)
);

将表employeesmobile字段修改到code字段后面

ALTER TABLE employees
    MODIFY mobile VARCHAR(25) AFTER code;

将表employeesbirth字段改名为birthday

ALTER TABLE employees
    CHANGE birth birthday DATE;

修改sex字段,数据类型为char(1)

ALTER TABLE employees
    MODIFY sex char(1);

删除字段note

ALTER TABLE employees
DROP note;

增加字段名favoriate_activity,数据类型为varchar(100)

ALTER TABLE employees
    ADD favorite_activity VARCHAR(100);

将表employees的名称修改为 employees_info

RENAME TABLE employees
TO employees_info;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/460398.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2023华为软件精英挑战赛,探寻软件人才与科技创新的最优解

作者 | 曾响铃 文 | 响铃说 今天,软件行业正呈现出江河入海一般的大汇流趋势。 一方面是技术的汇流,诸如人工智能等前沿技术与软件行业的深度融合,正全面颠覆软件产品的开发模式和服务逻辑。 另一方面则是行业的汇流,数字化浪…

PyEcharts数据可视化(1)——配置项

PyEcharts 学习连接 一、查看pyecharts版本 import pyecharts print(pyecharts.__version__)输出:1.9.0 二、绘制第一个图表 from pyecharts.charts import Bar bar Bar() # 创建柱形图对象 bar.add_xaxis(["衬衫","羊毛衫","雪纺衫…

创建路由React router(使用react-router dom V6版本)

React路由 隔了很长一段时间,重新捡起来React学习。 发现React的路由从原来的 Switch改成了Routes。nice,nice,nice!!!! 刚开始接触确实还是有一点生疏的。之前的关于【传参】【js跳转】【跳转模…

管理后台项目-06-用户管理角色管理模块

目录 1-路由信息搭建和api文件信息创建 2-用户管理模块 2.1-列表数据获取以及动态渲染 2.2-添加 | 修改 用户 2.3-删除-批量删除用户 2.4-分配角色 3-角色管理 3.1-修改角色 3.2-分配权限 1-路由信息搭建和api文件信息创建 我们先进行路由菜单的配置,在系统…

【测试开发】测试人的养成记,在这测试内卷乱世中突破测试开发...

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 这几年&#xff0…

442. 数组中重复的数据|||41. 缺失的第一个正数|||485. 最大连续 1 的个数

442. 数组中重复的数据 题目 给你一个长度为 n 的整数数组 nums ,其中 nums 的所有整数都在范围 [1, n] 内,且每个整数出现 一次 或 两次 。请你找出所有出现 两次 的整数,并以数组形式返回。 你必须设计并实现一个时间复杂度为 O(n) 且仅…

Python如何连接Mysql及基本操作

1.什么要做python连接mysql,一般是解决什么问题的 做自动化测试时候,注册了一个新用户,产生了多余的数据,下次同一个账号就无法注册了,这种情况怎么办呢?自动化测试都有数据准备和数据清理的操作&#xff…

KDJB-1200继电保护定值校验仪器

一、产品概述 KDJB-1200 微机继电保护校验仪是在参照电力部颁发的《微机型继电保护试验装置技术条件(讨论稿)》的基础上,听取用户意见,总结目前国内同类产品优缺点,充分使用现代微电子技术和器件实现的一种新型小型化微机继电保护测试仪。 采…

《C++ Primer Plus》(第6版)第18章编程练习

《C Primer Plus》(第6版)第18章编程练习 《C Primer Plus》(第6版)第18章编程练习1. 函数average_list()2.3. sum_value()4. 使用lambda重新编写程序清单16.15 《C Primer Plus》(第6版)第18章编程练习 1…

mysql进阶-查询优化-慢查询日志

文章目录 一、什么是慢查询日志二、慢查询日志能干什么2.1 性能分析和优化2.2 诊断和排查问题2.3 数据分析和探索 三、慢查询日志实战3.1 永久开启开启慢查询日志3.2 临时开启慢查询日志3.4 常用命令 四、如何分析慢查询日志五、优化慢查询语句五、总结 一、什么是慢查询日志 …

这场SIG组开放工作会议为何吸引了那么多人的关注?

【中国,上海,2023年4月20日-21日】openEuler Developer Day 2023在线上和线下同步举办。本次大会由开放原子开源基金会指导,中国软件行业协会、openEuler社区、边缘计算产业联盟共同主办,以“万涓汇流,奔涌向前”为主题…

数据仓库与数据库之间的区别与联系

文章目录 一、数据库与数据仓库的区别 1.1、区别 1.2、ACID内容 二、原子性(Atomicity) 三、持久性(Durability) 四、隔离性(Isolation) 1、锁机制 2、脏读、不可重复读和幻读 2、事务隔离级别 五…

权限提升:溢出漏洞.(普通权限 提升 管理员权限.)

权限提升:溢出漏洞 权限提升简称提权,由于操作系统都是多用户操作系统,用户之间都有权限控制,比如通过 Web 漏洞拿到的是 Web 进程的权限,往往 Web 服务都是以一个权限很低的账号启动的,因此通过 Webshell …

日增百亿数据,查询结果秒出, Apache Doris 在 360商业化的统一 OLAP 应用实践

导读: 360商业化为助力业务团队更好推进商业化增长,实时数仓共经历了三种模式的演进,分别是 Storm Druid MySQL 模式、Flink Druid TIDB 的模式 以及 Flink Doris 的模式,基于 Apache Doris 的新一代架构的成功落地使得 360商…

“不幸的是,你知道的太多了”

《平凡的世界》里有一段话是这么说的:“谁让你读了这么多书,又知道了双水村以外还有个大世界。 如果从小你就在这个天地里日出而作,日落而息,那你现在就会和众乡亲抱同一理想,经过几年的辛劳,像大哥一样娶…

PHP 实现会话Session信息共享

目录 解决方案也有很多种: 会话保持 会话复制 会话共享 环境准备 架构设计 SessionHandlerInterface接口 代码编写 总结 优化 前言: 小流量的网站中,我们往往只需要一台服务器就可以维持用户正常的访问以及相关的操作。 随着网站的…

Superset整合keycloak系统

本篇主要介绍superset如何整合单点登陆系统keycloak,现在网上的博客大部分都是失效了,这里我相当于更新一下,避免大家再走弯路 一、环境配置 Macos keycloak:18.0.0 superset:2.1.0 keycloak规定:每一…

原理这就是索引下推呀

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。 索引下推是之前面试的时候遇到的一个面试题,当时没有答上来,今天来学习一下。 介绍索引下推之前先看一下MySQL基…

2022年NOC大赛创客智慧编程赛道图形化scratch复赛题,包含答案解析

目录 2022 年 NOC 大赛创客智慧编程图形化复赛用题 下载文档打印做题:

ArcGIS Pro、Python、USLE、INVEST模型等多技术融合的生态系统服务构建生态安全格局

第一章、生态安全评价理论及方法介绍 一、生态安全评价简介 ​ 二、生态服务能力简介 ​ 三、生态安全格局构建研究方法简介 ​ 第二章、平台基础一、ArcGIS Pro介绍1. ArcGIS Pro简介2. ArcGIS Pro基础3. ArcGIS Pro数据编辑4. ArcGIS Pro空间分析5. 模型构建器6. ArcGIS Pro…