Java操作Oracle空间信息介绍(SDE)
Java对sde操作,首先需要下载sde支持的jar包。jpe92_sdk.jar和jsde92_sdk.jar两个包,这两个包可以从安装的目录下找到。
sde是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的链接代码:
/**
* 连接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数据进行添加,点线面的新增
/**
* 添加资源信息点到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
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
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查询接口实现
/**
* 查询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信息删除操作

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

MySQL在Web應用中的主要作用是存儲和管理數據。 1.MySQL高效處理用戶信息、產品目錄和交易記錄等數據。 2.通過SQL查詢,開發者能從數據庫提取信息生成動態內容。 3.MySQL基於客戶端-服務器模型工作,確保查詢速度可接受。

InnoDB使用redologs和undologs確保數據一致性和可靠性。 1.redologs記錄數據頁修改,確保崩潰恢復和事務持久性。 2.undologs記錄數據原始值,支持事務回滾和MVCC。

MySQL是一種開源的關係型數據庫管理系統,主要用於快速、可靠地存儲和檢索數據。其工作原理包括客戶端請求、查詢解析、執行查詢和返回結果。使用示例包括創建表、插入和查詢數據,以及高級功能如JOIN操作。常見錯誤涉及SQL語法、數據類型和權限問題,優化建議包括使用索引、優化查詢和分錶分區。

MySQL在數據庫和編程中的地位非常重要,它是一個開源的關係型數據庫管理系統,廣泛應用於各種應用場景。 1)MySQL提供高效的數據存儲、組織和檢索功能,支持Web、移動和企業級系統。 2)它使用客戶端-服務器架構,支持多種存儲引擎和索引優化。 3)基本用法包括創建表和插入數據,高級用法涉及多表JOIN和復雜查詢。 4)常見問題如SQL語法錯誤和性能問題可以通過EXPLAIN命令和慢查詢日誌調試。 5)性能優化方法包括合理使用索引、優化查詢和使用緩存,最佳實踐包括使用事務和PreparedStatemen

選擇MySQL的原因是其性能、可靠性、易用性和社區支持。 1.MySQL提供高效的數據存儲和檢索功能,支持多種數據類型和高級查詢操作。 2.採用客戶端-服務器架構和多種存儲引擎,支持事務和查詢優化。 3.易於使用,支持多種操作系統和編程語言。 4.擁有強大的社區支持,提供豐富的資源和解決方案。

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。MySQL以其高性能、可扩展性和跨平台支持著称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

MySQL索引基数对查询性能有显著影响:1.高基数索引能更有效地缩小数据范围,提高查询效率;2.低基数索引可能导致全表扫描,降低查询性能;3.在联合索引中,应将高基数列放在前面以优化查询。

MySQL適合小型和大型企業。 1)小型企業可使用MySQL進行基本數據管理,如存儲客戶信息。 2)大型企業可利用MySQL處理海量數據和復雜業務邏輯,優化查詢性能和事務處理。
