多表查询是指基于两个和两个以上的表或是视图的查询.在实际应用中,查询单个表可能不能满足你的需求,(如显示sales部门位置和其员工的姓名),这种情况下需要使用到(dept表和emp表)
自连接是指在同一张表的连接查询
select * from emp where empno=(select mgr from emp where ename='ford')
子查询是指嵌入在其它sql查询语句中的select语句,也叫嵌套查询
单行子查询是 指只返回一行数据的子查询语句
select * from emp where deptno=(select deptno from emp where ename='smith')
多行子查询指返回多行数据的子查询 使用关键字 in
如果我们的一个子查询,返回的 结果是多列,就叫做列子查询
合并多个select语句的结果,可以使用集合 *** 作符 union,union all
重复值的原因:
一般就是连接的过程中连接条件出问题或者where语句有问题,所以最好检查一下,并且建议从简单的表开始关联,不要一次性关联太多表,会使逻辑复杂。
解决方法:
多表连接查询,且去掉重复列,使用 USING(),代码如下:
select * from (select * from school left join course USING (courseid)) e left join student USING (studentid)
select * from school left join course USING (courseid)相当于
select * from school left join course on school.courseid=course.courseid
扩展资料:
常用语句:
1、新建用户:
>CREATE USER name IDENTIFIED BY 'ssapdrow';
2、更改密码:
>SET PASSWORD FOR name=PASSWORD('fdddfd');
3、权限管理
>SHOW GRANTS FOR name;//查看name用户权限
>GRANT SELECT ON db_name.* TO name;//给name用户db_name数据库的所有权限
>REVOKE SELECT ON db_name.* TO name;//GRANT的反 *** 作,去除权限;
一、数据库 *** 作:
1、查看数据库:
>SHOW DATABASES
2、创建数据库:
>CREATE DATABASE db_name//db_name为数据库名
3、使用数据库:
>USE db_name
4、删除数据库:
>DROP DATABASE db_name
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)