文档章节

System.Data.DataColumnCollection

fandyx
 fandyx
发布于 2015/02/03 14:12
字数 223
阅读 27
收藏 0
// Copyright (C), 2014, CEU Co., Ltd.
// USR Changed by 2014-10-14T12:27:59 Fandy Xie 谢宇帆
// Version       : 1.0
// Description   : 将table/view的fields添加到.net dataColumnCollection
// Return        :
static System.Data.DataColumnCollection getTableColumnsCollection(
    System.Data.DataColumnCollection    _colCollection,
    tableId                             _tableId)
{
    DictTable       dicTable;
    DictField       dictField, dfArray;
    set             setLabel    = new set(types::String);
    map             mapField    = new map(types::Integer, types::String);
    mapEnumerator   me;

    fieldId         fieldId;
    int             a, fieldCnt,m;
    name            fieldName, fieldLabel;
    container       con, fieldCon;
    identifiername  extend;
    types           type;
    System.Type     netType;
    ;

    dicTable    = new DictTable(_tableId);
    fieldCnt    = dicTable.fieldCnt();

    if(dicTable.isMap())// || dicTable.isSystemTable() || dicTable.isView())
        return _colCollection;
    for(m = 1;m <= fieldCnt; m++)
    {
        dictField   = new DictField(dicTable.id(),dicTable.fieldCnt2Id(m));
        fieldId     = dictField.id();
        fieldName   = dictField.name(dbBackend::Sql);
        fieldLabel  = dictField.label();
        type        = dictField.baseType();
        if(dictField.isSystem() && fieldName != "DATAAREAID")
            continue;
        if (!fieldName)
            continue;
        if (type == types::Container)
            continue;
        if (fieldName like "del_*")
            continue;

        extend = global::extendedTypeId2name(dictField.typeId());
        if (dictField.arraySize() > 1) // 数组 Dimension
        {
            for(a = 1; a <= dictField.arraySize(); a++)
            {
                dfArray     = new dictField(dicTable.id(), fieldId2Ext(dictField.id(), a));
                fieldId     = dfArray.id();
                fieldName   = dfArray.name(dbBackend::Sql);
                fieldLabel  = dfArray.label();
                if (!fieldLabel)
                    fieldLabel = fieldName;

                if (setLabel.in(fieldLabel))
                    continue;
                setLabel.add(fieldLabel);
                mapField.insert(fieldId, fieldName);
                _colCollection.Add(fieldName);
            }
        }
        else
        {
            if (!fieldLabel)
                fieldLabel = fieldName;
            if (setLabel.in(fieldLabel))
                continue;
            setLabel.add(fieldLabel);
            mapField.insert(fieldId, fieldName);
            _colCollection.Add(fieldName);
            //_colCollection.Add(fieldName,
            netType = System.Type::GetType("System.Int32");//int
            //System.Int64;//int64;
            /*
            System.String;//str;
            System.Int64;//int64;
            System.Int64;//int64;
            System.Int64;//int64;*/
        }
    }
    /*
    me = mapField.getEnumerator();
    while (me.moveNext())
    {
        fieldId     = me.currentKey();
        fieldName   = me.currentValue();
        lastCol++;
    }
    */
    return _colCollection;
}


© 著作权归作者所有

共有 人打赏支持
上一篇: fields list of table
下一篇: DataSet, DataTable
fandyx
粉丝 0
博文 39
码字总数 11111
作品 0
东莞
技术主管
私信 提问

暂无文章

开始看《Java学习笔记》

虽然书买了很久,但一直没看。这其中也写过一些Java程序,但都是基于IDE的帮助和对C#的理解来写的,感觉不踏实。 林信良的书写得蛮好的,能够帮助打好基础,看得出作者是比较用心的。 第1章概...

max佩恩
昨天
6
0
Redux 三大原则

1.单一数据源 在传统的MVC架构中,我们可以根据需要创建无数个Model,而Model之间可以互相监听、触发事件甚至循环或嵌套触发事件,这些在Redux中都是不被允许的。 因为在Redux的思想里,一个...

wenxingjun
昨天
3
0
跟我学Spring Cloud(Finchley版)-12-微服务容错三板斧

至此,我们已实现服务发现、负载均衡,同时,使用Feign也实现了良好的远程调用——我们的代码是可读、可维护的。理论上,我们现在已经能构建一个不错的分布式应用了,但微服务之间是通过网络...

周立_ITMuch
昨天
2
0
XML

学习目标  能够说出XML的作用  能够编写XML文档声明  能够编写符合语法的XML  能够通过DTD约束编写XML文档  能够通过Schema约束编写XML文档  能够通过Dom4j解析XML文档 第1章 xm...

stars永恒
昨天
0
0
RabbitMQ学习(2)

1. 生产者客户端 void basicPublish(String exchange, String routingKey, boolean mandatory, boolean immediate, BasicProperties props, byte[] body) 1. 在生产者客户端发送消息时,首先......

江左煤郎
昨天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部