赞
踩
前些日子做了一个数据库的修改工作,要为数据添加字段,数据为Geodatabase类型,里面有90多个图层,每个图层添加6个字段,一共要做2个小时左右,而且效率比较低,容易出错,因此想到了通过程序来解决。
实现如下,首先先建立程序主窗体,包括TocControl,AxMapControl和ToolBarControl,设置好他们之间的Buddy属性,在ToolBarControl中添加基本工具(包含数据加载工具,用于加载操作数据)。
地图加载进来,就可以对图层进行循环处理添加字段了。
主要代码如下:
- public ILayer pLayer;
- public IFeatureLayerpFLayer;
- public IFeatureClasspFC;
- public ILayerFieldspLayerFields;
- DataTable dt = new DataTable();
- private voidbtnAdd_Click(object sender, EventArgs e)
- {
- if(axMapControl1.LayerCount == 0)
- {
- MessageBox.Show("请先加载添加字段的图层!");
- return;
- }
- //循环所有图层
- for(int i = 0; i < axMapControl1.LayerCount;i++)
- {
- try
- {
- pLayer =axMapControl1.get_Layer(i);
- pFLayer = pLayer as IFeatureLayer;
- pFC = pFLayer.FeatureClass;
- pLayerFields = pFLayer as ILayerFields;
- ITablepTable = (ITable)pFC;
- //删除原来表中的数据,若不需要可以去除,在数据库有数据的情况下无法插入非空字段
- pTable.DeleteSearchedRows(null);
- IFieldnewField = new FieldClass();
- IFieldEditfieldEdit = (IFieldEdit)newField;
- fieldEdit.Name_2 = "字段名称";
- //数据类型,这里以字符型为例
- fieldEdit.Type_2 = esriFieldType.esriFieldTypeString;
- //字节长度
- fieldEdit.Length_2 = 1;
- //字段是否允许为空
- fieldEdit.IsNullable_2 = false;
- pFC.AddField(newField);
- }
- catch(Exception exc)
- {
- MessageBox.Show("添加失败" + exc.Message);
- }
- }
- }

Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。