### SQL 会创建多表及多表的关系

本文探讨了SQL中如何创建和管理多表关系,重点介绍了外键约束在维护分类表和商品表关系中的作用。通过示例说明了一对多、多对多和一对一的建表原则,并解释了在删除操作时的注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SQL 会创建多表及多表的关系

需求:

分类表和商品表之间是不是有关系? 如果有关系,在数据库中如何表示这种关系

create table category(
  cid int primary key auto_increment,
  cname varchar(10),
  cdesc varchar(31)
);

insert into category values(null,'手机数码','电子产品,黑马生产');
insert into category values(null,'鞋靴箱包','江南皮鞋厂倾情打造');
insert into category values(null,'香烟酒水','黄鹤楼,茅台,二锅头');
insert into category values(null,'酸奶饼干','娃哈哈,蒙牛酸酸乳');
insert into category values(null,'馋嘴零食','瓜子花生,八宝粥,辣条');

select * from category;
select cname,cdesc from category;

--所有商品
1.商品ID
2.商品名称
3.商品的价格
4.生产日期
5.商品分类ID

商品和商品分类 : 所属关系
create table product(
	pid int primary key auto_increment,
  	pname varchar(10),
  	price double,
  	pdate timestamp,
  	cno int
);

insert into product values(null,'小米mix4',998,null,1);
insert into product values(null,'锤子',2888,null,1);
insert into product values(null,'阿迪王',99,null,2);
insert into product values(null,'老村长',88,null,3);
insert into product values(null,'劲酒',35,null,3);
insert into product values(null,'小熊饼干',1,null,4);
insert into product values(null,'卫龙辣条',1,null,5);
insert into product values(null,'旺旺大饼',1,null,5);

//插入数据会失败
insert into product values(null,'充气的',1,null,12);

技术分析:
  • 多表之间的关系如何来维护

    外键约束: foreign key

    • 给product中的这个cno 添加一个外键约束

      alter table product add foreign key(cno) references category(cid);

    • 自己挖坑

    • 从分类表中,删除分类为5信息,

      • delete from category where cid =5; //删除失败
      • 首先得去product表, 删除所有分类ID5 商品
  • 建数据库原则:

    • 通常情况下,一个项目/应用建一个数据库
  • 多表之间的建表原则

    • 一对多 : 商品和分类

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

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

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

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

      • 建表原则:

        • 将一对一的情况,当作是一对多情况处理,在任意一张表添加一个外键,并且这个外键要唯一,指向另外一张表
        • 直接将两张表合并成一张表
        • 将两张表的主键建立起连接,让两张表里面主键相等
      • 实际用途: 用的不是很多. (拆表操作 )

        • 相亲网站:
          • 个人信息 : 姓名,性别,年龄,身高,体重,三围,兴趣爱好,(年收入, 特长,学历, 职业, 择偶目标,要求)
          • 拆表操作 : 将个人的常用信息和不常用信息,减少表的臃肿,

  • 网上商城表实例的分析: 用户购物流程

  • 用户表 (用户的ID,用户名,密码,手机)

    create table user(
    	uid int primary key auto_increment,
      	username varchar(31),
      	password varchar(31),
      	phone  varchar(11)
    );
    
    insert into user values(1,'zhangsan','123','13811118888');
    
  • 订单表 (订单编号,总价,订单时间 ,地址,外键用户的ID)

      create table orders(
      	oid int primary key auto_increment,
        	sum int not null,
          otime timestamp,
        	address varchar(100),
        	uno int,
        	foreign key(uno) references user(uid)
      );
      insert into orders values(1,200,null,'黑马前台旁边小黑屋',1);
      insert into orders values(2,250,null,'黑马后台旁边1702',1);
    
  • 商品表 (商品ID, 商品名称,商品价格,外键cno)

    create table product(
    	pid int primary key auto_increment,
      	pname varchar(10),
      	price double,
      	cno int,
      	foreign key(cno) references category(cid)
    );
    
    insert into product values(null,'小米mix4',998,1);
    insert into product values(null,'锤子',2888,1);
    insert into product values(null,'阿迪王',99,2);
    insert into product values(null,'老村长',88,3);
    insert into product values(null,'劲酒',35,3);
    insert into product values(null,'小熊饼干',1,4);
    insert into product values(null,'卫龙辣条',1,5);
    insert into product values(null,'旺旺大饼',1,5);
    

  • 订单项: 中间表(订单ID,商品ID,商品数量,订单项总价)

    create table orderitem(
    	ono int,
      	pno int,
      	foreign key(ono) references orders(oid),
      	foreign key(pno) references product(pid),
      	ocount int,
      	subsum double
    );
    --给1号订单添加商品 200块钱的商品
    insert into orderitem values(1,7,100,100);
    insert into orderitem values(1,8,101,100);
    
    --给2号订单添加商品 250块钱的商品 ()
    insert into orderitem values(2,5,1,35);
    insert into orderitem values(2,3,3,99);
    

  • 商品分类表(分类ID,分类名称,分类描述)

    create table category(
    	cid int primary key auto_increment,
      	cname varchar(15),
      	cdesc varchar(100)
    );
    
    insert into category values(null,'手机数码','电子产品,黑马生产');
    insert into category values(null,'鞋靴箱包','江南皮鞋厂倾情打造');
    insert into category values(null,'香烟酒水','黄鹤楼,茅台,二锅头');
    insert into category values(null,'酸奶饼干','娃哈哈,蒙牛酸酸乳');
    insert into category values(null,'馋嘴零食','瓜子花生,八宝粥,辣条');
    
  • 多表之间的关系如何维护: 外键约束 : foreign key

  • 添加一个外键: alter table product add foreign key(cno) references category(cid);

    • ​ foreign key(cno) references category(cid)
    • 删除的时候, 先删除外键关联的所有数据,再才能删除分类的数据
  • 建表原则:

    • 一对多:
      • 建表原则: 在多的一方增加一个外键,指向一的一方
    • 多对多:
      • 建表原则: 将多对多转成一对多的关系,创建一张中间表
    • 一对一: 不常用, 拆表操作
      • 建表原则: 将两张表合并成一张表
        • 将两张表的主键建立起关系
        • 将一对一的关系当作一对多的关系去处理

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

  • 外键都是指向另外一张表的主键
  • 主键一张表只能有一个

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

  • 唯一约束不可以作为其它表的外键
  • 可以有多个唯一约束

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

多对多: 建表原则:

​ 拆成一对多

​ 创建一张中间表, 至少要有两个外键, 指向原来的表

一对一: 建表原则: 合并一张表, 将主键建立关系 , 将它当作一对多的情况来处理

  • 数据库客户端软件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值