sunfruit[請訪問http://www.fruitres.cn]

          --我相信JAVA能走得更遠 QQ:316228067

          [原創(chuàng)]Oracle Spatial新驅動的查詢記錄實例

          --sunfruit
          ??? Oracle的空間數(shù)據(jù)庫的操作驅動更新了,新的驅動適用于Oracle8.0或以上,新驅動在對數(shù)據(jù)庫的操作上面和原有的驅動差別比較大,不過有一點:使用變得簡單了
          ??? 建立空間數(shù)據(jù)庫和建立空間索引的步驟就略過了,那些網(wǎng)上有很多例子,而且實現(xiàn)方式上面也沒有變化,下面列出查詢空間數(shù)據(jù)庫記錄的代碼:

          import java.sql.DriverManager;
          import java.sql.ResultSet;
          import java.sql.SQLException;
          import oracle.spatial.geometry.JGeometry;
          import java.sql.PreparedStatement;
          import oracle.sql.STRUCT;
          import java.sql.Connection;

          /**
          ?* <p>Title: </p>
          ?*
          ?* <p>Description: </p>
          ?*
          ?* <p>Copyright: Copyright (c) 2006</p>
          ?*
          ?* <p>Company: </p>
          ?*
          ?* @author?sunfruit
          ?* @version 1.0
          ?*/
          public class SdoSelect {
          ? public SdoSelect() {
          ? }
          ? public static void main(String[] args) {
          ??? String driver = "oracle.jdbc.driver.OracleDriver";
          ??? String url = "jdbc:oracle:thin:@172.16.75.200:1521:starmap";
          ??? String uid = "hmbst";
          ??? String psw = "hmbst";
          ??? Connection conn = null;
          ??? PreparedStatement ps=null;
          ??? try {
          ????? Class.forName(driver);
          ????? conn = DriverManager.getConnection(url, uid, psw);

          ????? JGeometry jGeometry=new JGeometry(41884696,14377039,42884696,14477039,0);
          ????? STRUCT obj =jGeometry.store(jGeometry,conn);
          ????? String sql = "SELECT * FROM POISDO p WHERE sdo_filter(p.gshape,?,'querytype=window')='TRUE'";
          ????? ps = conn.prepareStatement(sql,ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_READ_ONLY);
          ????? ps.clearParameters();
          ????? ps.setObject(1, obj);
          ????? // 插入點地物記錄
          ????? ResultSet rs=ps.executeQuery();
          ????? while(rs.next())
          ????? {
          ??????? STRUCT st = (oracle.sql.STRUCT)rs.getObject("gshape");
          ??????? JGeometry j_geom = JGeometry.load(st);
          ??????? double[] dou=j_geom.getPoint();
          ??????? String buff="";
          ??????? for(int i=0;i<dou.length;i++)
          ??????? {
          ????????? buff=buff+String.valueOf((int)dou[i])+"?? ";
          ??????? }
          ??????? System.out.println(buff);
          ????? }
          ??? }
          ??? catch (Exception ex) {
          ????? ex.printStackTrace();
          ??? }
          ??? finally
          ??? {
          ????? if(conn!=null)
          ????? {
          ??????? try {
          ????????? conn.close();
          ??????? }
          ??????? catch (SQLException ex) {
          ????????? ex.printStackTrace();
          ??????? }
          ????? }
          ????? if(ps!=null)
          ????? {
          ??????? try {
          ????????? ps.close();
          ??????? }
          ??????? catch (SQLException ex) {
          ????????? ex.printStackTrace();
          ??????? }
          ????? }

          ??? }
          ? }

          }

          表POISDO的結構如下
          create table poi (
          ? id?INTEGER,
          ??gname?VARCHAR2(256),
          ??gshape?MDSYS.SDO_GEOMETRY);

          posted on 2006-07-20 15:28 sunfruit 閱讀(566) 評論(0)  編輯  收藏 所屬分類: JAVA SE & EE數(shù)據(jù)庫

          主站蜘蛛池模板: 望城县| 新野县| 微山县| 明光市| 阿尔山市| 新营市| 克山县| 罗甸县| 临洮县| 宿州市| 嫩江县| 五台县| 斗六市| 年辖:市辖区| 肇源县| 疏附县| 布尔津县| 许昌市| 大邑县| 图们市| 沧源| 新巴尔虎右旗| 霍山县| 竹山县| 理塘县| 伊春市| 宜兴市| 柘荣县| 海阳市| 东安县| 陵水| 彩票| 平乡县| 巴彦县| 三明市| 辛集市| 南涧| 达州市| 玉门市| 江北区| 梁山县|