点击这里给我发消息 点击这里给我发消息

用JSP导出ORACLE的数据表DDL

添加时间:2013-12-7
    相关阅读: 数据库 程序 JSP Oracle

  下面的程序expddl.jsp可导出当前连接数据库的用户下的所有数据表的DDL.
  
  EXPDDL.JSP:
  
  <%@ page contentType="text/html; charset=gb2312" language="java" %>
  <%@ page import = "java.sql.*" %>
  <%@ page import = "oracle.jdbc.OracleDatabaseMetaData" %>
  <%@ page import = "oracle.jdbc.OracleResultSetMetaData" %>
  <%@ page import = "javax.sql.*,javax.naming.Context" %>
  <%@ page import = "javax.naming.InitialContext" %>
  <div align="center">
  <%
  DataSource ds = null;
  
  Context ic = new InitialContext();
  ds = (DataSource) ic.lookup("java:comp/env/jdbc/mydb");
  
  Connection conn = ds.getConnection();
  
  OracleDatabaseMetaData odmd = (OracleDatabaseMetaData) conn.getMetaData();
  String us = odmd.getUserName();
  String[] types = new String[1];
  types[0] = "TABLE";
  ResultSet rs = odmd.getTables(null,us,"%",types);
  while(rs.next()) {
  //取表名
  String tname = rs.getString(3);
  %>
  <div align="center">表名:<%= tname%></div>
  <table width="483" height="50" border="1" cellpadding="2" cellspacing="0">
  <tr>
  <td><div align="center">序号</div></td>
  <td><div align="center">标识</div></td>
  <td><div align="center">类型/精度</div></td>
  <td><div align="center">标识说明</div></td>
  </tr>
  <%
  Statement st = conn.createStatement();
  ResultSet rs1 = st.executeQuery("select * from " + tname);
  OracleResultSetMetaData ormd = (OracleResultSetMetaData) rs1.getMetaData();
  //取列总数
  int colcnt = ormd.getColumnCount();
  //列序号
  int num = 1;
  for(int j=0;j<colcnt;j++) {
  String s = ormd.getColumnTypeName(j+1).toLowerCase();
  //只处理varchar2 char date number类型(根据需要添加相应的处理)
  if(s.equals("varchar2") || s.equals("char") || s.equals("date") || s.equals("number")) {
  if(s.equals("varchar2") || s.equals("char"))
  s = s + "(" + ormd.getColumnDisplaySize(j+1) + ")";
  if(s.equals("number"))
  s = s + "(" + ormd.getPrecision(j+1) + "," + ormd.getScale(j+1) + ")";
  %>
  <tr>
  <td width="40"><div align="center"><%= num++ %></div></td>
  <td width="98"><%=ormd.getColumnName(j+1)%></td><td width="144"><%= s %></td>
  <td width="173"> </td> </tr>
  <%
  }
  }
  rs1.close();
  st.close();
  %>
  </table>
  <br>
  <%
  }
  rs.close();
  conn.close();
  %>
  </div>
咨询热线:020-85648757 85648755 85648616 0755-27912581 客服:020-85648756 0755-27912581 业务传真:020-32579052
广州市网景网络科技有限公司 Copyright◎2003-2008 Veelink.com. All Rights Reserved.
广州商务地址:广东省广州市黄埔大道中203号(海景园区)海景花园C栋501室
= 深圳商务地址:深圳市宝源路华丰宝源大厦606
研发中心:广东广州市天河软件园海景园区 粤ICP备05103322号 工商注册