表结构操作:

  添加单列: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数据库表结构与表约束的更多相关文章

  1. 用户中心mysql数据库表结构的脚本

    /* Navicat MySQL Data Transfer Source Server : rm-m5e3xn7k26i026e75o.mysql.rds.aliyuncs.com Source S ...

  2. mysql数据库表结构导出

    mysql数据库表结构导出 命令行下具体用法如下: mysqldump -u用戶名 -p密码 -d 数据库名 表名 > 脚本名; 导出整个数据库结构和数据 mysqldump -h localh ...

  3. 比较两个mysql数据库表结构的差异

    需求来源:一个线上系统,一个开发系统,现在要把开发系统更新到线上,但是开发系统的数据库结构与线上的略有差异,所以需要找出两个数据库的表结构差异. 数据库表结构的差异 注:操作均在Linux系统下完成 ...

  4. 一个漂亮的输出MySql数据库表结构的PHP页面

    经常为了方便和直观,我们会首先直接在数据库中设计出表,但是接下来又要将表的结构和设计编写在设计文档中,以便编码的时候可以直观的查询,一旦数据库表非常多,字段非常多的时候,这无疑是件非常郁闷的工作. 这 ...

  5. centos/windows服务器,Mysql数据库表结构损坏-已解决

    [问题原因]服务器突然断电 [故障报告]数据库表结构损坏 [解决思路]进入强制恢复模式,备份库表及数据重建 故障发现 周末公司断电,周一启动数据库就直接报错了 查看日志 上面标记的log,明确表示是非 ...

  6. PHP快速获取MySQL数据库表结构

    直接举例某个数据库中只有两个数据表,一个 test ,一个 xfp_keywords ,获取他们的数据库表结构. 此功能可以用于开发人员快速获取数据表结构通过获取的数据生成各种文件形式,用来快速理解数 ...

  7. PowerDesigner逆向生成MYSQL数据库表结构总结

    由于日常数据建模经常使用PowerDesigner,使用逆向工程能更加快速的生成模型提高效率,所以总结使用如下: 1.      安装MYSQL的ODBC驱动 Connector/ODBC 5.1.1 ...

  8. 反向读取Mysql数据库表结构到PowerDesigner中

    使用PowerDesigner挺长时间了,只是一些简单的表结构设计,因需要对当前数据库进行再设计,需要看一下数据库中所有的表,及表之间的关系,并重新修改表结构,因此需求就是怎么把数据库中的表结构反向生 ...

  9. powerDesigner如何动态显示mysql数据库表结构

    原文链接:http://jingyan.baidu.com/article/e5c39bf5d64efa39d760333c.html 有时候,由于数据库中的表太多,主外键关系复杂,对数据库的非设计人 ...

随机推荐

  1. python爬虫入门学习

    近期写的一个爬虫的Demo,只是简单的用了几个函数.实现了简单的爬取网页的功能(以途牛为例). import urllib2 import re import urlparse import robo ...

  2. 45、SQL逻辑查询语句执行顺序

    一 SELECT语句关键字的定义顺序 SELECT DISTINCT <select_list> FROM <left_table> <join_type> JOI ...

  3. iOS tableViewCell 在cell赋值、网络加载照片位置偏移大小错乱,做一个类似qq列表的tableview 更新3

    更新3: 问题 加载慢!(一时间给的处理负载过大,要分散)在下载图片,判断状态后 对每个cell对图片灰置图片处理保存,影响了主线程的操作 :上拉加载时,无法上下滑动tableview 无法点击cel ...

  4. Keras的安装与配置

    Keras是由Python编写的基于Tensorflow或Theano的一个高层神经网络API.具有高度模块化,极简,可扩充等特性.能够实现简易和快速的原型设计,支持CNN和RNN或者两者的结合,可以 ...

  5. ADODB.Connection、ADODB.RecordSet

    1.数据库连接对象(ADODB. Connection)该对象用于与ODBC数据库建立连接,所有对数据库的操作均通过该连接进行.数据库连接对象ADODB. Connection的作用象Delphi中的 ...

  6. hibernate 3.6.10 maven pom.xml

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  7. Coursera深度学习(DeepLearning.ai)编程题&笔记

    因为是Jupyter Notebook的形式,所以不方便在博客中展示,具体可在我的github上查看. 第一章 Neural Network & DeepLearning week2 Logi ...

  8. JVM类加载机制以及类缓存问题的处理

    一:JVM类加载机制 和 类缓存问题的处理 当一个java项目启动的时候,JVM会找到main方法,根据对象之间的调用来对class文件和所引用的jar包中的class文件进行加载(其步骤分为加载.验 ...

  9. Docker(十三):OpenStack部署Docker集群

    1.介绍 本教程使用Compose.Machine.Swarm工具把WordPress部署在OpenStack上. 本节采用Consul作为Swarm的Discovery Service模块,要利用C ...

  10. java进程脱离终端运行

    关于 java 进程脱离终端放入后台运行的问题,首先想到是使用nohup命令: 研究了一下tomcat启动脚本.jenkins.war启动方式以及其他linux命令,结论是在目前的linux系统上不使 ...