联表查询的问题?

airermeng 2008-09-18 05:29:56
有一个学生在线学习系统,要实现学生消息收件箱的功能,老师和学生都可以给某个学生发消息,学生进入消息收件箱的的时候要能同时列表显示老师和同学发过来的消息,要显示的字段如下:
消息主题,发消息人的姓名,发消息的时间

老师用户是一张表(Tteacher),学生用户也是一张表(Tstudent),2张表互相独立。

消息收件箱的表(Tmsg)的结构如下:
id,subject(主题),body(消息内容),key_id(发送人的id,教师用户id或者学生用户id),flag(1表示发送人是教师,2表示发送人是学生),send_time(发送消息时间)

问题是:发送人有可能是老师也有可能是学生,请问这儿的表怎么连?或者表的结构怎么改进比较好?
...全文
209 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
PurSpary 2008-09-20
  • 打赏
  • 举报
回复
Create Table Tteacher(id int ,name varchar(10))
insert into Tteacher values(1,'李明')
insert into Tteacher values(2,'王洪')
insert into Tteacher values(3,'张丽')

Create Table Tstudent(id int ,name varchar(10))
insert into Tstudent values(1,'王五')
insert into Tstudent values(2,'张三')
insert into Tstudent values(3,'李四')


create table Tmsg(id int,subject nvarchar(128),body nvarchar(1000),key_id int,flag int)
insert into Tmsg values(1,'你好','明天去你家家访。',1,1)
insert into Tmsg values(1,'你好','明天去打球。',2,2)
insert into Tmsg values(1,'你好','星期天一起去野营?',1,2)
insert into Tmsg values(1,'你好','明天下午你到我办公室一下。',2,1)
insert into Tmsg values(1,'你好','为什么不交作业',3,1)

Select * from Tmsg
select * from Tteacher
select * from Tstudent

----使用Case语句处理
Select id,subject,body,Case when flag=1 then (select name from Tteacher where id=key_id)+'老师' else (select name from Tstudent where id=key_id)+'同学' end sender
from Tmsg

----使用连接和Case语句处理
Select m.id,m.subject,m.body,m.flag,case when m.flag=1 then t.name+'老师' when m.flag=2 then s.name+'同学' end Sender
from Tmsg m left join Tteacher t on m.flag=1 and m.key_id=t.id
left join Tstudent s on m.flag=2 and m.key_id=s.id


当然还可以用其它的方式解决,在此就不再更出。
qinhl99 2008-09-20
  • 打赏
  • 举报
回复
个人觉得放到一张表里面比较好,再加一个字段区分学生/教师.
同意!

select m.subject as 主题,isnull(t.name,s,name) as 发消息人的姓名,m.send_time as 发消息的时间
from Tmsg m
left join Tteacher t on m.flag=1 and m.key_id=t.id
left join Tstudent s on m.flag=2 and m.key_id=s.id
where 其他条件

正确的
gulunhua 2008-09-20
  • 打赏
  • 举报
回复
最后的一句也可以写成这样:

select j.context,j.flagid,(case j.flag when 1 then (select t.tname from @teacher t where t.sid=j.flagid) else (select s.sname from @student s where s.sid=j.sid) end) as '发送者'
from @join j


运行结果是:
context flagid 发送者
-------------------- ----------- --------------------
hou are you 1 stu1
hello 2 tea2

(所影响的行数为 2 行)

airermeng 2008-09-19
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 dawugui 的回复:]
flag(1表示发送人是教师,2表示发送人是学生)

把这里用case 语句不就行了吗?
[/Quote]

能麻烦写一下sql吗
gulunhua 2008-09-19
  • 打赏
  • 举报
回复
呵呵,这个我写的,能正确运行,对你提供的数据库结构稍微简化了一下:

declare @teacher table(sid int identity,tname varchar(20))

insert into @teacher
select 'tea1'
union all
select 'tea2'

select * from @teacher--显示一下插入的教师信息


declare @student table(sid int identity,sname varchar(20))

insert into @student
select 'stu1'
union all
select 'stu2'

select * from @student--显示一下插入的学生信息

declare @join table(sid int identity,context varchar(20),flagid int,flag int)
insert into @join
select 'hou are you',1,2
union all
select 'hello',2,1

select * from @join--显示一下消息信息,join表里放了消息

--下面用了case语句来表明了,是老师发的消息,还是其他同学发的消息
select j.flagid as '消息编号',(case flag when 1 then '教师('+t.tname+')发的消息:'+context else '学生('+s.sname+')发的消息:'+context end) as '消息内容'
from @join j,@teacher t,@student s
where j.flagid=t.sid and j.flagid=s.sid


运行结果:

(所影响的行数为 2 行)

sid tname
----------- --------------------
1 tea1
2 tea2

(所影响的行数为 2 行)


(所影响的行数为 2 行)

sid sname
----------- --------------------
1 stu1
2 stu2

(所影响的行数为 2 行)


(所影响的行数为 2 行)

sid context flagid flag
----------- -------------------- ----------- -----------
1 hou are you 1 2
2 hello 2 1

(所影响的行数为 2 行)

消息编号 消息内容
----------- -------------------------------------------------------
1 学生(stu1)发的消息:hou are you
2 教师(tea2)发的消息:hello

(所影响的行数为 2 行)



  • 打赏
  • 举报
回复
欢迎光临这儿,有很多数据库与.NET的知道,来看吧....
http://blog.csdn.net/chinahuyong
infohzc 2008-09-18
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 sdhylj 的回复:]
个人觉得放到一张表里面比较好,再加一个字段区分学生/教师.
[/Quote]

同意 ,不要给自己增加不必要的麻烦

dawugui 2008-09-18
  • 打赏
  • 举报
回复
flag(1表示发送人是教师,2表示发送人是学生)

把这里用case 语句不就行了吗?
青锋-SS 2008-09-18
  • 打赏
  • 举报
回复
结构不一样就不能合并,在查询语句上下功夫吧.
airermeng 2008-09-18
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 Haiwer 的回复:]
SQL codeselect m.subject as 主题,isnull(t.name,s,name) as 发消息人的姓名,m.send_time as 发消息的时间
from Tmsg m
left join Tteacher t on m.flag=1 and m.key_id=t.id
left join Tstudent s on m.flag=2 and m.key_id=s.id
where 其他条件
[/Quote]

是学生表和教师表合并到一个表吗?教师和学生很多属性差异很大的。
最近作个项目涉及到多个不同对象之间的相同操作,就比如多个不同的对象给学生发信息一样,烦死了,不知道各位高手在处理这种情况的时候都如何处理的?
hyqwan11112 2008-09-18
  • 打赏
  • 举报
回复
select m.subject as 主题,isnull(t.name,s,name) as 发消息人的姓名,m.send_time as 发消息的时间 
from Tmsg m
left join Tteacher t on m.flag=1 and m.key_id=t.id
left join Tstudent s on m.flag=2 and m.key_id=s.id
where 其他条件
jacklinchen 2008-09-18
  • 打赏
  • 举报
回复
select m.subject 消息主题,isnull(t.name,s.name) 发消息人的姓名,m.send_time 发消息的时间
from Tmsg m
left join Tteacher t on m.flag=1 and m.key_id=t.id
left join Tstudent s on m.flag=2 and m.key_id=s.id
青锋-SS 2008-09-18
  • 打赏
  • 举报
回复
个人觉得放到一张表里面比较好,再加一个字段区分学生/教师.
昵称被占用了 2008-09-18
  • 打赏
  • 举报
回复
select m.subject as 主题,isnull(t.name,s,name) as 发消息人的姓名,m.send_time as 发消息的时间 
from Tmsg m
left join Tteacher t on m.flag=1 and m.key_id=t.id
left join Tstudent s on m.flag=2 and m.key_id=s.id
where 其他条件

22,209

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧