GeneXus 扩展 - 如何知道与表关联的数据存储?

发布于 2025-01-11 11:04:29 字数 138 浏览 0 评论 0原文

我需要创建一个 GeneXus 扩展来遍历 DEFAULT DataStore 的表(但不在其他数据存储中)来执行某些检查。

了解与表关联的数据存储的最佳方法是什么?

我可以检查该表是否被 DataView 引用,但也许有更好的方法。

I need to make a GeneXus extension that goes through the tables of the DEFAULT DataStore (but not in the other datastore) to do certain checks.

What is the best way to know the datastore associated with a table?

I can check if the table is referenced by a DataView, but maybe there is a better method.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

波浪屿的海角声 2025-01-18 11:04:29

目前还没有直接的 API 可以解决此查询。建模的方式是,DataView 是将TableDataStoreCategory 关联的实体。

检查交叉引用是缩小问题范围的好方法,尽管为了确定给定的数据视图是否绑定到给定的表,您必须检查 AssociatedTableKey 属性。

另一件需要记住的事情是,可能有一个数据视图与 DEFAULT 数据存储中的表关联,或者多个数据视图绑定到同一个表和不同的数据存储。
无法保证模型在任何时候都处于有效状态,并且决定如何处理这些情况可能会影响您构建查询的方式。

此示例查询返回与数据存储关联的所有表。如果有多个数据视图与该表关联,它会检查第一个数据视图是否属于给定的数据存储。

IEnumerable<Table> GetTablesInDataStore(DataStoreCategory ds)
{
    foreach (EntityKey tblKey in Table.GetKeys(ds.Model))
    {
        if (IsInDataStore(tblKey, ds))
            yield return Table.Get(ds.Model, tblKey.Id);
    }
}

bool IsInDataStore(EntityKey tblKey, DataStoreCategory ds)
{
    DataView dv = GetDataView(ds.Model, tblKey);
    if (dv is null)
        return ds.IsDefault;
    else
        return Artech.Genexus.Common.Properties.XFL.GetDatastore(dv).Identifier == ds.Id;
}

DataView GetDataView(KBModel model, EntityKey tblKey)
{
    foreach (var r in model.GetReferencesTo(tblKey, LinkType.UsedObject, new[] { ObjClass.DataView }))
    {
        var dv = DataView.Get(model, r.From.Id);
        if (dv.AssociatedTableKey == tblKey)
            return dv;
    }
    return null;
}

Currently there is no straightforward API that solves this query. The way things are modeled is that the DataView is the entity that associates a Table to a DataStoreCategory.

Checking the cross-reference is a nice way to narrow down the problem space, although to be certain that a given data view is bound to a given table, you have to check for the AssociatedTableKey property.

Another thing to keep in mind, is that there could be a data view associated to a table in the DEFAULT data store, or more than one data view bound to the same table and different data stores.
There are no guarantees that the model is in a valid state at any moment, and deciding how to handle these situations may affect how you build your query.

This sample query returns all tables associated to a data store. If there are multiple data views associated to the table, it checks if the first of them belongs to the given data store.

IEnumerable<Table> GetTablesInDataStore(DataStoreCategory ds)
{
    foreach (EntityKey tblKey in Table.GetKeys(ds.Model))
    {
        if (IsInDataStore(tblKey, ds))
            yield return Table.Get(ds.Model, tblKey.Id);
    }
}

bool IsInDataStore(EntityKey tblKey, DataStoreCategory ds)
{
    DataView dv = GetDataView(ds.Model, tblKey);
    if (dv is null)
        return ds.IsDefault;
    else
        return Artech.Genexus.Common.Properties.XFL.GetDatastore(dv).Identifier == ds.Id;
}

DataView GetDataView(KBModel model, EntityKey tblKey)
{
    foreach (var r in model.GetReferencesTo(tblKey, LinkType.UsedObject, new[] { ObjClass.DataView }))
    {
        var dv = DataView.Get(model, r.From.Id);
        if (dv.AssociatedTableKey == tblKey)
            return dv;
    }
    return null;
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文