mysql数据库表结构与表约束
表结构操作:
添加单列:alter table tb_name add [column] col_name
添加一列: alter table `sudty` add `aaa` int;
添加多列:
指定添加在哪:默认添加在最后一列,用after+col_name可以添加在某一列之后
使用first可以添加第一列。
alter table `sudty` add `bbb` int after `name`;在sudty这个表的name后添加一列bbb。
alter table `sudty` add `科目` int first;
删除列:alter table sudty drop bbb;
删除多列:alter table sudty drop aaa,drop scx;
修改表:
修改age的数据类型:
alter table sudty modify `age` varchar(20);
修改age的列名为年龄:
alter table sudty change `age` `年龄` varchar(20);
修改表名sudty为school:
alter table sudty rename to school;
非空约束:not null
建表时约束:
建表后约束:
此时,id和name的Null值都变为NO了。有非空约束的列,传值进去的时候就必须传它。
唯一约束:
确保字段中的值的唯一: unique key
同not null一样,它可以在建表的时候:
删除唯一约束:
添加唯一约束:现在给tb 添加一列`name`,让后添加一个联合唯一:
此时,联合唯一的key名是id,所以删除只需要写:alter table tb drop key id;
insert into tb (id,name) values(1,'王五'),(2,'王五'); 注意两个联合起来才唯一,
即只要id和name不是两个同时相同就可以。
主键约束:
主键保证记录的唯一性, 唯一标识每一条数据主键自动为NOT NULL;
每张数据表只能存在
一个主键not null+unique key,
一个unique key 又是一个not null的时候,那么它被当做primary
key主键当一张表里没有一个主键的时候,第一个出现的非空且为唯一的列被视为有主键。
自然可以在建表的时候添加主键约束,下面讨论给表tb的id添加主键约束:
删除主键:
添加联合主键:任然只有一个主键(虽然有两个PRI)
删除联合主键和正常删除主键是一样的操作。
自增长AUTO_INCREMENT
自动编号,一般与主键组合使用。一个表里面只有一个自增默认情况下,起始值为1,
每次的增量为1。当插入记录时,如果为AUTO_INCREMENT
数据列明确指定了一个数值,则
会出现两种情况。
情况一,如果插入的值与已有的编号重复,则会出现出错信息,因为数据列的值必须
是唯一的;
情况二,如果插入的值大于已编号的值,则会把该插入到数据列中,并使在下一个编
号将从这个新值开始递增。也就是说,可以跳过一些编号。如果自增序列的最大值被删除
了,则在插入新记录时,该值被重用。(可以调大,不可以缩小)如果插入的值小于现有
的值且不重复,则会成功,但是下一个数据过来还是默认从最大的值开始增长。
默认约束:default
初始值设置,插入记录时,如果没有明确为字段赋值,则自动赋予默认值。
插入值:
此时表的详情:
删除default:
添加默认default
方法一:
方法二:
mysql数据库表结构与表约束的更多相关文章
- 用户中心mysql数据库表结构的脚本
/* Navicat MySQL Data Transfer Source Server : rm-m5e3xn7k26i026e75o.mysql.rds.aliyuncs.com Source S ...
- mysql数据库表结构导出
mysql数据库表结构导出 命令行下具体用法如下: mysqldump -u用戶名 -p密码 -d 数据库名 表名 > 脚本名; 导出整个数据库结构和数据 mysqldump -h localh ...
- 比较两个mysql数据库表结构的差异
需求来源:一个线上系统,一个开发系统,现在要把开发系统更新到线上,但是开发系统的数据库结构与线上的略有差异,所以需要找出两个数据库的表结构差异. 数据库表结构的差异 注:操作均在Linux系统下完成 ...
- 一个漂亮的输出MySql数据库表结构的PHP页面
经常为了方便和直观,我们会首先直接在数据库中设计出表,但是接下来又要将表的结构和设计编写在设计文档中,以便编码的时候可以直观的查询,一旦数据库表非常多,字段非常多的时候,这无疑是件非常郁闷的工作. 这 ...
- centos/windows服务器,Mysql数据库表结构损坏-已解决
[问题原因]服务器突然断电 [故障报告]数据库表结构损坏 [解决思路]进入强制恢复模式,备份库表及数据重建 故障发现 周末公司断电,周一启动数据库就直接报错了 查看日志 上面标记的log,明确表示是非 ...
- PHP快速获取MySQL数据库表结构
直接举例某个数据库中只有两个数据表,一个 test ,一个 xfp_keywords ,获取他们的数据库表结构. 此功能可以用于开发人员快速获取数据表结构通过获取的数据生成各种文件形式,用来快速理解数 ...
- PowerDesigner逆向生成MYSQL数据库表结构总结
由于日常数据建模经常使用PowerDesigner,使用逆向工程能更加快速的生成模型提高效率,所以总结使用如下: 1. 安装MYSQL的ODBC驱动 Connector/ODBC 5.1.1 ...
- 反向读取Mysql数据库表结构到PowerDesigner中
使用PowerDesigner挺长时间了,只是一些简单的表结构设计,因需要对当前数据库进行再设计,需要看一下数据库中所有的表,及表之间的关系,并重新修改表结构,因此需求就是怎么把数据库中的表结构反向生 ...
- powerDesigner如何动态显示mysql数据库表结构
原文链接:http://jingyan.baidu.com/article/e5c39bf5d64efa39d760333c.html 有时候,由于数据库中的表太多,主外键关系复杂,对数据库的非设计人 ...
随机推荐
- 【阿里聚安全·安全周刊】双十一背后的“霸下-七层流量清洗”系统| 大疆 VS “白帽子”,到底谁威胁了谁?
关键词:霸下-七层流量清洗系统丨大疆 VS "白帽子"丨抢购软件 "第一案"丨企业安全建设丨Aadhaar 数据泄漏丨朝鲜APT组织Lazarus丨31款违规A ...
- mybatis的那些事
转载请注明出处:http://www.cnblogs.com/yidaijiankuanzhongbuhui/p/7003993.html 用mybatis一年多了,一直是别人搭好框架,配置好各种配置 ...
- xml文件生成方式一(字符串拼接,将多实体类对象写入xml文件)
1.xml文件生成,拼接字符串使用StringBuffer或StringBuilder 2.拼接好后写入文件即可,将多个实体类写入xml文件 3.这种方式比较简单,但是操作也比较麻烦 4.下面是我的代 ...
- HTML5 给图形绘制阴影(绘制五角星示例)
几个属性 shadowOffsetX:阴影的横向位移量. shadowOffsetY:阴影的纵向位移量. shadowColor:阴影的颜色. shadowBlur:阴影的模糊范围. 属性说明 sha ...
- Webpack 2 视频教程 017 - Webpack 2 中分离打包项目代码与组件代码
原文发表于我的技术博客 这是我免费发布的高质量超清「Webpack 2 视频教程」. Webpack 作为目前前端开发必备的框架,Webpack 发布了 2.0 版本,此视频就是基于 2.0 的版本讲 ...
- 搭建subversion 服务器,并自动部署项目
1 subversion目录文件说明: *dav目录:是提供apache与mod_dav_svn使用的目录,让他们存储内部数据*db目录:就是所有版本控制的数据存放文件*hooks目录:放置hook脚 ...
- php 简单通用的日志记录方法
使用file_put_contents 方法来实现简单便捷的日志记录功能 方法1: // use \r\n for new line on windows, just \n on linux func ...
- Sql 两个表left join 查左表最时间最大的一条记录显示
http://bbs.csdn.net/topics/350135010 参考 select * from a aa left join b bb on aa.id=bb.cid and bb.ad ...
- 鸟哥的linux私房菜学习-(五)补充:重点回顾
为了避免瞬间断电造成的Linux系统危害,建议做为服务器的Linux主机应该加上不断电系统来持续提供稳定的电力: 默认的图形模式登陆中,可以选择语系以及作业阶段.作业阶段为多种窗口管理员软件所提供,如 ...
- 洛谷 P1485 火枪打怪
题目描述 LXL进入到了一片丛林,结果他发现有n只怪物排成一排站在他面前.LXL有一杆火枪能对付这些怪物.他知道从左至右数第i只怪物的血量是mi.现在LXL可以将一些子弹射向某个怪物.LXL可以控制他 ...