線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:2043
推到 Plurk!
推到 Facebook!

SQL子查询返回的值多于一个 请问如何调整?

答題得分者是:harpist
baby2321
初階會員


發表:52
回覆:165
積分:48
註冊:2005-06-11

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-05-08 22:07:06 IP:58.48.xxx.xxx 未訂閱
学员表:
学号 姓名 年龄 班级
101 张A 18 一班
102 张B 19 一班
201 李C 17 二班
202 王D 18 二班
301 张E 19 三班
302 吴F 19 三班
303 张G 19 三班
想以姓氏作检索 检索出 有该姓氏的 同班级的所有同学资料 并显示在DBGRID中
select * from 学员表 where 班级=(select 学员表.班级 from 学员表 where (学员表.姓名 like
'张' '%'))
执行 提示错误:子查询返回的值多于一个。当子查询跟随在 =、!=、<、<=、>、>= 之后,或子查询用作表达式时,这种情况是不允许的。
请问这里需要如何调整?

另:我又用游标处理了一下 查询分析器里都是OK的 但通过DBGRID显示 则只显示一班的记录 DBGRID没有显示三班的

谢谢大家

編輯記錄
baby2321 重新編輯於 2007-05-08 22:08:12, 註解 無‧
baby2321 重新編輯於 2007-05-08 22:10:45, 註解 無‧
baby2321 重新編輯於 2007-05-08 23:42:34, 註解 無‧
harpist
資深會員


發表:3
回覆:251
積分:430
註冊:2002-10-03

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-05-09 00:02:39 IP:211.74.xxx.xxx 未訂閱
你希望在DBGRID裡面同時出現一班跟三班那就過濾姓氏用班級去排序
<textarea class="sql" rows="10" cols="60" name="code"> select * from 学员表 where 学员表.姓名 like '张' '%' order by 学员表.班级 asc </textarea>
------
~§~迷時師渡,悟了自渡~§~
baby2321
初階會員


發表:52
回覆:165
積分:48
註冊:2005-06-11

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-05-09 00:48:55 IP:221.232.xxx.xxx 未訂閱
多谢harpist提示

已解决
編輯記錄
baby2321 重新編輯於 2007-05-09 00:59:54, 註解 無‧
eaglewolf
資深會員


發表:4
回覆:268
積分:429
註冊:2006-07-06

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-05-09 14:17:49 IP:211.75.xxx.xxx 訂閱
把 = 改成 in 
select * from 学员表 where 班级 in (select 学员表.班级 from 学员表 where (学员表.姓名 like '张%'))
或著用 join的方式
select T1.* from 学员表 T1 Join 学员表 T2 On T1.班級 = T2.班級 where T2.姓名 like '张%'

===================引 用 baby2321 文 章===================
学员表:
学号 姓名 年龄班级
101 张A 18一班
102张B19 一班
201李C 17 二班
202王D 18 二班
301张E 19 三班
302吴F 19 三班
303 张G19 三班
想以姓氏作检索 检索出 有该姓氏的 同班级的所有同学资料 并显示在DBGRID中
select * from 学员表 where 班级=(select 学员表.班级 from 学员表 where (学员表.姓名 like
'张' '%'))
执行 提示错误:子查询返回的值多于一个。当子查询跟随在 =、!=、<、<=、>、>= 之后,或子查询用作表达式时,这种情况是不允许的。
请问这里需要如何调整?

另:我又用游标处理了一下 查询分析器里都是OK的 但通过DBGRID显示 则只显示一班的记录 DBGRID没有显示三班的

谢谢大家

------
先查HELP
再查GOOGLE
最後才發問

沒人有義務替你解答問題
在標題或文章中標明很急
並不會增加網友回答速度

Developing Tool:
1.Delphi 6
2.Visual Studio 2005
3.Visual Studio 2008
DBMS:
MS-SQL
baby2321
初階會員


發表:52
回覆:165
積分:48
註冊:2005-06-11

發送簡訊給我
#5 引用回覆 回覆 發表時間:2007-05-09 15:58:47 IP:221.232.xxx.xxx 未訂閱
谢谢eaglewolf的回复
如阁下所言 确是如此解决

再次感谢
系統時間:2024-07-02 8:39:09
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!