服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > JAVA > 新手入门 > 基础入门 > 查看文档

用jsp导出oracle的数据表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>

扫描关注微信公众号