【二次开发】CityMaker数据操作——增加

**

数据增加

**

一、原理

数据库ITable通过Insert()方法取得插入记录的游标,同时检查锁状态,为插入记录做准备。游标通过InsertRow,实现数据插入,并通过Flush()强制写入数据库。

二、实现代码

1. .net

//存数据库,增加记录
private void InsertRow(){
	if (_currentFc != null && _currentRowbuf!=null)
	{
	   IRowBuffer rbuffer = _currentFc.CreateRowBuffer();//创建一条新的记录
	   for (int i = 0; i < _currentFc.GetFields().Count; ++i)
	   {
	       if (_currentFc.GetFields().Get(i).Name != "oid")//非主键“oid”的字段
	       {
	           int npos =_currentRowbuf.FieldIndex(_currentFc.GetFields().Get(i).Name);
	           rbuffer.SetValue(npos, _currentRowbuf.GetValue(npos));   //设置记录除主键"oid"外字段值
	       }
	       int npos0 = rbuffer.FieldIndex("Geometry");
	       IModelPoint mpnew=geoEditing as IModelPoint;//geoEditing为几何编辑模式下创建的ModelPoint
	       rbuffer.SetValue(npos0, mpnew); //设置空间几何字段的值
	   }
	
	   IFdeCursor  cursor=   _currentFc.Insert();//获取insert游标
	   if(rbuffer!=null){
		   	cursor.InsertRow(rbuffer);//插入记录
	     	cursor.Flush();//写入数据库
	   }
	}
	if (cursor != null)
	{
	    System.Runtime.InteropServices.Marshal.ReleaseComObject(cursor);
	    cursor = null;
	}
}

2. JS

var cursorinsert=fc.insert();//获取insert游标
cursorinsert.insertRow(insertRowBuffer);//插入记录,insertRowBuffer的创建可以参考.NET部分的rbuffer对象
cursorinsert.flush(); //写入数据库

三、注意事项

1、在执行Insert()方法时数据库会对ObjectClass加锁,需在执行完插入操作后调用ObjectClass::Close释放锁提交数据。否则易出现可视化时拿不到数据的问题。

2、当数据源类型是Firbird/SQLite的时候,如果文件大小超过500MB,将会抛出“拒绝访问”的异常。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值