vb SQL多表联合查询问题(Access数据库表)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vb SQL多表联合查询问题(Access数据库表)相关的知识,希望对你有一定的参考价值。

联合查询不是你那么用的,联合查询是用于字段的联合,也就是会横向扩展表。
例如A表中会有人物id,姓名,年龄等,而b表中会有每个人每次考试的成绩,也就是成绩id,成绩分数,人物id。
这时如果要查询什么人(姓名)得了多少分,就需要用联合查询了。也就是将成绩表横向扩展出一栏姓名出来。
你这种情况应该把数据放在一个表里比较好点。
如果实在不希望改数据库,那么有这么两种办法:
1.子查询:就像badkano
回答的。不过那个new_table
名称要你自己改的。不能原样不动。这个表你自己根据那几个表的结构建,你不是说那几个表完全一样吗。
2.在程序代码中用循环语句分几次查询,最后把查询结果合到一块。
3.用语句建立一个临时表,将那些表的内容都查询到临时表里面。
参考技术A Adodc1.RecordSource
=
"select
new_table.编号,new_table.地址,new_table.名称,new_table.其它
from
(select
*
from
a
union
all
select
*
from
b
union
all
select
*
from
c
union
all
select
*
from
d
union
all
select
*
from
e)
as
new_table
名称
Like
"
&
"'"
&
text1.text
&
"'"
----补充---
new_table不是新建的表,只是给那括号里的查询起一个别名
要不可以改成
Adodc1.RecordSource
=
"select
new_table.编号,new_table.地址,new_table.名称,new_table.其它
from
(select
*
from
a
union
all
select
*
from
b
union
all
select
*
from
c
union
all
select
*
from
d
union
all
select
*
from
e)
as
new_table
where
名称
Like
"
&
"'"
&
text1.text
&
"'"
---补充---
少写了个where

SharePoint 列表多表联合查询

在SharePoint平台二次开发中,我们有时需要涉及多表关联查询展示多列表中的不同字段信息;SharePoint和Sql数据表一样,也支持多表联合查询,但是不像Sql语句那样简单,有一定的局限性,需要使用SPQuery的Joins属性来完成。

  联合查询的前提条件:

  1、子列表必须采用查阅项进行关联主表;

  

  下面,我们通过一个简单的例子,为大家演示一下如何使用SPQuery通过查阅项字段来进行两个列表的联合查询。

  1、创建主列表,City是城市;子列Address,是地址,子列表新增加查阅项CityLook进行关联,如下表所示:

   

    

  2、执行查询语句:

 1 string SiteUrl = Microsoft.SharePoint.SPContext.Current.Site.Url ;
 2         using (SPSite site = new SPSite(SiteUrl))
 3         {
 4             using (SPWeb web = site.OpenWeb("/Test"))
 5             {
 6                 SPQuery query = new SPQuery();
 7                 //Joins属性,这里有INNER和LEFT两种方式连接,均可查询,而且支持多表连接;
 8                 query.Joins = "<Join Type=\'INNER\' ListAlias=\'City\'>" +
 9                               "<Eq>" +
10                               "<FieldRef Name=\'CityLook\' RefType=\'ID\'/>" +
11                               "<FieldRef List=\'City\' Name=\'ID\'/>" +
12                               "</Eq>" +
13                               "</Join>";
14 
15                  
16                 //设置关联的查阅项字段
17                 query.ProjectedFields = "<Field Name=\'CityDescription\' Type=\'Lookup\' List=\'City\' ShowField=\'Description\'/>" +
18                                         "<Field Name=\'CityCode1\' Type=\'Lookup\' List=\'City\' ShowField=\'Code\'/>";
19                 //设置需要显示的字段
20                 query.ViewFields = "<FieldRef Name=\'ID\'/>" +
21                                    "<FieldRef Name=\'Title\'/>" +
22                                    "<FieldRef Name=\'CityCode\'/>" +
23                                    "<FieldRef Name=\'CityLook\'/>" +
24                                    "<FieldRef Name=\'CityCode1\'/>" +
25                                    "<FieldRef Name=\'CityDescription\'/>";
26 
27                 //query.Query = "<Where><Eq><FieldRef Name=\'CityCode\'/><Value Type=\'Text\'>XM</Value></Eq></Where>";
28                 //查阅项查询,采用ID值进行查询
29                 query.Query = "<Where><Eq><FieldRef Name=\'CityLook\' LookupId=\'TRUE\'/><Value Type=\'Lookup\'>4</Value></Eq></Where>";
30  
31                 SPList list = web.Lists["Address"];
32      
33                 SPListItemCollection items = list.GetItems(query);
34 
35                 foreach (SPListItem item in items)
36                 {
37                     SPFieldLookupValue CityLook = new SPFieldLookupValue(item["CityLook"].ToString());
38                     SPFieldLookupValue CityCode1 = new SPFieldLookupValue(item["CityCode1"].ToString());
39 
40                     string info = "ID:" + item.ID.ToString() +""+
41                                   "Title:" + item["Title"].ToString() + "" +
42                                   "CityCode:" + item["CityCode"].ToString() + "" +
43                                   "CityDescription:" + item["CityDescription"].ToString() + "" +
44                                   "CityCode1:" + CityCode1.LookupValue + "[" + CityCode1.LookupId + "]" + "" +
45                                   "CityLook:" + CityLook.LookupValue + "[" + CityLook.LookupId + "]";
46                     Response.Write(info + "<br />");
47                 }
48 
49                 //DataTable dtData = items.GetDataTable();
50                 //GridView1.DataSource = dtData;
51                 //GridView1.DataBind();
52             }
53         }

  3、执行效果图:

  

 

  注意事项:

  1、Join属性类型Type若设置为LEFT时,若主表字段删除后,则加载可能会出错;

  2、主表的字段若要在查询结果中体现,则需通过SPQuery.ProjectedFields设置查阅项的模式进行绑定显示;

以上是关于vb SQL多表联合查询问题(Access数据库表)的主要内容,如果未能解决你的问题,请参考以下文章

ACCESS数据库中如何实现多表联合查询?

Access数据库中多表联合查询,并显示记录

Access select where 数据库查询 多表联合查询

Access的Left join多表联合查询

如何实现多表关联查询

关于access sql查询多表的问题