添加点数据
insert into category(cid,cname) values(‘c001’,‘家电’);
insert into category(cid,cname) values(‘c002’,‘服饰’);
insert into category(cid,cname) values(‘c003’,‘化妆品’);
insert into product(pid,pname,price,category_id) values(‘p001’,‘联想’,‘5000’,‘c001’);
insert into product(pid,pname,price,category_id) values(‘p002’,‘海尔’,‘5000’,‘c001’);
insert into product(pid,pname,price,category_id) values(‘p003’,‘雷神’,‘5000’,‘c001’);
insert into product(pid,pname,price,category_id) values(‘p004’,‘JACK JONES’,‘800’,‘c002’);
insert into product(pid,pname,price,category_id) values(‘p005’,‘真维斯’,‘200’,‘c002’);
insert into product(pid,pname,price,category_id) values(‘p006’,‘花花公子’,‘440’,‘c002’);
insert into product(pid,pname,price,category_id) values(‘p007’,‘劲霸’,‘2000’,‘c002’);
insert into product(pid,pname,price,category_id) values(‘p008’,‘香奈儿’,‘800’,‘c003’);
insert into product(pid,pname,price,category_id) values(‘p009’,‘相宜本草’,‘200’,‘c003’);
最后一列 category_id 列在创建表的时候自己定义的,如果没有,则可以使用一下命令添加一列。
alter table product add category_id
链接两张表
alter table product add foreign key(category_id) references category(cid);
两张表已经关联,主表有外键约束。不能轻易删除主表数据,因为从表有他的记录。
要想解除关系,先删除从表对他有关系的数据删除,再删除主表数据。
使用外键的目的
保证数据的完整性。
注意事项
从表外键不能添加主表中不存在的记录。
主表不能删除从表中已经引用的记录。
表与表之间的关系
表语表之间的关系,说的就是表与表数据之间的关系。
一对多的关系
常见的实例:客户和订单,分类和商品,部门和员工。
一对多建表原则:在从表(多方)创建一个字段,字段作为外键指向主表的主键。
alter table 从表 add [constraint][外键名称] foreign key(从表外键在字段名) references 主表(主表的主键);
多对多的关系
常见的实例:学生和课程,商品和订单,演员和角色。
多对多关系建立表原则:需要创建第三张表,中间表中至少两个字段,这两个字段分别作为外键指向各自一方的主键。
建立关系
alter table stu_course add foreign key(sno) references stu(sid);
alter table stu_course add foreign key(sno) references course(cid);
一对一关系(了解)
在实际开发中应用不多,因为一对一可以创建成一张表。
两种建表原则:
外键唯一:主表的主键和从简的外键唯一,形成主外键关系,外键唯一 unique。
外键是主键:主表的主键和从表的主键,形成主外键关系。
多对多连接
实现如下表结构:
创建订单表
create table orders(
oid varchar(32) primary key,
totalprice double
);
创建经单项的表(中间表)
create table orderitem(
oid varchar(50),
pid varchar(50)
);
关联两张表
alter table orderitem add constraint orderitem_fk foreign key(oid) references orders(oid);
alter table orderitem add constraint orderitem1_fk foreign key(pid) references product(pid);
多表查询操作
1. 交叉连接查询(基本不会用到 - 得到的是两个表的乘积)
select * from A,B
select * from category,product;
内容是乱的!第一张表3条数据,第二张表9条数据,一共 3*9 = 27 条数据。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
最后的话
无论是哪家公司,都很重视Spring框架技术,重视基础,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。
同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,好了希望这篇文章对大家有帮助!
部分截图:
图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新**
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-vCaYVlpW-1711711099599)]
最后的话
无论是哪家公司,都很重视Spring框架技术,重视基础,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。
同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,好了希望这篇文章对大家有帮助!
部分截图:
[外链图片转存中…(img-iFS2gBmx-1711711099599)]