当前位置: 首页 > news >正文

泉州制作手机网站宁波seo搜索排名优化

泉州制作手机网站,宁波seo搜索排名优化,可以做网站吗,重庆网站建设齐重庆零臻科技一、数据库约束 约束:按照一定条件进行规范的做事; 表定义的时候,某些字段保存的数据需要按照一定的约束条件; 1.null约束 字段null:该字段可以为空;not null:该字段不能为空不指定的话就是…

一、数据库约束

约束:按照一定条件进行规范的做事;

表定义的时候,某些字段保存的数据需要按照一定的约束条件;

1.null约束

  • 字段null:该字段可以为空;not null:该字段不能为空
  • 不指定的话就是null

id int not null;

2.unique:唯一约束

表示某个字段,不能重复(实际可以使用多个字段来建立unique唯一约束)

null不进行unique唯一校验;

sn int unique;

当sn重复时便会报错

3.default:默认值约束

表示某个字段设置了default及默认值,插入的时候该列不插入,就会插入默认值。

显示的插入数据即使是null,默认值也不会生效

name varchar(20) default 'unkown';

插入的字段不使用name,才会插入默认值:

4.primary key:主键约束

主键一般用于某张表标识唯一的一条数据

  • primary key =not null unique

仅仅unique约束的字段,还可以保存多条null的数据,也不能标识唯一的数据

主键字段不插入或者插入重复的都会报错

 一张表一般都需要设计主键

如果使用整型主键还可以结合auto_increment,表示从1开始,++自增

 自增不是以最大值加1的方式,而是mysql记录了这个值来递增。

 再插入数据,id就可能不连续

5.foreign key:外键约束

用于设计表与表之间的关系

表1(主表:主键)-----表2(从表:外键):就可以建立表1和表2一对一或者一对多的关系

二、表的设计

数据库设计表关系

主表的主键关联从表的外键(建立外键,不一定非要使用主键来关联,只是常用主键和外键关联)

create table 主表(

  id int primary key auto_increment,

...

);

create table 从表(

  id int primary key auto_increment,

...

  主表_id int,

   foreign key (主表_id) references 主表(id)

);

上面两个表中 蓝色部分建立关系

foreign key (主表_id) references 主表id)--->

主表_id:从表的外键字段名

主表:主表的表名;

id:主表的关联字段名(一般使用主键)

1.一对一的关系

比如:人对身份证

id:主键

name:姓名

amount:存款

username:账号

password:密码

身份证

id:主键

身份证号:*******

住址:*******

......

user_id:外键

建立人的主键与身份证外键的联系

从现实看,其实可以设计成一张表,但是人这张表查询比较频繁,如果把身份证相关的字段也放在一起,那么比较频繁的又不获取身份证信息的查询效率就比较低。

设计为一对一关系的两张表目的是:

  1. 数据库表设计其实就是建模(建立一种对象模型)
  2. 解耦:模型之间的解耦
  3. 效率:不经常使用的数据,单独存储,效率会比较高

2.一对多的关系

班级表

班级id

班级名称

...

学生表

学生 id:主键

学生姓名

学号

班级id:外键

班级id就是班级表和学生表之间的关联

一对多其实是有方向的,包含:

(1)班级到学生:一对多,一个班级多个学生

(2)学生到班级,一对一,一个学生一个班级

3.多对多的关系

表设计的时候(这个多对多关系,在两张主表中没有外键体现):

(1)两张主表建立多对多关系

(2)使用一张单独的中间表来表示两张主表的多对多关系

学生和课程再某个业务发生后就可能产生关系:

考试:一个学生考多门课程,一门课程有多个学生考试

设计上使用中间表:

(1)两个外键:分别关联两张主表的主键

(2)还可能设计一些业务的字段,比如考试成绩

学生表和课程表是多对多的关系(逻辑上的多对多关系),主表没有关系的体系;

中间表(体现实际的多对多关系),两个外键其实就表现出多对多的关系;

插入数据:

 在MySQL中执行后:

 表结构上只有两个一对多关系;数据上,体现出两个一对多关系,及逻辑上的多对多关系;

  • 一个学生考多个试--->学生表:中间表=1:n
  • 一个课程有多个考试成绩--->课程表:中间表=1:m
  • 中间表(考试成绩表)--->学生:课程=n:m

三、新增

插入操作:insert into 表 select...from 表 where... order by ... limit;

使用场景:

(1)复制表

(2)提前准备一些统计的数据(统计的sql一般关联很多表,条件可能也很复杂,执行效率可能不高),很多系统就提前运行任务,将统计的数据准备在单独的一张表中

 把查询结果集返回的所有数据,按查询出来的字段顺序,插入到insert表给的字段。

http://www.yayakq.cn/news/30485/

相关文章:

  • 网站上登录系统制作广州建设网站方案
  • 电子商务网站建设与管理考试例题搜狗搜索网页版
  • 宁波做简单网站的建设厅网站的投诉可以哪里查
  • seo两个域名一个网站有影响吗帝国网站如何做中英文切换
  • wordpress私人建站主题龙岩kk网首页
  • 视频网站开发费用铜仁市住房和城乡建设局网站
  • 腾讯域名怎么做网站郑州建设网站设计
  • 怎么开发一个网站厦门软件外包公司
  • 个人做旅游网站的意义企业管理咨询工作内容
  • jquery 单页网站wordpress资源站
  • 做外贸网站效果图wordpress安卓客户端
  • 成都保障房中心官方网站免费游戏网站建设
  • 支付单页网站模板项目交流平台
  • 河北涿州市网站建设什么叫平台
  • 崇明专业网站建设住建城乡建设部网站证件查询
  • 网站开发结束语体育西网站开发设计
  • 山东网站建设最便宜做网站 参考文献
  • 网站建站网站建站自己开发一个网站多少钱
  • 建水网站建设宁波seo优化服务
  • 做网站算新媒体运营吗ui网页设计介绍
  • 网站建设设计细节如何自己设计装修效果图
  • 做网站流行的外贸网站建设如何做呢
  • 连云港做网站设计网站免费建站 图标
  • 如果做夺宝网站企业展厅策划设计公司排名
  • 网上做网站广告投放杭州网站推广方案平台
  • 联客易外贸网站建设推广上海中远建设 网站
  • wordpress使用百度云存储网站优化网站优化
  • 大庆城乡建设局网站首页流量查询中国移动官方网站
  • 涿州市建设局网站win7 iis 添加网站
  • 专业的南昌网站建设重庆装修公司全包价格