免费视频|新人指南|投诉删帖|广告合作|地信网APP下载

查看: 2479|回复: 1
收起左侧

利用Java进行AcrSDE开发实例

[复制链接]

1986

主题

10万

铜板

98

好友

技术员

Network change life, change t

积分
17879

斑竹勋章地信元老

QQ
发表于 2009-12-15 09:14 | 显示全部楼层 |阅读模式
利用Java进行AcrSDE开发实例:

ArcSDE提供了C API和Java API两种接口。这里我们只导论如何通过Java API进行arcSDE开发。
开发环境:
JDK 1.5
WIN 插P
Eclipse 3.1+MyEclipse
ArcSDE for Oracle 9i
(1)把arcSDE java API所需要的三个jar包导到web\lib目录,包括jsde90_sdk.jar,jpe90_sdk.jar ,concurrent.jar;
(2)添加点:
public class AddPointBean {
    public static boolean process(HttpServletRequest request,
            HttpServletResponse response) throws Exception {
        Map map=null;
        if (request.getSession().getAttribute(StaticConstant.SESSION_MAP) == null) {
            String strErr = "地图还没有初始化";
            request.setAttribute(StaticConstant.REQUEST_ERROR, strErr);
            return false;
        }
        map=(Map)request.getSession().getAttribute(StaticConstant.SESSION_MAP);
        //连接SDE
        SeConnection conn = null;
        String server = "menglikunm";
        int instance = 5151;
        String database = "ora";
        String user = "sde";
        String password = "sde";
        SeLayer insertLayer=null;
        try {
            conn = new SeConnection(server, instance, database, user, password);
            Vector layerList = conn.getLayers();
            for (int index = 0; index < layerList.size(); index++) {
                SeLayer layer = (SeLayer) layerList.elementAt(index);
                // Displays the layer’s name
                System.out.println(layer.getName());
                // Displays the layer’s ID
                System.out.println(layer.getID().longValue());
                // Displays the layer’s spatial column name
                System.out.println(layer.getSpatialColumn());
                if(layer.getName().equalsIgnoreCase("ZHENGFUJIGUAN")){
                    insertLayer=layer;
                }
            }
        } catch (SeException e) {
            e.printStackTrace();
            return false;
        }
        //开始插入数据
        try{
            conn.startTransaction();
            String[] cols = new String[2];
            cols[0] = new String("NAME");
            cols[1] = insertLayer.getSpatialColumn();
            SeInsert insert = new SeInsert(conn);
            insert.intoTable(insertLayer.getName(),cols);
            insert.setWriteMode(true);
            SeCoordinateReference coordref =(SeCoordinateReference)insertLayer.getCoordRef();
            SeShape shape = new SeShape(coordref);
            double x=map.toMapPoint(10,10).getX();
            double y=map.toMapPoint(10,10).getY();
            
            int numPts = 1;
            SDEPoint[] ptArray = new SDEPoint[numPts];
            ptArray[0] = new SDEPoint(x, y);
            shape.generatePoint(numPts, ptArray);
            
            SeRow row = insert.getRowToSet();
            row.setString(0, "测验点");
            row.setShape(1,shape);
            insert.execute();
            insert.close();
            conn.commitTransaction();
            conn.close();
        }catch(Exception ex){
            conn.rollbackTransaction();
            conn.close();
            ex.printStackTrace();
        }
        return true;
    }
}(3)删除点:
public class DeletePointBean {
    public static boolean process(HttpServletRequest request,
            HttpServletResponse response) throws Exception {
        //连接SDE
        SeConnection conn = null;
        String server = "menglikunm";
        int instance = 5151;
        String database = "ora";
        String user = "sde";
        String password = "sde";
        try {
            conn = new SeConnection(server, instance, database, user, password);
            Vector layerList = conn.getLayers();
            for (int index = 0; index < layerList.size(); index++) {
                SeLayer layer = (SeLayer) layerList.elementAt(index);
                // Displays the layer’s name
                System.out.println(layer.getName());
                // Displays the layer’s ID
                System.out.println(layer.getID().longValue());
                // Displays the layer’s spatial column name
                System.out.println(layer.getSpatialColumn());
            }
        } catch (SeException e) {
            e.printStackTrace();
            return false;
        }
        //开始删除数据
        try{
            conn.startTransaction();
            SeDelete delete=new SeDelete(conn);
            SeObjectId id=new SeObjectId(641);
            delete.byId("ZHENGFUJIGUAN",id);
            conn.commitTransaction();
            delete.close();
        }catch(Exception ex){
            conn.rollbackTransaction();
            conn.close();
            ex.printStackTrace();
        }
        return true;
    }
}
轻轻的我来签到了,想带走一堆铜板...

1145

主题

10万

铜板

2

好友

传奇会员

Rank: 30Rank: 30Rank: 30Rank: 30Rank: 30Rank: 30Rank: 30Rank: 30

积分
21817

灌水勋章活跃勋章冰雪节勋章

QQ
发表于 2013-11-10 19:37 | 显示全部楼层
进来看看 学习学习

评分

参与人数 1铜板 +1 收起 理由
admin + 1 亲,你好快哦~~~

查看全部评分

加强科技支撑和引领  实现地质找矿新突破 。     
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

在线客服
快速回复 返回顶部 返回列表