地图 数据集连接

连接表:

Udb数据文件中同一数据源下有两个数据集。要把这两个数据集的表连接起来:

在这里用joinIte-m-

Reason:

建立连接的两个表必须在同一个数据源下,而用于建立关联关系的两个数据集表可以不在同一个数据源下。

 

//

按下面的代码,可以实现  市表 和省表连接起来。先是市表字段在接上省表的字段。当字段中有重复名的时候,自动改写成  表名.原字段名  加以区别。  当然如果指定显示内容可以用queryParameter的ResultField属性

/

 

Code:

private void Initialize()

{

WorkspaceConnectionInfo conInfo = new WorkspaceConnectionInfo(@"swmu地址");

m_workspace.Open(conInfo);

JoinItemSample(m_workspace.Datasources["名"]);

}

public void JoinItemSample(Datasource datasource)
{
    DatasetVector datasetVector = datasource.Datasets["市表"as DatasetVector;
    DatasetVector datasetVector1 = datasource.Datasets["省表"as DatasetVector;
    // 构造连接信息类对象,获得用于连接的表名
    JoinItem joinitem = new JoinItem();
    // 设置连接信息类的属性
    joinitem.ForeignTable = datasetVector1.TableName;
    joinitem.JoinFilter = "省表.id=市表.id";
    joinitem.JoinType = JoinType.LeftJoin;
    QueryParameter para = new QueryParameter();
    para.JoinItems.Add(joinitem);
    Recordset recordset = datasetVector.Query(para);
    string strField = "";
    for (int j = 0; j < recordset.FieldCount; j++)
    {
      strField = strField + "," + recordset.GetFieldInfos()[j].Name;
    }
    MessageBox.Show(strField);
    recordset.MoveFirst();
    if (!recordset.IsEOF)
    {
        string str = "";
        for (int i = 0; i < recordset.FieldCount; i++)
        {
            object oo = recordset.GetFieldValue(i);
            if (oo != null)
            {
                str = str + "," + oo.ToString();
            }
                    
        }
        MessageBox.Show(str);
        //  recordset.MoveNext();
    }
    recordset.Dispose();         
}

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值