日期:2014-05-18  浏览次数:20391 次

小弟有个SQL语句不会写了,请大神们帮帮忙。
两张表。
用户表:
id 用户名 标识
1 张三 1
2 李四 1
3 王五 2

信息表
id 用户id 用户名 性别
1 1 张三 男
2 2 李四 男
3 3 王五 女

----------------------------------------------------
条件是where 用户表.标识=1
我想查询出来的结果是

用户ID 用户名 性别
1 张三 男
2 李四 男

-----------------------------------------------------
请各位大神们指点,小弟不胜感激。

------解决方案--------------------
用户表t_User
信息表t_Info
select A.ID as UserID,
A.UserName,
B.Sex
from t_User A
Inner Join t_Info On A.ID=B.UserID
where A.Flag=1
------解决方案--------------------
SQL code

--> 测试数据: @用户表
declare @用户表 table (id int,用户名 varchar(4),标识 int)
insert into @用户表
select 1,'张三',1 union all
select 2,'李四',1 union all
select 3,'王五',2

--> 测试数据: @信息表
declare @信息表 table (id int,用户id int,用户名 varchar(4),性别 varchar(2))
insert into @信息表
select 1,1,'张三','男' union all
select 2,2,'李四','男' union all
select 3,3,'王五','女'

--第一种思路
select 
    b.用户id,b.用户名,b.性别 
from @用户表 a left join @信息表 b on a.id=b.用户id 
where a.标识=1

--第二种思路
select 
    b.用户id,b.用户名,b.性别 
from @信息表 b 
where (select 标识 from @用户表 a where a.id=b.用户id)=1

/*
用户id        用户名  性别
----------- ---- ----
1           张三   男
2           李四   男
*/

------解决方案--------------------
SQL code
select 
    b.用户id,b.用户名,b.性别 
from @用户表 a left join @信息表 b on a.id=b.用户id 
where a.标识=1