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表

相关推荐
不光头强10 小时前
Spring框架的事务管理
数据库·spring·oracle
百***920212 小时前
【MySQL】MySQL库的操作
android·数据库·mysql
q***766612 小时前
Spring Boot 从 2.7.x 升级到 3.3注意事项
数据库·hive·spring boot
信仰_27399324312 小时前
Redis红锁
数据库·redis·缓存
人间打气筒(Ada)12 小时前
Centos7 搭建hadoop2.7.2、hbase伪分布式集群
数据库·分布式·hbase
心灵宝贝13 小时前
如何在 Mac 上安装 MySQL 8.0.20.dmg(从下载到使用全流程)
数据库·mysql·macos
想睡hhh13 小时前
mysql索引——理解索引机制及操作
mysql
剑动山河13 小时前
ubuntu 升级mysql由mysql5.7.42 升级到8.4.0
mysql·ubuntu·adb
奋斗的牛马13 小时前
OFDM理解
网络·数据库·单片机·嵌入式硬件·fpga开发·信息与通信
忧郁的橙子.14 小时前
一、Rabbit MQ 初级
服务器·网络·数据库