java操作oracle空间信息介绍(SDE)

de是Spatial Database Engine简写,中文全称:空间数据库引擎。

SDE是一种客户/服务器软件,可使空间数据在工业标准的数据库管理系统中存储、管理和快速查询检索。把GIS数据放在RDBMS中,但是一般的RDBMS都没有提供GIS的数据类型(如点、线、多边形、以及这些feature之间的拓扑关系和投影坐标等相关信息),RDBMS只提供了少量的数据类型支持:int,float,double,Blob,Long ,char等,一般都是数字,字符串和二进制数据几种。并且RDBMS不仅没有提取对GIS数据类型的存储,也没有提供对这些基础类型的操作(如:判断包含关系,相邻、相交、求差、距离、最短路径等)
JAVA对sde操作,首先需要下载sde支持的jar包。jpe92_sdk.jar和jsde92_sdk.jar两个包,这两个包可以从安装的目录下找到。
下面是java获的sde的链接代码:

 

[java] 
/**
     * 连接sde服务
     * @return
     */ 
    public  SeConnection getConnection () { 
        SeConnection conn = null ; 
        try { 
            conn = new SeConnection(SDE_SERVER_IP, SDE_PROT, SDE_DATEBASE_SID, SDE_USERNAME, SDE_PASSWORD);  
        } catch (SeException e) { 
            return null; 
        } 
        return conn; 
    } 

/**
  * 连接sde服务
  * @return
  */
 public  SeConnection getConnection () {
        SeConnection conn = null ;
        try {
            conn = new SeConnection(SDE_SERVER_IP, SDE_PROT, SDE_DATEBASE_SID, SDE_USERNAME, SDE_PASSWORD);
        } catch (SeException e) {
            return null;
        }
        return conn;
 }
对sde数据进行添加,点线面的新增


[java] 
/**
     * 添加资源信息点到sde中
     * @param pointBean 坐标点 POJO
     * @param tbName    图层名称
     * @param String typeName 所画的类型 1 点 2 线 3 面
     * @return   Long   sde的id
     * @throws Exception
     */ 
    public Long addPointObject(PointBean pointBean, List columnList, String tableName, String typeName) throws Exception { 
        SeLayer insertLayer = null; 
        SeConnection conn = null; 
        Long intsertRowID = null; 
        SeInsert insert = null; 
        try { 
            conn = this.getConnection(); 
            insertLayer = new SeLayer( conn,  tableName, "SHAPE"); 
            if (insertLayer == null) { 
                throw new Exception("找不到空间表:" + tableName); 
            } 
            conn.startTransaction(); 
            int arrayLength = columnList.size() + 1 ; 
            String[] cols = new String[arrayLength]; 
            cols[0] = "SHAPE"; 
            for (int i = 0 ;i<columnList.size() ; i++) { 
                ColumnBean columnBean = (ColumnBean)columnList.get(i); 
                cols[i+1] = columnBean.getName(); 
            } 
            insert = new SeInsert(conn); 
            insert.intoTable(insertLayer.getName(), cols); 
            insert.setWriteMode(true); 
            SeCoordinateReference coordref = (SeCoordinateReference) insertLayer.getCoordRef(); 
            SeShape shape = new SeShape(coordref); 
             
            if ("1".equals(typeName)) { 
                this.addPoint(pointBean, shape); 
            } else if ("2".equals(typeName)) { 
                this.addLine(pointBean, shape); 
            } else if ("3".equals(typeName)) { 
                this.addPolygon(pointBean, shape); 
            } 
            SeRow row = insert.getRowToSet(); 
            row.setShape(0, shape); 
            for (int i = 0 ;i<columnList.size() ; i++) { 
                ColumnBean columnBean = (ColumnBean)columnList.get(i); 
                if (columnBean.getTypeObject() == 1) { 
                    row.setNString(i+1, String.valueOf(columnBean.getValObject())); 
                } else if (columnBean.getTypeObject() == 2) { 
                    row.setInteger(i+1, Integer.parseInt(columnBean.getValObject().toString())); 
                }else if (columnBean.getTypeObject() == 3) { 
                    row.setDouble(i+1, Double.parseDouble(columnBean.getValObject().toString())); 
                }  
            } 
            insert.execute(); 
            intsertRowID = new Long(insert.lastInsertedRowId().longValue()); 
            conn.commitTransaction(); 
        } catch (Exception ex) { 
            ex.printStackTrace(); 
            conn.rollbackTransaction(); 
        } finally { 
            if (insert != null) { 
                insert.close(); 
            } 
            if (conn != null) { 
                conn.close(); 
            } 
        } 
        return intsertRowID; 
    } 

/**
  * 添加资源信息点到sde中
  * @param pointBean 坐标点 POJO
  * @param tbName    图层名称
  * @param String typeName 所画的类型 1 点 2 线 3 面
  * @return   Long   sde的id
  * @throws Exception
  */
 public Long addPointObject(PointBean pointBean, List columnList, String tableName, String typeName) throws Exception {
  SeLayer insertLayer = null;
  SeConnection conn = null;
  Long intsertRowID = null;
  SeInsert insert = null;
  try {
   conn = this.getConnection();
   insertLayer = new SeLayer( conn,  tableName, "SHAPE");
   if (insertLayer == null) {
    throw new Exception("找不到空间表:" + tableName);
   }
   conn.startTransaction();
   int arrayLength = columnList.size() + 1 ;
   String[] cols = new String[arrayLength];
   cols[0] = "SHAPE";
   for (int i = 0 ;i<columnList.size() ; i++) {
    ColumnBean columnBean = (ColumnBean)columnList.get(i);
    cols[i+1] = columnBean.getName();
   }
   insert = new SeInsert(conn);
   insert.intoTable(insertLayer.getName(), cols);
   insert.setWriteMode(true);
   SeCoordinateReference coordref = (SeCoordinateReference) insertLayer.getCoordRef();
   SeShape shape = new SeShape(coordref);
   
   if ("1".equals(typeName)) {
    this.addPoint(pointBean, shape);
   } else if ("2".equals(typeName)) {
    this.addLine(pointBean, shape);
   } else if ("3".equals(typeName)) {
    this.addPolygon(pointBean, shape);
   }
   SeRow row = insert.getRowToSet();
   row.setShape(0, shape);
   for (int i = 0 ;i<columnList.size() ; i++) {
    ColumnBean columnBean = (ColumnBean)columnList.get(i);
    if (columnBean.getTypeObject() == 1) {
     row.setNString(i+1, String.valueOf(columnBean.getValObject()));
    } else if (columnBean.getTypeObject() == 2) {
     row.setInteger(i+1, Integer.parseInt(columnBean.getValObject().toString()));
    }else if (columnBean.getTypeObject() == 3) {
     row.setDouble(i+1, Double.parseDouble(columnBean.getValObject().toString()));
    }
   }
   insert.execute();
   intsertRowID = new Long(insert.lastInsertedRowId().longValue());
   conn.commitTransaction();
  } catch (Exception ex) {
   ex.printStackTrace();
   conn.rollbackTransaction();
  } finally {
   if (insert != null) {
    insert.close();
   }
   if (conn != null) {
    conn.close();
   }
  }
  return intsertRowID;
 }
sde查询接口实现


[java]
/**
     * 查询sde
     * @param productId 产品id
     * @throws SeException
     */ 
    public SeQuery searchSde (Long productId, String tableName) throws SeException { 
        SeConnection conn = getConnection(); 
        SeLayer layer = new SeLayer( conn,  tableName, "SHAPE"); 
        SeSqlConstruct sqlConstruct = new SeSqlConstruct(layer.getName()); 
        if (productId != null) { 
            sqlConstruct.setWhere("yid="+productId.intValue()); 
        } 
        String[] cols = null; 
        if (tableName.equals("YU_AN_POINT") || tableName.equals("FANG_AN_POINT")) { 
            cols = new String[4]; 
            cols[0] = new String("OBJECTID"); 
            cols[1] = layer.getSpatialColumn(); 
            cols[2] = new String("NAME"); 
            cols[3] = new String("IMAGETYPE"); 
        } else { 
            cols = new String[3]; 
            cols[0] = new String("OBJECTID"); 
            cols[1] = layer.getSpatialColumn(); 
            cols[2] = new String("NAME"); 
        } 
        System.out.println("cols.length : " + cols.length); 
        SeQuery query = new SeQuery(conn, cols, sqlConstruct ); 
        query.prepareQuery(); 
        query.execute(); 
        return query; 
    } 

/**
  * 查询sde
  * @param productId 产品id
  * @throws SeException
  */
 public SeQuery searchSde (Long productId, String tableName) throws SeException {
  SeConnection conn = getConnection();
  SeLayer layer = new SeLayer( conn,  tableName, "SHAPE");
        SeSqlConstruct sqlConstruct = new SeSqlConstruct(layer.getName());
        if (productId != null) {
         sqlConstruct.setWhere("yid="+productId.intValue());
        }
        String[] cols = null;
        if (tableName.equals("YU_AN_POINT") || tableName.equals("FANG_AN_POINT")) {
            cols = new String[4];
            cols[0] = new String("OBJECTID");
            cols[1] = layer.getSpatialColumn();
            cols[2] = new String("NAME");
            cols[3] = new String("IMAGETYPE");
        } else {
         cols = new String[3];
            cols[0] = new String("OBJECTID");
            cols[1] = layer.getSpatialColumn();
            cols[2] = new String("NAME");
        }
        System.out.println("cols.length : " + cols.length);
        SeQuery query = new SeQuery(conn, cols, sqlConstruct );
        query.prepareQuery();
        query.execute();
        return query;
 }
SDE信息删除操作


[java]
/**
     * 
     * 删除 通过列对应的值
     * @param id     值
     * @param column 列 
     * @param tbName 表名
     * @throws SeException
     */ 
     public void deletePointObject(String id, String column, String tbName) throws SeException { 
        SeConnection conn = null; 
        SeLayer layer = null; 
        SeDelete delete = null; 
        try { 
            conn = this.getConnection(); 
            layer = new SeLayer(conn, tbName, "SHAPE"); // 得到对应图层  
            if (layer == null) { 
                throw new Exception("找不到空间表:" + tbName); 
            } 
            conn.startTransaction(); 
            delete = new SeDelete(conn); 
            delete.fromTable(layer.getName(), column + "='" + id+"'"); 
            conn.commitTransaction(); 
        } catch (Exception ex) { 
            conn.rollbackTransaction(); 
        } finally { 
            if (delete != null) { 
                try { 
                    delete.close(); 
                } catch (SeException e) { 
                    e.printStackTrace(); 
                    throw e; 
                } finally { 
                    if (conn != null) { 
                        conn.close(); 
                    } 
                } 
            } 
        } 
    } 

/**
  *
  * 删除 通过列对应的值
  * @param id     值
  * @param column 列
  * @param tbName 表名
  * @throws SeException
  */
  public void deletePointObject(String id, String column, String tbName) throws SeException {
  SeConnection conn = null;
  SeLayer layer = null;
  SeDelete delete = null;
  try {
   conn = this.getConnection();
   layer = new SeLayer(conn, tbName, "SHAPE"); // 得到对应图层
   if (layer == null) {
    throw new Exception("找不到空间表:" + tbName);
   }
   conn.startTransaction();
   delete = new SeDelete(conn);
   delete.fromTable(layer.getName(), column + "='" + id+"'");
   conn.commitTransaction();
  } catch (Exception ex) {
   conn.rollbackTransaction();
  } finally {
   if (delete != null) {
    try {
     delete.close();
    } catch (SeException e) {
     e.printStackTrace();
     throw e;
    } finally {
     if (conn != null) {
      conn.close();
     }
    }
   }
  }
 }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要清除SDE空间的垃圾数据,可以使用以下步骤: 1. 首先,使用ArcCatalog或ArcMap的Catalog窗口连接到要清除的SDE数据库。 2. 右键单击要清除的SDE图层,选择“属性”选项。在“属性”窗口,选择“空间参考”选项卡,记录空间参考的名称。 3. 打开ArcToolbox的“数据管理工具”>“清理”>“清理SDE垃圾数据”工具。 4. 在“清理SDE垃圾数据”工具,选择要清理的SDE图层,选择要清理的垃圾数据类型(例如,无效的几何体、重复的要素等),并选择要清理的空间参考。 5. 点击“运行”按钮开始清理。 请注意,清除SDE空间的垃圾数据可能需要一些时间,具体时间取决于数据量的大小和计算机的性能。另外,清除垃圾数据可能会影响到SDE数据的完整性和一致性,因此在进行此操作之前,请务必备份SDE数据。 ### 回答2: Oracle SDE Layers 是一种在 Oracle 数据库存储和管理空间数据的技术。当使用 SDE Layers 存储空间数据时,有时候会存留一些垃圾数据,这些数据可能是由于删除或修改数据时没有完全清理而产生的。 清除 SDE 空间垃圾数据的方法有以下几种: 1. 使用 ArcSDE command line 工具:可以使用 sdelayer -o delete 命令来删除指定表的垃圾数据。这个命令将会把那些没有被任何几何要素引用的几何类型和相关的属性记录从表删除。 2. 使用 ArcGIS 数据完整性检查工具:可以使用 ArcGIS 提供的数据完整性检查工具来识别并删除表的垃圾数据。这个工具会检测表的每一行记录,如果发现某一行记录没有被任何几何要素引用,那么就会将其标记为垃圾数据,并且可以选择性地删除它们。 3. 手动清理:可以通过编写 SQL 查询语句来手动清理 SDE Layers 的垃圾数据。通过查询数据库的关联表,找到不再被任何几何要素引用的记录,并将其删除。 无论使用哪种方法,清除 SDE Layers 的垃圾数据都需要谨慎操作,确保不会误删有效数据。建议在清理之前先备份数据,以防万一。使用适当的工具和技术方法来清除垃圾数据,可以有效提升数据库性能和数据的完整性。 ### 回答3: 清除SDE空间垃圾数据可以通过以下步骤进行: 1. 首先,连接到Oracle数据库SDE用户。可以使用SQL*Plus或SQL Developer等数据库工具。 2. 检查SDE用户下的所有空间表,识别存在垃圾数据的表。可以使用以下SQL语句检索所有空间表的名称: ```sql SELECT table_name FROM all_tables WHERE owner = 'SDE' AND table_name LIKE 'SDE%' ``` 3. 对于每个空间表,可以采取以下方法清除垃圾数据: - 方法一:使用ArcGIS工具,如ArcCatalog或ArcMap等,连接到SDE数据库,打开要清理的图层,然后选择"Manage > Purge > Purge All"清除所有垃圾数据。这将删除不再被任何要素类参考的空间数据。 - 方法二:手动执行SQL语句来删除垃圾数据。在执行之前,建议先备份相关的表数据。以下是一个示例SQL语句,用于删除指定表的垃圾数据,并针对需要进行清理的每个表进行修改: ```sql DELETE FROM sde.table_name WHERE sde_column_name IS NULL ``` 在该语句,"table_name"是要清除垃圾数据的表的名称,"sde_column_name"是一个包含空间数据的列的名称(例如SHAPE或GEOMETRY)。 4. 在清除垃圾数据后,可以使用SDE命令重新创建空间索引以优化空间查询性能。可以使用以下命令进行重新创建空间索引: ```sql SDELAYER -o alter -l table_name,-1 sde:oracle11g:sde ``` 在该命令,"table_name"是要重新创建空间索引的表的名称。 5. 最后,验证清除操作是否成功,通过查询相关空间表的数据进行确认。 请注意,清除空间垃圾数据涉及对数据库进行修改和删除操作,因此在执行操作之前,请确保已进行适当的备份,并在生产环境谨慎操作

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值