SQL多表操作
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多表操作的更多相关文章
- My Sql多表操作(转载)
DELETE 在Mysql4.0之后,mysql开始支持跨表delete. Mysql可以在一个sql语句中同时删除多表记录,也可以根据多个表之间的关系来删除某一个表中的记录. 假定我们有两张表:Pr ...
- SQL复制表操作
select * into tb1 from tb2 insert into tb1 (fld1, fld2) select fld1, 0 from tb2 where fld0='x' 以上两句 ...
- SQL server 表操作语句(原创)
CREATE TABLE [dbo].[test] ([id11] int NOT NULL ,[as] varchar(1) COLLATE Chinese_PRC_CI_AS NULL ,[asd ...
- sql 单表操作
前戏 --创建表 create table xxx( id int unsigned not null auto_increment primary key, name varchar(20) not ...
- 数据库_7_SQL基本操作——表操作
SQL基本操作——表操作 建表的过程就是声明列的过程. 表与字段是密不可分的. 一.新增数据表 create table [if not exists] 表名( 字段名字 数据类型, 字段名字 数据类 ...
- (转)Hibernate中的多表操作
http://blog.csdn.net/yerenyuan_pku/article/details/70556208 Hibernate中的多表操作 在实际开发中,我们不可能只是简简单单地去操作单表 ...
- Django ORM 多表操作
目录 Django ORM 多表操作 表模型 表关系 创建模型 逆向到表模型 插入数据 ORM 添加数据(添加外键) 一对多(外键 ForeignKey) 一对一 (OneToOneFeild) 多对 ...
- Sql Server系列:数据表操作
表是用来存储数据和操作数据的逻辑结构,用来组织和存储数据,关系数据库中的所有数据都表现为表的形式,数据表由行和列组成.SQL Server中的数据表分为临时表和永久表,临时表存储在tempdb系统数据 ...
- SQL server基础知识(表操作、数据约束、多表链接查询)
SQL server基础知识 一.基础知识 (1).存储结构:数据库->表->数据 (2).管理数据库 增加:create database 数据库名称 删除:drop database ...
随机推荐
- flask 数据库迁移的简单操作
1.目的:修改现有数据库的表结构,不改变数据库中现有的数据. 2.导包:from flask_migrate import Migrate, MigrateCommandfrom flask_scri ...
- JMeter中Ultimate Thread Group插件使用
JMeter下载地址: http://jmeter.apache.org/Ultimate Thread Group插件下载地址: https://jmeter-plugins.org/get/ 一 ...
- Spring Boot Logback日志配置
logback的使用: Logback的默认配置 如果配置文件 logback-test.xml 和 logback.xml 都不存在,那么 logback 默认地会调用BasicConfigurat ...
- rem,em,与px的比较用法
在Web中使用什么单位来定义页面的字体大小,至今天为止都还在激烈的争论着,有人说PX做为单位好,有人说EM优点多,还有人在说百分比方便,以至于出现了CSS Font-Size: em vs. px v ...
- 作业一 :关于C语言
C语言是计算机专业的基础课,同时也是计算机专业的第一个入门语言,学好C语言母庸质疑.就目前来看,在C语言中已经学习的内容有:基本运算符及表达式.输入输出函数.选择 结构程序设计.循环结构程序设计.数组 ...
- c——简单排序
1.交换排序 a.冒泡排序 #include <stdio.h> int main() { , , , , }, i, j, t; ; i>=; i--) { ; j<i; j ...
- [Jave - JDBC] executeUpdate & executeQuery & execute
1. executeUpdate 用於執行INSERT.UPDATE.DELETE語法,以及 DDL語句(如CREATE TABLE 和DROP TABLE). 返回值為受影響的行數or更新計數(整數 ...
- linux 软件应用
grub2 安装grub2到某分区 mount /mnt/dev /dev/sdb2 //这里选择你刚才分区的第二个分区 sudo grub-install --root-directory=/mnt ...
- Flagr 架构
来自官方文档 https://checkr.github.io/flagr/#/flagr_overview There are three components in the flagr, Flag ...
- day02 进制之间的转换and计算机编码叙述
一. 进制的转好技巧 二进制:0 1 八进制:0 1 2 3 4 5 6 7 十进制:0 1 2 3 4 5 6 7 8 9 十六进制:0 1 2 3 4 5 6 7 8 9 A B C D E ...