用JSP导出ORACLE的数据表DDL

ZDNet软件频道 时间:2008-06-29 作者: | 中国IT实验室 我要评论()
本文关键词:DDL Oracle JSP
下面的程序expddl.jsp可导出当前连接数据库的用户下的所有数据表的DDL.
下面的程序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>

百度大联盟认证黄金会员Copyright© 1997- CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号 京ICP备09041801号-159
京公网安备:1101082134