科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道用JSP导出ORACLE的数据表DDL

用JSP导出ORACLE的数据表DDL

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

下面的程序expddl.jsp可导出当前连接数据库的用户下的所有数据表的DDL.

作者:中国IT实验室 来源:中国IT实验室 2007年9月4日

关键字: 数据表DDL ORACLE JSP

  • 评论
  • 分享微博
  • 分享邮件
 下面的程序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>

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章