创建表
!!!必须先进入一个数据库!!!
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 |
主键设计,唯一标识某一行数据的:
- 选一列作为主键(推荐)
- 选多列作为主键(不推荐)
- 自然主键:使用有业务含义(就是指这个值有用的,如身份证号码)的列作主键(不推荐)
- 代理主键:使用有没有业务含义的列作主键(推荐)
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。