1.创建表

mysql> create table t_address(
-> id int primary key auto_increment, // 设置id为主键,自动增值
-> bookid int,
-> address varchar(100),
-> note_address varchar(100),
-> foreign key(bookid) references t_book(id) // 设置bookid为外键,引用到t_book表中的id字段
-> );

通过复制表的方式快速创建表

mysql> create table t_copy as select * from t_booktype where id=0;  //这里给一个不存在的id的值,那么得到的新表只是复制了不包括约束的原表结构,没有复制数据

mysql> create table t_copy as select * from t_booktype;  //复制了不带约束的表结构和全部数据

mysql> create table t_authors as select authors from t_book where authors like '%richard%';

mysql> create table t_copy like t_booktype;  // 复制原表结构和约束,但是没有数据

常用的数据类型:

varchar 可变长度字符串,可根据实际数据长度动态分配空间,最长255个字符(可存255个汉字或数字?)。

char 定长字符串,不会动态分配空间,速度快,但是会导致空间浪费,最长255个字符。

int 整数,最长11

bigint 长整型

float 单精度浮点型

double 双精度浮点型

date 短日期

datetime 长日期

clob (character large object) 字符大对象,最多可以存储4G字符串。

blob (binary large object) 二进制大对象,声音、图片、视频等,需要IO流插入数据。

常见表的约束:

not null 非空约束,属于列级约束,只能加在字段后面

unique 唯一性约束,但可以包含多个null,属于表级约束,与列级约束见下文所述例子

create table t_user(
    id int,
    name varchar(32) not null,  // 列级约束
    birth date,
    create_time datetime,
    unique(id,name)  // 表级约束,多个字段添加某种约束
)

primary key 主键约束,每张表都应该有一个主键,不一定非得是关键字段用来当主键,只要能突出not null+unique即可,所以“id int primary key auto_increment,"这句话在创建表的时候用到就好了。主键不建议使用varchar类型,并且也不建议使用复合主键。

foreign key 外键约束。比如有一张记录书籍信息的表,还有一张记录书籍类别的表,每一本书都属于某一种类别。这时书籍的表是子表,书籍类别的表是父表。子表中的外键引用父表中的字段,这个字段不一定是主键,但是需要具有唯一性。创建表时先创建父表,再创建子表;插入数据时先插入父表数据,再插入子表数据。子表中插入数据时,如果插入的是父表中没有的类别,那么会报错。删除表时则先删子表,再删父表。

PS:如果两张表之间有多对多的关系,例如学生和老师,每个学生有多个老师,每个老师教多个学生,那么可以在学生和老师之间增加一个关系表,用于记录两者之间的关系。

2.更改表

a.增加字段

mysql> alter table t_copy add column property varchar(20) after booktype;

mysql> alter table t_copy add column property1 varchar(20),
-> add column property2 varchar(20);

b.删除字段

mysql> alter table t_copy drop column property1,
-> drop column property2;

c.更改字段类型

mysql> alter table t_copy modify column property int;

d.给字段添加外键约束

mysql> alter table t_copy add foreign key(property) references t_book(id) on delete cascade;

e.删除字段的外键约束

可以先用show create table t_copy\G 查询到想要删除的外键约束的名称。

mysql> show create table t_copy\G
*************************** 1. row ***************************
Table: t_copy
Create Table: CREATE TABLE `t_copy` (
`id` int NOT NULL DEFAULT '0',
`booktype` varchar(50) DEFAULT NULL,
`property` int DEFAULT NULL,
KEY `property` (`property`),
CONSTRAINT `t_copy_ibfk_1` FOREIGN KEY (`property`) REFERENCES `t_book` (`id`) ON DELETE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

mysql> alter table t_copy drop constraint t_copy_ibfk_1;

f.将表A的a字段赋值给表B的b字段

mysql>update A join B on A.id=B.Aid set A.a=B.b;

3.删除表

mysql> drop table if exists t_copy;

MySQL创建表、更改表和删除表的更多相关文章

  1. MySQL创建数据库 easyShopping,包括area表、goods表、customer表、orders表、ordersdetall表、test表

    MySQL创建数据库 easyShopping,包括area表.goods表.customer表.orders表.ordersdetall表.test表 商品表表结构: 字段名 说 明 类 型 长 度 ...

  2. 创建mysql数据库,在新数据库中创建表,再尝试删除表

    创建之前,先登录数据库存 mysql -u 账号 -p密码 登录完成后,展示一下已存在的数据库 show databases; 创建数据库 create database test111; 然后展示一 ...

  3. mysql 如何修改、添加、删除表主键

    在我们使用mysql的时候,有时会遇到须要更改或者删除mysql的主键,我们能够简单的使用alter table table_name drop primary key;来完成.以下我使用数据表tab ...

  4. mysql语句3-插入、修改删除表

    二.DML数据操纵语句 关键字:insert(插入)  delete(删除)  update(更新)  select(查询) 1.表创建好以后,就可以插入记录了,语法如下: 方法一 :insert i ...

  5. SQL语句创建数据库,SQL语句删除数据库,SQL语句创建表,SQL语句删除表,SQL语句添加约束,SQL语句删除约束

    创建数据库: CREATE DATABASE Test --要创建的数据库名称 ON PRIMARY ( --数据库文件的具体描述 NAME='Test_data', --主数据文件的逻辑名称 FIL ...

  6. Mysql命令增加、修改、删除表字段

    alter add 命令用来增加表的字段: alter add命令格式:alter table 表名 add字段 类型 其他:如下所示: ) comment '单位' alter drop 命令删除表 ...

  7. oracle 删除用户,表空间;循环删除表

    select * from dba_tablespaces 说明:查看所有表空间 ----------------------------------------------------------- ...

  8. MySQL创建用户、授权、删除

    1.在MySQL中创建新用户 使用具有shell访问权限的root用户登录MySQL服务器并创建名为“rahul”的新用户.下面的命令只允许从localhost系统访问用户rahul的MySQL服务器 ...

  9. Mysql 创建普通用户、数据库、表、插入记录,用户赋权

    C:\phpStudy\MySQL\bin>mysql -uroot -proot -h127.0.0.1 //创建用户 mysql> insert into mysql.user (ho ...

  10. MySql新增表的字段,删除表字段

    1增加两个字段: create table id_name(id int,name varchar(20));//创建原始数据表 alter table id_name add age int,add ...

随机推荐

  1. 切换不同的echarts时,出现图标缩小,报警告,Can’t get dom width or height!

    出现这样的原因是因为,在切换的时候,图表所对应的标签还没有显示出来,最好将代码放在$nextick里面执行,并且,采用使用v-if进行切换 转载:https://www.pianshen.com/ar ...

  2. TensorFlow 卷积神经网络实用指南 | iBooker·ApacheCN

    原文:Hands-On Convolutional Neural Networks with TensorFlow 协议:CC BY-NC-SA 4.0 自豪地采用谷歌翻译 不要担心自己的形象,只关心 ...

  3. 最近公共祖先-LCA

    题目描述 时间限制:1.2s 内存限制:256.0MB 问题描述 如题,给定一棵有根多叉树,请求出指定两个点直接最近的公共祖先. 输入格式 第一行包含三个正整数\(N\),\(M\),\(S\),分别 ...

  4. Java安全之BCEL ClassLoader

    目录 Java安全之BCEL ClassLoader 写在前面 About BCEL 调试分析 食用姿势 Fuzz反序列化Gadget Fastjson BCEL Payload Thymeleaf ...

  5. 【微服务】- SpringCloud中Config、Bus和Stream

    文章目录 SpringCloud中Config 1.Config的简介 官网 分布式系统面临的问题 config是什么 如何使用 能做什么 与git的配合使用 2.Config服务端的配置和测试 准备 ...

  6. linux计划任务之cron

    目录 cron计划任务之用户级 cron计划任务之系统级 cron计划任务之用户级 1.安装crond centos7 执行命令: # yum install -y crontabs /bin/sys ...

  7. NSString 类介绍及用法

    1.NSString常见方法 NSString是 Objective-C 中核心处理字符串的类之一 创建常量字符串,注意使用"@"符号. NSString *astring = @ ...

  8. java创建一个子类对象是会调用父类的构造方法会不会创建父类

    1.子类在创建实例后,类初始化方法会调用父类的初始化方法(除了Java.lang.Object类,因为java.lang.Object类没有父类),而这种调用会逐级追述,直到java.lang.Obj ...

  9. Java用n种方法编写实现双色球随机摇号案例

    方法清单 规则 实现方式一 实现方式二 实现方式三 实现方式四 实现方法五 之前我用JavaScript编写过一个实现双色球随机摇号的案例, 点击此处查看,今天我再用Java语言来实现这一效果. 规则 ...

  10. selenium连接浏览器方式

    支持HtmlUnitDriver无头浏览器自动化   定位元素的方式:是可嵌套的 WebElement cheese = driver.findElement(By.id("cheese&q ...