读书人

jsp脚本兑现本分数据库

发布时间: 2012-10-18 13:46:56 作者: rapoo

jsp脚本实现本分数据库

JSP导出Oracle数据表是一个在开发应用时的常用的操作,那么如何实现呢?现在开始我们的程序介绍,首先下面的程序expddl.jsp可导出Oracle数据表进行数据库的用户下的所有数据表的DDL.JSP导出的Oracle数据表之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 dmd = (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()) {   对JSP导出的Oracle数据表进行取表名String tname = rs.getString(3);  %  div align="center"表名:%= tname%/div  table width="483" height="50" border="1" cellpadding="2" cellspacing="0"  tr  tddiv align="center"序号/div/td  tddiv align="center"标识/div/td  tddiv align="center"类型/精度/div/td  tddiv align="center"标识说明/div/td  /tr  %  Statement st = conn.createStatement();  ResultSet rs1 = st.executeQuery("select * from " + tname);  OracleResultSetMetaData rmd = (OracleResultSetMetaData) rs1.getMetaData();   对JSP导出的Oracle数据表提取取列总数int colcnt = ormd.getColumnCount();   对JSP导出的Oracle数据表提取列序号int num = 1;  for(int j=0;jcolcnt;j++) {  String s = ormd.getColumnTypeName(j+1).toLowerCase();   对Oracle数据表只处理varchar2 char date number类型(根据需要添加相应的处理)   if(s.equals("varchar2") || s.equals("char") || s.equals("date") || s.equals("number")) {  if(s.equals("varchar2") || s.equals("char"))  ss = s + "(" + ormd.getColumnDisplaySize(j+1) + ")";  if(s.equals("number"))  ss = 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)%/tdtd width="144"%= s %/td  td width="173" /td /tr  %  }  }  rs1.close();  st.close();  %  /table  br  %  }  rs.close();  conn.close();  %  /div    通过上面对JSP导出的Oracle数据表的操作,你是否对于这个程序的实现有了自己的思路呢?

读书人网 >其他数据库

热点推荐