注册 登录
编程论坛 SQL Server论坛

大家帮我看下这个SQl语句怎么写?

青格儿 发布于 2008-07-02 22:05, 2522 次点击
DECLARE @A TABLE(员工ID INT,姓名 char(16), 部门 varchar(50), 薪水 decimal(10,2))
INSERT INTO @A
SELECT 1,'小张','网络部',2500 UNION ALL
SELECT 2,'小李','市场部',3000 UNION ALL
SELECT 3,'小王','网络部',3000 UNION ALL
SELECT 4,'小周','市场部',2500 UNION ALL
SELECT 5,'新文秘','临时工',1000

declare @B table(员工ID int,地址 nvarchar(50),电话 char(13))

insert into @B
select 1,'小张的地址1','小张的电话1' union all
select 1,'小张的地址2','小张的电话2' union all
select 3,'小王的地址1','小王的电话1' union all
select 3,'小王的地址2','小王的电话2' union all
select 6,'前文秘的地址','前文秘的电话'


select A.员工ID,A.姓名+B.地址 from @A A inner join @B B on A.员工ID=B.员工ID

怎么查来这个:

1   小张 小张地址1,小张地址2
3   小王 小王地址1,小王地址2
……


请大家帮帮忙,万分感谢!!!我查不出来
19 回复
#2
青格儿2008-07-05 14:20
怎么没人理我?创建表,插入数据,我都用SQL语句列出来了。我只是想查出
1   小张 小张地址1,小张地址2
3   小王 小王地址1,小王地址2
……
这个结果,难道SQL语句实现不了吗?请高手指点下吧,我写好长时间了,都没写出来!
#3
tomtory2008-07-05 14:23
你可以用SQL SERVER带的视图 去生成SQL语句
你这个SQL语句生成得出来的哈
#4
smoon2008-07-07 14:40
楼上的说的对啊,用试图直接就拉出来了啊
#5
青格儿2008-07-08 09:19
生成不出来吧?我试过了,最多它把所有的记录都读出来了,但是出来的不是:
1   小张 小张地址1,小张地址2
3   小王 小王地址1,小王地址2
……
而是:
1   小张 小张地址1
1   小张 小张地址2
3   小王 小王地址1
3   小王 小王地址2
……
#6
tomtory2008-07-08 10:51
在聚合一下噻
晕晕
#7
tomtory2008-07-08 10:51
把里面相同的数据聚合成一条数据
#8
青格儿2008-07-08 11:44
呵呵,我太笨,不会聚合啊。你帮我聚下吧。先谢了。上面就是完整的表带数据。
#9
tomtory2008-07-08 15:15
先把你生成的查询SQL语句发上来的嘛!!
#10
青格儿2008-07-08 17:22
已经发上来了啊!

select A.员工ID,A.姓名+B.地址 from @A A inner join @B B on A.员工ID=B.员工ID
这句就是啊! 你把上面那代码一运行,就知道了。麻烦你了。帮我看看吧。
#11
tomtory2008-07-09 09:57
select A.员工ID,A.姓名+B.地址 from @A A inner join @B B on A.员工ID=B.员工ID  group by A.员工ID,A.姓名+B.地址
#12
青格儿2008-07-09 10:33
很感谢你回复我的贴子,帮我解决问题,可是你试了吗?你试试就知道了,出来的结果不是:
1   小张 小张地址1,小张地址2
3   小王 小王地址1,小王地址2
……

group by ,order by  我都试过,根本就不行啊!!
#13
青格儿2008-07-09 10:35
DECLARE @A TABLE(员工ID INT,姓名 char(16), 部门 varchar(50), 薪水 decimal(10,2))
INSERT INTO @A
SELECT 1,'小张','网络部',2500 UNION ALL
SELECT 2,'小李','市场部',3000 UNION ALL
SELECT 3,'小王','网络部',3000 UNION ALL
SELECT 4,'小周','市场部',2500 UNION ALL
SELECT 5,'新文秘','临时工',1000

declare @B table(员工ID int,地址 nvarchar(50),电话 char(13))

insert into @B
select 1,'小张的地址1','小张的电话1' union all
select 1,'小张的地址2','小张的电话2' union all
select 3,'小王的地址1','小王的电话1' union all
select 3,'小王的地址2','小王的电话2' union all
select 6,'前文秘的地址','前文秘的电话'

select A.员工ID,A.姓名+B.地址 from @A A inner join @B B on A.员工ID=B.员工ID  group by A.员工ID,A.姓名+B.地址

你把这些代码全放在查询分析器里运行一下,你就知道了。这样真得不行。
#14
tomtory2008-07-09 10:59
我晕  看到了  知道原因了

你查询的第二个字段  A.姓名+B.地址

这个是不能聚合的  里面的值不一样

[[it] 本帖最后由 tomtory 于 2008-7-9 11:59 编辑 [/it]]
#15
tomtory2008-07-09 11:01
1    小张              小张的地址1
1    小张              小张的地址2
3    小王              小王的地址1
3    小王              小王的地址2


这是查询出来的值

但是后面那个字段里面的值 是聚合不了得
你的地址那条信息始终不一样的啊!!
#16
tomtory2008-07-09 12:03
嘿嘿
看到你要的功能了 呵呵

这样啊
1   小张 小张地址1,小张地址2
3   小王 小王地址1,小王地址2

好像  在SQL里面是不能完成的吧
你这样查出来肯定是两条数据  
然后在sql里面是没有数组的
你只有在程序里面完成了
#17
青格儿2008-07-10 09:23
原来SQL真得不能完成啊!其实我的是三个表(为了好写点,我发贴子时改成了两个表,我想也许这样会好实现点,没想到还是实现不了?)

我要显示UserInfo在一个GridView里,其中有一列要求显示每个用户所有的角色。我没办法,用了最笨的方法,先绑定了两个表,最后又遍历了Gridview所有行,又绑定了第三个表才实现了我要的效果。但是我觉得遍历了Gridview所有行这次效率太低了吧,就没有别的办法了吗?
#18
jxyga1112008-07-11 17:25
改用臨時表吧
#19
青格儿2008-07-14 09:53
谢谢楼上的朋友。不太明白具体用临时表怎么做?能细说下吗?先谢谢了!

SQL这么强大,我想它可以查出来吧。也许也要游标吧?呵呵,游标我用得不好。不过,不论用什么只要是用SQL实现的就行。请各位高手帮帮我。
1