重复值的原因:
一般就是连接的过程中连接条件出问题或者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
SELECT
t.file_id
FROM
app_polly_file_labels t
WHERE
t.style = '清新'
or t.style = '甜美'
or t.style = '韩潮来袭'
GROUP BY t.file_id
HAVING count(t.file_id)=3
或者
SELECT
a.file_id
FROM
app_polly_file_labels a
INNER JOIN app_polly_file_labels b ON a.file_id = b.file_id
INNER JOIN app_polly_file_labels c ON a.file_id = c.file_id
WHERE
a.style ='清新'
AND b.style ='甜美'
AND c.style ='韩潮来袭'
扩展资料:
sql常用的复杂查询语句
一、选择指定的列
select Sno as 学号,Sname as 姓名 from student
select Sno,Sname from student
二、查询全部列
select * from student
三、对查询后的指定列进行命名
select Sname as 姓名,(2014-Sage) as 出生年 from student
select Sname ,(2014-Sage) from student
四、消除取值重复的行
select distinct Sno as 选修了课程的学生学号 from SC
select distinct Sno from SC
五、选择表中若干元组,满足条件的
select Sname as 学生姓名 from student where Sdept='IS'
参考链接:SQL语句大全
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)