1.多表之间的建表原则

  一对多:商品和分类

    建表原则:在多的一方添加一个外键,指向一的一方的主键

  多对多:老师和学生,学生和课程

    建表原则:建立一张中间表,将多对多的关系,拆分成一对多的关系,中间表至少要有两个外键,分别指向原来的两张表

  一对一:班级和班长,公民和身份证,国家和国旗

    建表原则:  

      将一对一的情况,当做是一对多的情况处理,在任意一张表添加一个外键,并且这个外键要唯一指向另外一张表

      直接将两张表合并成一张表

      将两张表的主键建立起连接,让两张表里面的主键相等

    多表之间的关系如何维护:外键约束:foreign key

      添加一个外键:alter table 表名 add foreign key(列名) references 表名(列名);

        创建时添加:foreign key(列名) reference 表名(列名)

        删除的时候,先删除外键关联的所有数据,再才能删除分类的数据

    主键约束:默认就是不能为空,唯一

      外键都是指向另外一张表的主键

      主键一张表只能有一个

    唯一约束:列里面的内容,必须是唯一,不能出现重复的情况,可以为空

      唯一约束不可以作为其他表的外键

      可以有多个唯一约束

2.多表查询内链接

  内连接查询:

    隐式内链接:

      select * from 表名 p,表名 c where p.cno=c.cid;

    显示内链接:

      select * from 表名 p inner join 表名 c on p.cno=c.cid;

    区别:

      隐式内链接:在查询出结果的基础上去做的where条件过滤

      显示内链接:带着条件去查询结果,执行效率要高

3.多表外连接查询;

    左外连接;  

      会将左表中的所有元素都查询出来,如果右表中没有对应的数据,用NULL代替

      select * from 表名 p left outer join 表名 c on p.列名(外键约束)=c.列名;

    右外连接:

      会将右表所有的数据都查询出来,如果左表中没有对应的数据的话,用NULL代替

      select * from 表名 p right outer join 表名 c on p.列名(外键约束)=c.列名;

4.分页查询

  每页数据3

  起始索引从0

  第1页:0

  第2页:3

    起始索引;index代表显示第几页

    每页显示3条数据

    starindex=(index-1)*3

  第一个参数是索引

  第二个参数每页是显示的个数

  eg:select * from 表名 limit 0.3;

    select * from 表名 limit 3,3;

5.子查询

  select * from product where

  

SQL多表操作的更多相关文章

  1. My Sql多表操作(转载)

    DELETE 在Mysql4.0之后,mysql开始支持跨表delete. Mysql可以在一个sql语句中同时删除多表记录,也可以根据多个表之间的关系来删除某一个表中的记录. 假定我们有两张表:Pr ...

  2. SQL复制表操作

    select * into tb1 from tb2 insert into tb1 (fld1, fld2)  select fld1, 0 from tb2 where fld0='x' 以上两句 ...

  3. SQL server 表操作语句(原创)

    CREATE TABLE [dbo].[test] ([id11] int NOT NULL ,[as] varchar(1) COLLATE Chinese_PRC_CI_AS NULL ,[asd ...

  4. sql 单表操作

    前戏 --创建表 create table xxx( id int unsigned not null auto_increment primary key, name varchar(20) not ...

  5. 数据库_7_SQL基本操作——表操作

    SQL基本操作——表操作 建表的过程就是声明列的过程. 表与字段是密不可分的. 一.新增数据表 create table [if not exists] 表名( 字段名字 数据类型, 字段名字 数据类 ...

  6. (转)Hibernate中的多表操作

    http://blog.csdn.net/yerenyuan_pku/article/details/70556208 Hibernate中的多表操作 在实际开发中,我们不可能只是简简单单地去操作单表 ...

  7. Django ORM 多表操作

    目录 Django ORM 多表操作 表模型 表关系 创建模型 逆向到表模型 插入数据 ORM 添加数据(添加外键) 一对多(外键 ForeignKey) 一对一 (OneToOneFeild) 多对 ...

  8. Sql Server系列:数据表操作

    表是用来存储数据和操作数据的逻辑结构,用来组织和存储数据,关系数据库中的所有数据都表现为表的形式,数据表由行和列组成.SQL Server中的数据表分为临时表和永久表,临时表存储在tempdb系统数据 ...

  9. SQL server基础知识(表操作、数据约束、多表链接查询)

    SQL server基础知识 一.基础知识 (1).存储结构:数据库->表->数据 (2).管理数据库 增加:create database 数据库名称 删除:drop database ...

随机推荐

  1. C++报错

    编译的时候会报如下错误:warning: ISO C++11 does not allow conversion from string literal to 'char *' [-Wwritable ...

  2. Axure RP 介绍

    原型设计是将想法转变为设计过程中至关重要的一环.经常有设计师小伙伴可能会问到,“哪个原型设计工具是最好的呢”?实际上这是一种错误的提问方式,尤其是在当下原型工具种类繁多,针对不同需求各有优势的大环境中 ...

  3. ELK 起航

    ELK与我 我在2017年8月份第一次听说ELK并搭建了一次,当时看到KIBANA页面超级炫酷非常激动.现在已经过去了四个月了,现在的情况不像刚开始哪有无知了.现在是要应用到实际的项目中.首先说一下整 ...

  4. linux下禁用网卡的启用网卡的一些方法

    第一种方法: 这种方法主要是在不重启的情况下会一直生效,适用于服务器. #禁用网卡eth0 sudo ifconfig eth0 down #启用网卡eth0 sudo ifconfig eth0 u ...

  5. Centos系统快速添加yum源

    我常用的yum源如下: 阿里云yum源:http://mirrors.aliyun.com/repo/Centos-7.repo 小红帽yum源:https://dl.fedoraproject.or ...

  6. 利用类的反射导入excel示例

    直接上代码 1.页面展示 <div class="panel-heading font-bold text-center"> <i class="fa ...

  7. himm的使用

    1.设置管脚复用 himm 0x200F0100 1 himm 0x200F0104 1 2.设置GPIO_DIR himm 0x201C0400 0xff 3.设置GPIO_DATA himm 0x ...

  8. 为毛GPU Cache不能移动顶点?

    这篇文章属于典型的剥洋葱文,由表及里,逐步引入新的知识点,挖掘最本质的原因.这篇文的逻辑是先假设再证明,按照这个思路去阅读会比较轻松. Maya里的GPU Cache导入的几何体为什么不能编辑顶点?这 ...

  9. 在Vue组件中获取全局的点击事件

    // 定义全局点击函数 Vue.prototype.globalClick = function (callback) { document.getElementById('main').onclic ...

  10. IDEA下调试和运行Hadoop程序例子

    准备 配置好JDK和Hadoop环境, 在IDEA中建立maven项目,建立后的目录结构为: 修改pom..xml引入相关支持: <?xml version="1.0" en ...