用JSP导出ORACLE的数据表DDL
2005-03-29 08:51
393 查看
这几天忙着整理搞ISO的文档,也不知道自己维护的数据库手册是否齐全,算了干脆写个程序全给导出来算了;)。下面的程序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>
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>
相关文章推荐
- Oracle 11G 用exp无法导出空表解决方法以及数据泵的使用
- Oracle数据泵-schema导入导出
- LINUX下oracle数据导入导出方法
- 如何从oracle导出数据到powerdesigner
- oracle 数据库,数据整体导入和导出
- Oracle利用传输表空间方法导出导入数据的步骤
- Oracle数据导出
- direct=true 错误处理方法 (关于 Oracle 的数据导入导出及 Sql Loader (sqlldr) 的用法
- 在pl/sql中使用exp/imp工具实现oracle数据导出/导入
- oracle EXP-00011 导出数据时,空表报错
- Oracle建用户,建表空间,导入导出数据等语句
- oracle数据泵导入导出
- ORACLE 11.2.0.4 数据导出 EXP-00003错误(空表不能导出)
- mysql && oracle 导入导出数据方法总结
- Oracle-Oracle10 数据空间建立,导入,导出--oracle10g 删除步骤
- oracle数据的导入导出命令
- 关于pl /sql导入导出表结构,表数据,Oracle不能改变表的所有者
- 使用PLSQL Developer 把oracle数据表 导出到excel表
- Oracle数据导入导出命令!
- oracle 导入/导出数据库结构和数据【命令方式】