(五)mysql表操作和约束条件
(1)表基本操作
1)创建表
create table 表名(字段 数据类型 约束条件)
mysql> create table student1(id int,name varchar(50),sex enum('w','f'),age int);
2)查看表
mysql> desc student1; #查看表结构
+-------+---------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------------+------+-----+---------+-------+
| id | int(11) | YES | | NULL | |
| name | varchar(50) | YES | | NULL | |
| sex | enum('w','f') | YES | | NULL | |
| age | int(11) | YES | | NULL | |
+-------+---------------+------+-----+---------+-------+
mysql> show create table student1; #查看创表语句
----------------+| student1 | CREATE TABLE `student1` (
`id` int(11) DEFAULT NULL,
`name` varchar(50) DEFAULT NULL,
`sex` enum('w','f') DEFAULT NULL,
`age` int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1
3)删除表
drop table 表名
4)插入数据没有约束条件:数据可以重复
mysql> insert into student1 values(3,'wack','f',21),(4,'jaxc','w',18);
mysql> insert into student1 values(3,'wack','f',21),(4,'jaxc','w',18);
mysql> insert into student1(name,sex) values('wf','w');
mysql> insert into student1(name,sex) values('wf','w');
mysql> select * from student1;
| 4 | jaxc | w | 18 |
| 3 | wack | f | 21 |
| 4 | jaxc | w | 18 |
| NULL | wf | w | NULL |
| NULL | wf | w | NULL |
+------+------+------+------+
(2)表约束条件:保证数据的完整性和一致性
1)约束条件
primary key :标识字段为主键,可以唯一的标识记录,特性:唯一,不可以为空,一个表中只有1个主键
foreign key :标识字段为外键,实现表与表之间的关联
not null:标识该字段不能为空
unique key :标识该字段唯一,可以为空,一个表中可以有多个unique key
auto_increment:标识该字段的值自动增长(整数类型,而且是主键)
default :为该字段设置默认值
unsigned :无符号,正数
zerofill : 使用0填充
2)default默认值和not null非空
mysql> create table student1(id int not null,name varchar(50) not null,sex enum('m','f') default 'm' not null,age int unsigned default 18 not null);
mysql> desc student1;
+-------+------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+------------------+------+-----+---------+-------+
| id | int(11) | NO | | NULL | |
| name | varchar(50) | NO | | NULL | |
| sex | enum('m','f') | NO | | m | |
| age | int(10) unsigned | NO | | 18 | |
+-------+------------------+------+-----+---------+-------+
mysql> insert into student1 values(1,'jack','m',21);
mysql> insert into student1(id,name) values(2,'robin');
mysql> insert into student1 values(3,null,'f',28);
ERROR 1048 (23000): Column 'name' cannot be null
3)primary key单列做主键测试
创建主键方式1:
mysql> create table student(id int auto_increment primary key,
-> name varchar(50) not null,
-> sex enum('m','f') not null default 'm',
-> age int not null default 18);
创建主键方式二:
mysql> create table student(id int auto_increment,
-> name varchar(50) not null,
-> sex enum('m','f') not null default 'm',
-> age int not null default 18, primary key(id));
mysql> desc student;
+-------+---------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| name | varchar(50) | NO | | NULL | |
| sex | enum('m','f') | NO | | m | |
| age | int(11) | NO | | 18 | |
+-------+---------------+------+-----+---------+----------------+
mysql> insert into student values(1,'jack','m',18);
mysql> insert into student(name) values('robby');
mysql> insert into student values(1,'wf','m',20);
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'
mysql> select * from student;
+----+-------+-----+-----+
| id | name | sex | age |
+----+-------+-----+-----+
| 1 | jack | m | 18 |
| 2 | robby | m | 18 |
+----+-------+-----+-----+
4)复合多列主键:多个列组合作为主键,单列值可以重复
mysql> create table service(ip varchar(15) not null,
-> service varchar(10) not null,
-> port int not null,
-> protocol enum('tcp','udp') not null default 'tcp',
-> allow enum('Y','N') default 'N',
-> primary key(ip,service));
mysql> desc service;
+----------+-------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------------+------+-----+---------+-------+
| ip | varchar(15) | NO | PRI | NULL | |
| service | varchar(10) | NO | PRI | NULL | |
| port | int(11) | NO | | NULL | |
| protocol | enum('tcp','udp') | NO | | tcp | |
| allow | enum('Y','N') | YES | | N | |
+----------+-------------------+------+-----+---------+-------+
mysql> insert into service values('192.168.1.32','http',80,'tcp','Y');
mysql> insert into service(ip,service,port) values('192.168.1.32','ftp',21);
mysql> insert into service(ip,service,port) values('192.168.1.32','http',80);
ERROR 1062 (23000): Duplicate entry '192.168.1.32-http' for key 'PRIMAR
mysql> select * from service;
+--------------+---------+------+----------+-------+
| ip | service | port | protocol | allow |
+--------------+---------+------+----------+-------+
| 192.168.1.32 | dns | 53 | tcp | N |
| 192.168.1.32 | ftp | 21 | tcp | N |
| 192.168.1.32 | http | 80 | tcp | Y |
+--------------+---------+------+----------+-------+
5)unique:标识该字段唯一,可以为空,一个表中可以有多个unique key
mysql> create table department(dept_id int,dept_name varchar(50) unique);
mysql> desc department;
+-----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------+-------------+------+-----+---------+-------+
| dept_id | int(11) | YES | | NULL | |
| dept_name | varchar(50) | YES | UNI | NULL | |
+-----------+-------------+------+-----+---------+-------+
mysql> insert into department values(1,"hr");
mysql> insert into department values(1,"it");
mysql> insert into department values(1,"hr");
ERROR 1062 (23000): Duplicate entry 'hr' for key 'dept_name'
mysql> select * from department;
+---------+-----------+
| dept_id | dept_name |
+---------+-----------+
| 1 | hr |
| 1 | it |
+---------+-----------+
(3)修改表
1)语法
修改表:
alter table 表名 rename 新表名
增加字段:
alter table 表名 add 字段名 数据类型[约束条件]
alter table 表名 add 字段名 数据类型[约束条件] first;
alter table 表名 add 字段名 数据类型[约束条件] after 字段名;
删除字段:
alter table 表名 drop 字段名
修改字段类型:
alter table 表名 modify 字段名 数据类型[约束条件];
alter table 表名 change 旧字段名 新字段名 新数据类型[约束条件];
2)修改表的存储引擎:
mysql> alter table t1 engine=innodb;
3)添加字段
mysql> create table t1(id int);
mysql> alter table t1 add name varchar(50) not null,add age int not null default 20;
mysql> alter table t1 add num int not null after name, add sex enum('m','f') not null default 'm' first
4)删除字段
mysql> alter table t1 drop sex;
5)修改字段类型:
mysql> alter table t1 modify age tinyint; \\注意保留原有的约束条件
mysql> alter table t1 modify age tinyint not null default 20;
mysql> alter table t1 modify id int not null primary key auto_increment; \\在字段有主键的情况下添加auto_increment这种方法不行
ERROR 1068 (42000): Multiple primary key defined
mysql> alter table t1 modify id int not null auto_increment; \\在字段有主键的情况下添加auto_increment方式
6)添加复合主键:
mysql >alter table t2 add primary key(id,name);
7)添加主键:
mysql> alter table t1 modify id int not null primary key; \\添加主键,不建议
mysql> alter table t1 add primary key(id);
8)删除主键:如果字段有auto_increment约束,需要先删除这个约束才能在删除主键,因为自增依赖主键
mysql> alter table t1 drop primary key;
ERROR 1075 (42000): Incorrect table definition; there can be only one auto column and it must be defined as a key
mysql> alter table t1 modify id int not null; \\先删除主键上的自增
mysql> alter table t1 drop primary key; \\删除主键
(4)复制表
1)复制表结构+记录,key不会复制,也就是主键丶索引不会复制
mysql> create table new_t1 select * from t1; \\key不会复制,也就是主键丶索引不会复制
2)只复制表结构
mysql> create table new_t2 select * from t1 where 1=3; //条件为假,查不到任何记录
3)复制表结构,包括key
mysql> create table new_t3 like t1;
(五)mysql表操作和约束条件的更多相关文章
- Python 3 mysql 表操作
Python 3 mysql 表操作 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段 id,name,qq,age称为字段,其余的,一行内容称为 ...
- 数据库 -- mysql表操作
一,存储引擎介绍 存储引擎即表类型,mysql根据不同的表类型会有不同的处理机制 详见:https://www.cnblogs.com/peng104/p/9751738.html 二,表介绍 表相当 ...
- mysql数据库从删库到跑路之mysql表操作
表介绍 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段 id,name,qq,age称为字段,其余的,一行内容称为一条记录 内容: 1 创建表 ...
- MySQL 表操作 (Day40)
阅读目录 一.表介绍 二.创建表 三.查看表 四.修改表 五.删除表 六.操作表中的记录 一.表介绍 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,则称为表 ...
- 8.3 mysql 表操作
库操作 一 系统数据库 information_schema: 虚拟库,不占用磁盘空间,存储的是数据库启动后的一些参数,如用户表信息.列信息.权限信息.字符信息等 performance_sch ...
- MySQL表操作及数据操作
表操作 表相当于一个文件,其形式与现实中的表格相同.表中的每条记录都有相应的字段,字段就类似于表格的表头. 表操作详细: #对表进行操作(文件) #首先要切换到指定库(即文件夹)下:use db1; ...
- mysql表操作与权限操作
修改表ALTER TABLE 语法: . 修改表名 ALTER TABLE 表名 RENAME 新表名; . 增加字段 ALTER TABLE 表名 ADD 字段名 数据类型 [完整性约束条件…], ...
- SQL学习笔记三之MySQL表操作
阅读目录 一 存储引擎介绍 二 表介绍 三 创建表 四 查看表结构 五 数据类型 六 表完整性约束 七 修改表ALTER TABLE 八 复制表 九 删除表 一 存储引擎介绍 存储引擎即表类型,mys ...
- Mysql表操作《一》表的增删改查
一.表介绍 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段 id,name,qq,age称为字段,其余的,一行内容称为一条记录 二.创建表 语法 ...
随机推荐
- 如何使用 window.open() 处理ajax请求返回的url: 在本页面打开并防止浏览器拦截
ajax请求中用window.open()打开请求返回url(例如实现下载功能时),可能会因为跨域问题导致浏览器拦截 解决办法是:在请求前,打开一个窗口,请求成功后将返回的url直接赋值给该窗口的hr ...
- IE浏览器报Promise未定义的错误
背景: 一个vue-cli构建的vue项目,一个使用angular的项目,两个项目在其他浏览器一切正常,但是ie中会报Promise未定义的错误 解决办法: vue的项目: 1. npm insta ...
- [Java] 为什么要定义接口
摘自:https://www.douban.com/note/61810488/ 通俗的讲,就是为了降低耦合度. 一个很搞笑的例子: 看看下面的程序: 一个学校里边,有两种人:学生.老师.他们都要吃饭 ...
- 【bzoj1061】[NOI2008]志愿者招募 线性规划与费用流
题目描述 申奥成功后,布布经过不懈努力,终于成为奥组委下属公司人力资源部门的主管.布布刚上任就遇到了一个难题:为即将启动的奥运新项目招募一批短期志愿者.经过估算,这个项目需要N 天才能完成,其中第i ...
- BZOJ4327 JSOI2012玄武密码(AC自动机)
当然可以在SA上二分答案,但看起来会被卡log.考虑对模板串建出AC自动机,用母串在上面跑,标记上所有能到达的点.注意到达某个点时需要标记所有其通过fail指针可以走到的点,如果遇到一个标记过的点就可 ...
- Lua学习笔记:面向对象
Lua学习笔记:面向对象 https://blog.csdn.net/liutianshx2012/article/details/41921077 Lua 中只存在表(Table)这么唯一一种数据结 ...
- CLion 终于支持 jump outside closing bracket/quote with Tab 了!
我觉得这个 feature 真的很有用.一直期待 CLion 加上这个 feature.今天才知道最新版本(CLion 2018.3.4)中已经有这个功能了,不过我不清楚从哪个版本开始支持的. How ...
- 【题解】HNOI2017大佬
哎……做了几个小时最后还是没能想到怼大佬的合法性到底怎么搞.写暴力爆搜感觉复杂度爆炸就没敢写 bfs / dfs 一类,后来发现在种种的约束条件下(远小于所给的 \(n, m\))复杂度完全是可以承受 ...
- EOS docker开发环境
EOS Wiki提供了有关如何使用docker容器编译最新版本代码的说明.但可能有它自己的一些问题,因此我们鼓励你在学习时引用下面镜像.这样最初会更容易,更快. 如果你还没有安装docker,请在此处 ...
- [学习笔记]LCT进阶操作
LCT总结——应用篇(附题单)(LCT) 一般都是维护链的操作.split即可搞定. 进阶操作的话,处理好辅助树和原树的关系即可搞定. 其实,最大的区别就是,splay随便转,辅助树形态变了,但是原树 ...