登录
首页 >  数据库 >  MySQL

MySQL——表的操作和约束

来源:SegmentFault

时间:2023-02-21 08:44:26 120浏览 收藏

在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是数据库学习者,那么本文《MySQL——表的操作和约束》就很适合你!本篇内容主要包括MySQL——表的操作和约束,希望对大家的知识积累有所帮助,助力实战开发!

创建表

!!!必须先进入一个数据库!!!

create table [tablename](
    列名1 类型 [约束],
    列名1 类型 [约束],
    列名1 类型 [约束]
);
/* 最后一行没有逗号,但是括号外有分号 */

创建一张学生信息表,记录学生的id、name、age

create table t_students
(
id bigint,
name varchar(20),
age int
);

如果创建表中使用到了数据库的关键字,可以用反引号【 ` 】将名字括起来,一般用:t_表名

图片描述

简单的创建表语句:

/* 创建一个新的表从另一个表复制过来,但是不复制主键、索引等结构 */
create table emp_copy as select * from emp;
/* where 1=2为false,所以不复制表 */
create table emp_copy as select * from emp where 1=2;
/* 不复制数据,只复制结构,不会拷贝外键 */
create talbe emp_bak like emp;

查看表的结构

desc [tablename];

图片描述

查看表的详细定义

show create table [tablename];

其实显示的就是创建表的SQL语句

图片描述

删除表

drop table [tablename];

表的约束

类型 语句 作用
非空约束 not null 不允许某列的内容为空
设置默认值 default+值 默认值
唯一约束 unique 这一列的内容必须唯一,不能重复
主键约束 primary key 非空且唯一
主键自增长 auto_increment 从1开始,步长为1,整数才能自增
外键约束 foreign key

主键设计,唯一标识某一行数据的:

  • 选一列作为主键(推荐)
  • 选多列作为主键(不推荐)
  • 自然主键:使用有业务含义(就是指这个值有用的,如身份证号码)的列作主键(不推荐)
  • 代理主键:使用有没有业务含义的列作主键(推荐)

好了,本文到此结束,带大家了解了《MySQL——表的操作和约束》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表