下面的程序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>
闽公网安备 35060202000074号