MySQL - 创建表的三种方法详解及练习

目录

[🥙1. 基础创建](#🥙1. 基础创建)

🧀实例1

[🥙2. 带约束创建](#🥙2. 带约束创建)

🧀实例2

[🥙3. 复制创建](#🥙3. 复制创建)

🧀实例3:

🧀实例4:

🧀实例5:

​ 🧀实例6:

🧀实例7:

[🥙4. 牛客题:](#🥙4. 牛客题:)


🥙1. 基础创建

sql 复制代码
-- 基本语法
CREATE TABLE 表名称(
    字段名1 数据类型1,
    字段名2 数据类型2,
    字段名3 数据类型3);

🧀实例1

创建一个actor表,包含如下列信息

|-------------|-------------|
| 列表 | 类型 |
| actor_id | smallint(5) |
| first_name | varchar(45) |
| last_name | varchar(45) |
| last_update | date |

示例代码

sql 复制代码
drop table if exists actor;
create table actor(
    actor_id smallint(5),
    first_name varchar(45),
    last_name varchar(45),
    last_update date
);

结果:

🥙2. 带约束创建

sql 复制代码
-- 基本语法
CREATE TABLE 表名称(
    字段名1 数据类型1 主键 自增长,
    字段名2 数据类型2 非空 默认值,
    字段名3 数据类型3)
ENGINE=当前表格的引擎 
AUTO_INCREMENT=自增长的起始值 
DEFAULT CHARSET=表数据的默认字符集;

🧀实例2

创建一个actor表,包含如下列信息

CHARSET为utf8,ENGINE为INNODB

|-------------|-------------|----------|------|--------|
| 列表 | 类型 | 是否为NULL | 含义 | 其他 |
| actor_id | smallint(5) | not null | 主键id | 自增从1开始 |
| first_name | varchar(45) | not null | 名字 | |
| last_name | varchar(45) | not null | 姓氏 | |
| last_update | date | not null | 日期 | |

sql 复制代码
drop table if exists actor;
create table actor(
    actor_id smallint(5) primary key auto_increment comment '主键id',
    first_name varchar(45) not null comment '名字',
    last_name varchar(45) not null comment '姓氏',
    last_update date not null comment '日期'
)ENGINE=INNODB,AUTO_INCREMENT=1,DEFAULT charset =utf8;

结果:

🥙3. 复制创建

sql 复制代码
CREATE TABLE new_table LIKE old_table;   #复制表的所有结构
CREATE TABLE new_table SELECT list FROM old_table WHERE 0;  #复制表的部分结构
CREATE TABLE new_table SELECT * FROM old_table;   #复制表的所有结构+所有数据
CREATE TABLE new_table SELECT field_list FROM old_table;  #复制表的部分结构+所有数据
CREATE TABLE new_table SELECT field_list FROM old_table WHERE condition;  #复制表的部分结构+部分数据 

先往实例2创建的actor表中插入几条数据

sql 复制代码
insert into actor values ('1', 'PENELOPE', 'GUINESS', '2006-02-15 12:34:33'), 
                         ('2', 'NICK', 'WAHLBERG', '2006-02-15 12:34:33');

关于如何插入数据的讲解可参选如下连接:

Mysql - 常用插入数据的三种方法详解及练习-CSDN博客

🧀实例3

另建一个和actor一样的空表actor_copy

sql 复制代码
drop table if exists actor_copy;
create table actor_copy like actor;

结果

🧀实例4

将actor表中的first_name, last_name单独拿出来,存在一个新的空表actor_name中

sql 复制代码
create table actor_name
select first_name,last_name
from actor
where 0;

结果:

🧀实例5

另建一个和actor一模一样表actor_copy1

sql 复制代码
create table actor_copy1
select *
from actor;

结果

🧀实例6

请你创建一个actor_name2表,并且将actor表中的所有first_name以及last_name导入该表.

sql 复制代码
create table actor_name2
select first_name,last_name
from actor;

结果

🧀实例7

请你创建一个actor_name3表,并且将actor表中的first_name为'Nick'人的first_name和last_name导入该表.

sql 复制代码
create table actor_name3
select first_name,last_name
from actor
where first_name='NICK';

结果:

🥙4. 牛客题:

SQL227 创建一个actor表

SQL230 创建一个actor_name表

相关推荐
偶遇急雨洗心尘29 分钟前
记录一次服务器迁移时,数据库版本不一致导致sql函数报错和系统redirect重定向丢失域名问题
运维·服务器·数据库·sql
Arva .1 小时前
MySQL 的存储引擎
数据库·mysql
Logic1011 小时前
《Mysql数据库应用》 第2版 郭文明 实验5 存储过程与函数的构建与使用核心操作与思路解析
数据库·sql·mysql·学习笔记·计算机网络技术·形考作业·国家开放大学
小二·1 小时前
MyBatis基础入门《十六》企业级插件实战:基于 MyBatis Interceptor 实现 SQL 审计、慢查询监控与数据脱敏
数据库·sql·mybatis
bing.shao1 小时前
Golang WaitGroup 踩坑
开发语言·数据库·golang
专注VB编程开发20年1 小时前
C#内存加载dll和EXE是不是差不多,主要是EXE有入口点
数据库·windows·microsoft·c#
小二·1 小时前
MyBatis基础入门《十二》批量操作优化:高效插入/更新万级数据,告别慢 SQL!
数据库·sql·mybatis
何中应2 小时前
【面试题-6】MySQL
数据库·后端·mysql·面试题
路遥_132 小时前
银河麒麟 V10 安装部署瀚高数据库 HighGoDB 4.5 全流程(统信UOS Server 20同理)
数据库
TDengine (老段)2 小时前
从关系型数据库到时序数据库的思维转变
大数据·数据库·mysql·时序数据库·tdengine·涛思数据·非关系型数据库