首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >基于多条记录的复合主键查询结果

基于多条记录的复合主键查询结果
EN

Stack Overflow用户
提问于 2012-06-19 02:51:55
回答 1查看 1.5K关注 0票数 0

根据选定的主键从数据库中获取记录的最佳方式是什么?

我能够从网格视图中获取所选(选中)行的主键,现在需要从数据库中检索这些所选复合主键的相应记录。

如果行只使用一个主键,就会更容易。我可以只连接主键(逗号分隔),并在WHERE in子句中使用它。但是这些行使用了三个主键(int、int、string)

我正在考虑使用SELECT JOIN (每组主键一个select,然后连接所有select),但我不确定这是否是最优化的方式。

处理这个问题的最好方法是什么?

提前谢谢。

妮基

更新-无法回复个人评论,我可能还没有足够的权限,所以我将在这里更新帖子以澄清。

下面是我正在做的一个例子:

来自具有复合键的数据库表的数据:

代码语言:javascript
复制
TABLE1
KeyCol1 INT (Primary Key),
KeyCol2 STRING (Primary Key),
KeyCol3 INT (Primary Key),
Col4    Decimal,
Col5    STRING,
Other columns . . .

第1页,带GRIDVIEW 1:

代码语言:javascript
复制
Sel |KeyCol1 |KeyCol2 |KeyCol3 |Col4  |Col5          |Other Columns . . .
[ ] |100     |CODE1   |01      |10.05 |Description 1 |. . .
[/] |100     |CODE1   |02      | 5.03 |Description 2 |. . .
[ ] |100     |CODE2   |01      |12.45 |Description 4 |. . .
[/] |102     |CODE1   |01      |21.50 |Description 1 |. . .
[/] |102     |CODE2   |01      | 9.10 |Description 5 |. . .
[/] |102     |CODE3   |03      | 7.15 |Description 1 |. . .

。。。(其中选择列是一个复选框,并且/处于选中状态)

然后在单击按钮后(例如,"Cancel Records")在第1页上,我需要获取这些行,以便显示到另一个页面,如下所示:

第2页,带GRIDVIEW 2

代码语言:javascript
复制
KeyCol1 |KeyCol2 |KeyCol3 |Col4  |Other Colums  |Reason
100     |CODE1   |02      | 5.03 |. . .         |_______
102     |CODE1   |01      |21.50 |. . .         |_______
102     |CODE2   |01      | 9.10 |. . .         |_______
102     |CODE3   |03      | 7.15 |. . .         |_______

(其中原因列是文本框)

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-06-20 16:34:44

您可以在单个查询中为每三个in添加一个OR子句(即,为您的网格视图中的每个选定行添加OR子句)。例如:

从Table1 WHERE (KeyCol1=val1-1 AND KeyCol2=val1-2 AND KeyCol3=val1-3) OR (KeyCol1=val2-1 AND KeyCol2=val2-2 AND KeyCol3=val2-3)或.等

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11089170

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档