zl程序教程

您现在的位置是:首页 >  大数据

当前栏目

CYQ.Data 轻量数据访问层(七) 自定义数据表实现绑定常用的数据控件(上)

数据 实现 常用 自定义 访问 控件 Data 绑定
2023-09-14 08:59:37 时间

继上一节实现MDataTable之后,我们再为MDataTable加上一个NewRow()方法,以便能构造出该表的新行

如下:

ContractedBlock.gifExpandedBlockStart.gifCode
 public MDataRow NewRow()
ExpandedBlockStart.gifContractedBlock.gif        {
            MDataRow mdr = new MDataRow();
            mdr.TableName = _TableName;
            MDataCellStruct mdcStruct = null;
            for (int i = 0; i   this.Columns.Count; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif            {
                mdcStruct=this.Columns[i];
                mdr.Add(new MDataCell(ref mdcStruct));
            }
            return mdr;
        }

 

OK,接下来,我们新建一个Demo的web工程,在Default.aspx中随便拖一个GridView控件进去,然后在Page_Load里写下以下代码:

ContractedBlock.gifExpandedBlockStart.gifCode
MDataTable table=new MDataTable("myTableName");
            table.Columns.Add("A", SqlDbType.NVarChar);
            table.Columns.Add("B",SqlDbType.NVarChar);

            MDataRow mdr = table.NewRow();
            mdr[0].Value = "helloA";
            mdr[1].Value = "111111";
            table.Add(mdr);
            GridView1.DataSource = table;
            GridView1.DataBind();

 

敲mdr["A"]本来是要这样敲的,不支持字符串索,只好敲了mdr[0]了,这里顺路为MDataRow加上一个字符串索引,如下:

ContractedBlock.gifExpandedBlockStart.gifCode
public MDataCell this[string Key]
        {
            get
            {
                MDataCell dataCell = null;
                for (int i = 0; i   base.Count; i++)
                {
                    if (base[i].ColumnName == Key)
                    {
                        dataCell = base[i];
                        break;
                    }
                }
                return dataCell;
            }
        }

 

OK,就这样添加了两个列头,又添加了一行数据,运行后看结果如下:


晕,数据根本不是我们想要的....

上面显示的列,有三个都是Table的属性,还有一个ConnectionString是Table的行的属性

吓,咋就混在一块了。。。。

于是,我们开始动手寻找绑定之法...