免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1842 | 回复: 8
打印 上一主题 下一主题

怎样把一个学生的2个志愿一次select出来 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-08-03 09:19 |只看该作者 |倒序浏览
数据库结构如下:
一个subject表,内有su_id和su_name
一个student表,内有stu_rel_su_id、stu_rel2_su_id和一些其它信息

目前的问题是:怎样把学生信息和第一志愿、第二志愿的名称一次都select出来,或者建一个更合理的数据库结构来实现这个目的。

论坛徽章:
0
2 [报告]
发表于 2005-08-03 09:41 |只看该作者

怎样把一个学生的2个志愿一次select出来

student 表里没有和subject关联的字段么?

论坛徽章:
0
3 [报告]
发表于 2005-08-03 16:41 |只看该作者

怎样把一个学生的2个志愿一次select出来

select  subject.subject,student.stu_rel_su_id from subject,student where name='studentname';

论坛徽章:
0
4 [报告]
发表于 2005-08-03 16:43 |只看该作者

怎样把一个学生的2个志愿一次select出来

select  subject.su_name,student.stu_rel_su_id from subject,student where name='studentname';
上个敲错了

论坛徽章:
0
5 [报告]
发表于 2005-08-04 01:45 |只看该作者

怎样把一个学生的2个志愿一次select出来

老兄,我想应该是这个样子的吧!

第一个表:
student   su_name  和 su_id
第二个表
subject    su_id,stu_rel_su_ids,tu_rel2_su_id 以及其他的信息

select的时候应该是:
select student.su_name,subject.stu_rel_su_ids,subject.tu_rel2_su_id
from student,subject
where su_name='studentname' & student.su_id=subject.su_id;

试试看,说不定行哟!

论坛徽章:
62
2016科比退役纪念章
日期:2016-06-28 17:45:06奥兰多魔术
日期:2015-05-04 22:47:40菠菜神灯
日期:2015-05-04 22:35:07菠菜神灯
日期:2015-05-04 22:35:02NBA季后赛大富翁
日期:2015-05-04 22:33:34NBA常规赛纪念章
日期:2015-05-04 22:32:032015年亚洲杯纪念徽章
日期:2015-04-14 16:54:452015年亚洲杯之朝鲜
日期:2015-03-19 23:03:16明尼苏达森林狼
日期:2015-03-16 21:51:152015小元宵徽章
日期:2015-03-06 15:57:202015年迎新春徽章
日期:2015-03-04 09:55:282015年辞旧岁徽章
日期:2015-03-03 16:54:15
6 [报告]
发表于 2005-08-04 09:12 |只看该作者

怎样把一个学生的2个志愿一次select出来

楼上几位别胡出主意

论坛徽章:
0
7 [报告]
发表于 2005-08-04 09:18 |只看该作者

怎样把一个学生的2个志愿一次select出来

原帖由 "ixiangjin" 发表:
老兄,我想应该是这个样子的吧!

第一个表:
student   su_name  和 su_id
第二个表
subject    su_id,stu_rel_su_ids,tu_rel2_su_id 以及其他的信息

select的时候应该是:
select student.su_name,subj..........


其实我就是这个意思,但是敲到where的时候就开始懒了~~

论坛徽章:
0
8 [报告]
发表于 2005-08-05 11:33 |只看该作者

怎样把一个学生的2个志愿一次select出来

楼上几位的方法肯定是行不通的,给的语句只是简单的表之间的关联。而现在的问题是一个多对多的关系,而且志愿还有顺序,如果没有数据冗余的话一个select估计是出不来。

论坛徽章:
0
9 [报告]
发表于 2005-08-05 13:49 |只看该作者

怎样把一个学生的2个志愿一次select出来

这个是一对多的问题,是一条三表连接的问题,
select t1.*,t2.su_name,t3.su_name  from student t1
left join subject t2 on t1.stu_rel_su_id=t2.su_id
left join subject t3 on t1.stu_rel2_su_id=t3.su_id
order by 1,2
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP