mysql的表和约束操作
在创建表是默认为加上数据引擎和字符集,如创建一个student表,代码如下:
create table students(id int unsigned zerofill auto_increment primary key,
name varchar(20) not null, --不允许字段为null
sex char(1)
); -----------------------------自动加上数据引擎和字符集------------------------
create table students(id int unsigned zerofill auto_increment primary key,
name varchar(20) not null,
sex char(1)
)engines=innodb default charset=utf8;
- 插入数据(insert和replace)
1.insert命令直接在表的插入一条记录。
insert into students(sname,sex) values('orna','男');
insert into students(sname,sex) values('lisi','男');
insert into students(sname,sex) values('wangwu','男');
mysql> select * from students;
+------------+--------+------+------+
| id | sname | sex | tid |
+------------+--------+------+------+
| 0000000001 | orna | 男 | NULL |
| 0000000002 | lisi | 男 | NULL |
| 0000000003 | wangwu | 男 | NULL |
+------------+--------+------+------+
3 rows in set (0.00 sec)
2.replace命令在插入记录时判断主键是否相同,相同就修改,否则插入一条新记录。
replace into students(id,sname,sex) values(2,'luscy','女');
replace into students(id,sname,sex) values(20,'zhangsan','男'); mysql> select * from students;
+------------+----------+------+------+
| id | sname | sex | tid |
+------------+----------+------+------+
| 0000000001 | orna | 男 | NULL |
| 0000000002 | luscy | 女 | NULL |
| 0000000003 | wangwu | 男 | NULL |
| 0000000020 | zhangsan | 男 | NULL |
+------------+----------+------+------+
4 rows in set (0.00 sec)
- 用select 结果集创建一个表
mysql> select * from students;
+------------+-------+------+
| id | name | sex |
+------------+-------+------+
| 0000000001 | luscy | 女 |
| 0000000002 | lisi | 男 |
| 0000000003 | orna | 男 |
+------------+-------+------+
3 rows in set (0.00 sec) mysql> create table stu select * from students;
Query OK, 3 rows affected (0.33 sec)
Records: 3 Duplicates: 0 Warnings: 0 mysql> select * from stu;
+------------+-------+------+
| id | name | sex |
+------------+-------+------+
| 0000000001 | luscy | 女 |
| 0000000002 | lisi | 男 |
| 0000000003 | orna | 男 |
+------------+-------+------+
3 rows in set (0.00 sec)
- 修改表名
有两种方法可以修改表名。
mysql> rename table stu to st;
Query OK, 0 rows affected (0.17 sec) mysql> alter table st rename to s;
Query OK, 0 rows affected (0.23 sec)
- 删除表
drop table 表名;
drop table 表1,表2,表3.............. 表示可以同时删除多少个表。
- 修改表的列名称
在修改字段需要注意几点:
- 修改字段宽度只能改大,不能改小;
- 修改字段类型时,要兼容;
mysql> alter table s change name sname varchar(30);
Query OK, 3 rows affected (1.02 sec)
Records: 3 Duplicates: 0 Warnings: 0 mysql> select * from s;
+------------+-------+------+
| id | sname | sex |
+------------+-------+------+
| 0000000001 | luscy | 女 |
| 0000000002 | lisi | 男 |
| 0000000003 | orna | 男 |
+------------+-------+------+
3 rows in set (0.01 sec)
- 限定字段的取值范围
create table students(id int unsigned zerofill auto_increment primary key,
name varchar(20) not null,
sex enum('男','女') --指定取值范围。enum和set关键字同意
);
insert into students(name,sex) values('orna','男'); --插入数据成功 ------------------------------------插入数据时报错---------------------------------------
mysql> insert into students(name,sex) values('orna','未知');
ERROR 1265 (01000): Data truncated for column 'sex' at row 1
mysql> select * from students;
+------------+------+------+
| id | name | sex |
+------------+------+------+
| 0000000001 | orna | 男 |
+------------+------+------+
1 row in set (0.00 sec)
- 主建、外建和唯一
一个表只能有一个主键,但可以用多个字段建立一个组合主键。可以有多个外键和唯一约束。
- 增加主键
创建主键的两种方法:
--指定主键名
alter table s add constraint pk primary key(id);
--不指定主键名
alter table s add constraint primary key(id);
2.删除主键
mysql> desc s;
+-------+---------------------------+------+-----+------------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------------------------+------+-----+------------+-------+
| id | int(10) unsigned zerofill | NO | PRI | 0000000000 | |
| sname | varchar(30) | YES | | NULL | |
| sex | set('男','女') | YES | | NULL | |
+-------+---------------------------+------+-----+------------+-------+
3 rows in set (0.00 sec) mysql> alter table s drop primary key;
Query OK, 3 rows affected (0.82 sec)
Records: 3 Duplicates: 0 Warnings: 0 mysql> desc s;
+-------+---------------------------+------+-----+------------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------------------------+------+-----+------------+-------+
| id | int(10) unsigned zerofill | NO | | 0000000000 | |
| sname | varchar(30) | YES | | NULL | |
| sex | set('男','女') | YES | | NULL | |
+-------+---------------------------+------+-----+------------+-------+
3 rows in set (0.00 sec)
3.增加字段
在增加字段时,可以用first和after关键字,但没有before关键字。
mysql> alter table students add address varchar(50) not null after sex;
Query OK, 0 rows affected (0.49 sec)
Records: 0 Duplicates: 0 Warnings: 0 mysql> desc students;
+---------+---------------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+---------+---------------------------+------+-----+---------+----------------+
| id | int(10) unsigned zerofill | NO | PRI | NULL | auto_increment |
| name | varchar(20) | NO | | NULL | |
| sex | set('男','女') | YES | | NULL | |
| address | varchar(50) | NO | | NULL | |
+---------+---------------------------+------+-----+---------+----------------+
4 rows in set (0.00 sec)
4.删除字段
mysql> select * from s;
+------------+-------+------+
| id | sname | sex |
+------------+-------+------+
| 0000000001 | luscy | 女 |
| 0000000002 | lisi | 男 |
| 0000000003 | orna | 男 |
+------------+-------+------+
3 rows in set (0.00 sec) mysql> alter table s drop column sex;
Query OK, 0 rows affected (0.63 sec)
Records: 0 Duplicates: 0 Warnings: 0 mysql> desc s;
+-------+---------------------------+------+-----+------------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------------------------+------+-----+------------+-------+
| id | int(10) unsigned zerofill | NO | | 0000000000 | |
| sname | varchar(30) | YES | | NULL | |
+-------+---------------------------+------+-----+------------+-------+
2 rows in set (0.00 sec)
2.增加唯一约束
--创建表时增加唯一约束。
create table students(id int unsigned zerofill auto_increment primary key,
sname varchar(20) not null unique,
sex set('男','女'),
tid int unsigned
)engine=innodb default charset=utf8; --创建表后,再增加唯一约束。
alter table students add constraint uk unique(sname); mysql> desc students;
+-------+---------------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------------------------+------+-----+---------+----------------+
| id | int(10) unsigned zerofill | NO | PRI | NULL | auto_increment |
| sname | varchar(20) | NO | UNI | NULL | |
| sex | set('男','女') | YES | | NULL | |
| tid | int(10) unsigned | YES | | NULL | |
+-------+---------------------------+------+-----+---------+----------------+
4 rows in set (0.01 sec) --删除唯一约束。
mysql> alter table students drop index uk;
Query OK, 0 rows affected (0.26 sec)
Records: 0 Duplicates: 0 Warnings: 0
3.增加外键约束
alter table students add constraint fk foreign key(tid) references teachers(id);
--alter table students add constraint fk foreign key(tid) references teachers(id) on delete set null;表示删除外键引用的记录时把当前记录的外键值修改成空。
--alter table students add constraint fk foreign key(tid) references teachers(id) on delete cascade;表示删除外键引用的记录时把当前记录同时删除。
--alter table students add constraint fk foreign key(tid) references teachers(id) on delete set null on update cascade;表示删除外键引用的记录时把当前记录的外键值修
--改成空,或者修改引用记录同时修改外键引用字段。
mysql> desc students;
+-------+---------------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+---------------------------+------+-----+---------+----------------+
| id | int(10) unsigned zerofill | NO | PRI | NULL | auto_increment |
| sname | varchar(20) | NO | | NULL | |
| sex | set('男','女') | YES | | NULL | |
| tid | int(10) unsigned | YES | MUL | NULL | |
+-------+---------------------------+------+-----+---------+----------------+
4 rows in set (0.00 sec)
4.删除外键约束
alter table students drop foreign key fk;
alter table students drop index fk;
5.创建索引
mysql> create index sname on students(sname desc);
Query OK, 0 rows affected (0.27 sec)
Records: 0 Duplicates: 0 Warnings: 0
--alter table students add index(sname desc);
6.删除索引
alter table students drop index sname;
--drop index sname on students;
mysql的表和约束操作的更多相关文章
- MySQL入门第一天——概述、数据表与约束操作
一.概述 1.安装 初学MySQL,我们下载msi的安装版:http://dev.mysql.com/downloads/file.php?id=457403 安装的过程文字简述可以参考之前随笔:ht ...
- 对mysql数据库表的相关操作
虫师博客(Python使用MySQL数据库(新)): https://www.cnblogs.com/fnng/p/3565912.html 1.更改表的结构,增加一个字段放置新增的属性 alter ...
- mysql之表的查看操作
一 补充一些杂碎的知识 1 插入数据: create table 新表名(字段 数据类型[约束条间]...) select 字段... from 旧表名 create table 新表名(字段 数据类 ...
- python之路--MySQL 库,表的详细操作
一 库操作 数据库命名规则 可以由数字,字母,下划线,@, #, $ 区分大小写 唯一性 不能使用关键字如 create select 不能单独使用数字 最长128位 # 这些是对上次的补充. 二 ...
- mysql数据库表的查询操作-总结
转自:https://www.cnblogs.com/whgk/p/6149009.html 序言 1.MySQL表操作(创建表,查询表结构,更改表字段等), 2.MySQL的数据类型(CHAR.VA ...
- 二 mysql库表的详细操作
目录 1.库操作 1.创建数据库 2.数据库相关操作 2.表操作 1.存储引擎 2.表介绍 3.创建表 4.查看表结构 5.MySQL的基础数据类型 6.表的完整性约束 7.修改表 alter tab ...
- 最全MySQL数据库表的查询操作
序言 1.MySQL表操作(创建表,查询表结构,更改表字段等), 2.MySQL的数据类型(CHAR.VARCHAR.BLOB,等), 本节比较重要,对数据表数据进行查询操作,其中可能大家不熟悉的就对 ...
- MYSQL关于表的一些操作
mysqldump -u username -p dbname > dbname.sql 清空表数据 delete from xxxx; 插入一条数据 insert into tablename ...
- MySQL之表的约束
一 介绍 约束条件与数据类型的宽度一样,都是可选参数 作用:用于保证数据的完整性和一致性主要分为: PRIMARY KEY (PK) 标识该字段为该表的主键,可以唯一的标识记录 FOREIGN KEY ...
随机推荐
- Tornado长轮询和WebSocket
Http协议是一种请求响应式协议, 不允许服务端主动向客户端发送信息. 短轮询是一种简单的实现服务端推送消息的解决方案, 客户端以一定间隔自动向服务端发送刷新请求, 服务端返回要推送的消息作为响应. ...
- javaScript中用eval()方法转换json对象
var u = eval('('+user+')'); 1.对于服务器返回的JSON字符串,如果jQuery异步请求没做类型说明,或者以字符串方式接受,那么需要做一次对象化处理,方式不是太麻烦,就是将 ...
- VB里的 dim是什么意思?
Dim为Dimension的缩写,后面加上所需变量的名字As为变量指定类型程序运行时,Dim语句就根据变量类型为变量分配内存空间
- HTML5本地存储localStorage、sessionStorage基本用法、遍历操作、异常处理等
HTML5 的本地存储 API 中的 localStorage 与 sessionStorage 在使用方法上是相同的,区别在于 sessionStorage 在关闭页面后即被清空,而 localSt ...
- “Device eth0 does not seem to be present”解决办法
在KVM中克隆出新的CentOS虚拟机时,出现如下问题:# service network restartShutting down loopback insterface: [ OK ]Bringi ...
- 【原】公司P2P平台的功能拆分
银行回调:由原来写在PC门户项目中拆分开来,作为一个专门处理回调的项目,配置多个数据源,实时写入数据库. 定时回查:由原来写在PC后台管理项目中拆分开来,作为一个专门回查银行网关的项目. 请求银行:由 ...
- JVM GC总结
判断对象存活 引用计数算法 给对象中添加一个引用计数器,每当有一个地方引用它时,计数器就加1,引用失效时,计数器就减1:任何时刻计数器都为0的对象就是不可能再被使用的. 问题:无法解决对象之间的相互循 ...
- vue + element ui 表格自定义表头,提供线上demo
前言:工作中用到 vue+element ui 的前端框架,需要使用自定义表头,需要使用 re.转载请注明出处:https://www.cnblogs.com/yuxiaole/p/9710826.h ...
- 有 a - b < c 对Java安全性的思考
软件工程中,不论使用哪种开发语言,安全性一直是一个非常棘手却又重要的问题.安全性是软件开发领域永远的主题之一,而且随着互联网的蜂拥发展而带动的新技术的兴起与革命(比如近几年火起来的node.js,py ...
- mac 更新macOS Sierra 之后无法正常关机
参考网址h:ttps://www.zhihu.com/question/50940249 这里就简单记录一下,因为网上写的仔细的比较少,我也写一份,希望病友们可以更方便的找到解决办法 其实就是mysq ...