mysql(三)[通俗易懂]

mysql(三)[通俗易懂]1 多表查询:创建一个部门表和员工表并插入数据 查询员工的ID,姓名,部门的名称: 连接查询(内连接,左连接,右连接,全连接) 2约束 not null 非空约束 default 默认值约束 uniq

mysql(三)

1 多表查询:创建一个部门表和员工表并插入数据

代码块
use company;

#创建部门表
CREATE TABLE department (
id int PRIMARY key  auto_increment,
dep_name varchar(10) not null
);

#创建员工表
CREATE TABLE employee(
id int PRIMARY key auto_increment,
emp_name varchar(10) not null,
dep_id int
-- CONSTRAINT dep_id_fk  FOREIGN key (dep_id) REFERENCES company(id) on DELETE CASCADE on UPDATE CASCADE
#上面的外键约束没有也可以,外键约束不影响表与表之间关联,影响的是表插入数据的约束
);

#向部门表中插入数据
insert into  department(dep_name) VALUES ('网盟营销'),('大数据中心')

#向员工表中插入数据
insert into employee(emp_name,dep_id) VALUES('wangsiyu',1),('alex',2)

代码100分

查询员工的ID,姓名,部门的名称:

代码100分代码块
select employee.id,emp_name,dep_name from employee,department WHERE department.id=employee.dep_id;
注意:对于两个表都同名的字段,应该在查询该字段的前面加上对应的表,否则电脑不知道你这个字段是哪个表的

连接查询(内连接,左连接,右连接,全连接)

代码块
内连接:    只连接匹配的行

select * from employee inner join department on employee.dep_id=department.id;

左连接 显示左表的全部记录

select * from employee left join department on employee.dep_id=department.id;

右连接:显示右表的全部记录

select * from employee right join department on employee.dep_id=department.id;

全连接:显示两个表的全部记录,没有对应的就用空表示

select * from employee full join department on employee.dep_id=department.id;

连接查询

2约束

not null 非空约束

default 默认值约束

unique 唯一约束

primary key 主键约束

auto_increment 自增

foreign key 外键约束
别跑,点个赞再走

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10333.html

(0)
上一篇 2022-12-29
下一篇 2022-12-29

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注