`
韩悠悠
  • 浏览: 830429 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

元数据(ResultSetMeta接口)学习笔记

    博客分类:
  • java
阅读更多

利用DatabaseMetaData得到数据库中所有表的信息,利用ResultSetMetaData获取表的结构,并和表中的数据一起输出到客户端.

 

1, 编写GetDBInfoServlet.java

 

 

 

package cn.apache.pl;

 

import java.io.*;

import java.sql.*;

import java.util.ArrayList;

import javax.servlet.*;

import javax.servlet.http.*;

 

public class GetDBInfoServlet extends HttpServlet

{

    private String url;

    private String user;

    private String password;

   

    public void init() throws ServletException

    {

       ServletContext sc = getServletContext();

       String driverClass  = sc.getInitParameter("driverClass");

       url = sc.getInitParameter("url");

       user = sc.getInitParameter("user");

       password = sc.getInitParameter("password");

      

       try

       {

           Class.forName(driverClass);

       }catch(ClassNotFoundException ce)

       {

           throw new UnavailableException("数据库驱动加载失败");

       }

    }

   

    public void doGet(HttpServletRequest req, HttpServletResponse resp)

       throws IOException, ServletException

    {

       Connection conn = null;

       Statement stmt = null;

       ResultSet rs = null;

      

       try

       {

           conn = DriverManager.getConnection(url, user, password);

          

           resp.setContentType("text/html; charset=gb2312");

           PrintWriter out = resp.getWriter();

           out.println("<html><head>");

           out.println("<title>数据库表的信息</title>");

           out.println("</head><body>");

          

           //调用请求对象的getParameter()方法得到查询的表名

           String tableName = req.getParameter("tableName");

          

           //如果表名为空,则执行if块内的代码

           if(null == tableName || tableName.equals(""))

           {

              //调用连接对象的getMetaData()方法得到DatabaseMetaData对象

              DatabaseMetaData dbMeta = conn.getMetaData();

             

              /*

               *调用DatabaseMetaData对象的getTables()得到,传递"TABLE"参数

               *(代码中使用new String[]{"TABLE"})获取数据库中所有表的信息,

               *返回一个结果集对象

               *还可以传递"VIEW",获取数据库中视图的信息

               */

              rs = dbMeta.getTables(null, null, null, new String[]{"TABLE"});

             

              //输出一个表单

              out.println("<form action=\"getdbinfo\" method=\"get\">");

             

              //表单中有一个列表框

              out.println("<select size=1 name=tableName>");

              while(rs.next())

              {

                  //调用getString("TABLE_NAME")得到表的名字

                  out.println("<option value="+rs.getString("TABLE_NAME")+">");

                  out.println(rs.getString("TABLE_NAME"));

                  out.println("</option>");

              }

              out.println("</select><p>");

             

              out.println("<input type=\"submit\" value=\"提交\">");

              out.println("</form>");

           }

          

           //如果用户提交了表名参数,则执行else

           else

           {

              stmt = conn.createStatement();

             

              //查询表中所有字段,返回结果集

              rs = stmt.executeQuery("select * from "+tableName);

             

              //调用ResultSet对象的getMetaData()方法ResultSetMetaData对象

              ResultSetMetaData rsMeta = rs.getMetaData();

             

              //调用ResultSetMetaData对象的getColumnCount()方法得到结果集中列的总数

              int columnCount = rsMeta.getColumnCount();

             

              //以表格形式输出表的结构

              out.println("<table border=1>");

              out.println("<caption>表的结构</caption>");

              out.println("<tr><th>字段名</th><th>字段类型</th><th>最大字符宽度</th></tr>");

             

              //构造一个ArrayList集合对象,用于存储表中字段的名字

              ArrayList<String> al = new ArrayList<String>();

             

              for(int i=1; i<=columnCount; i++)

              {

                  out.println("<tr>");

                 

                  //调用ResultSetMetaData对象的getColumnName()方法得到列的名字

                  String columnName = rsMeta.getColumnName(i);

                 

                  out.println("<td>"+columnName+"</td>");

                 

                  //将列的名字保存到ArrayList集合中

                  al.add(columnName);

                 

                  /*

                   *调用ResultSetMetaData对象的getColumnTypeName()方法得到列的

                   *数据库特定的类型名 和 列的最大字符宽度

                   */

                  out.println("<td>"+rsMeta.getColumnTypeName(i)+"</td>");

                  out.println("<td>"+rsMeta.getColumnDisplaySize(i)+"</td>");

              }

             

              out.println("</table><p>");

             

              //以表格形式输出表中的数据

              out.println("<table border=1>");

              out.println("<caption>表中的数据</caption>");

              out.println("<tr>");

             

              //通过for循环取出存储在ArrayList集合中的列名,作为表格的表头

              for(int i=0; i<columnCount; i++)

              {

                  out.println("<th>"+al.get(i)+"</th>");

              }

             

              while(rs.next())

              {

                  out.println("<tr>");

                  for(int i=1; i<=columnCount; i++)

                  {

                     out.println("<td>"+rs.getString(i)+"</td>");

                  }

                  out.println("</tr>");

              }

              out.println("</table>");

           }

           out.println("</body></html>");

           out.close();

       }catch(SQLException se)

       {

           se.printStackTrace();

        }finally

       {

           if(rs != null)

           {

              try

              {

                  rs.close();

              }catch(SQLException se)

              {

                  se.printStackTrace();

              }

              rs = null;          

           }

           if(stmt != null)

           {

              try

              {

                  stmt.close();

              }catch(SQLException se)

              {

                  se.printStackTrace();

              }

              stmt = null;

           }

           if(conn != null)

           {

              try

              {

                  conn.close();

              }catch(SQLException se)

              {

                  se.printStackTrace();

              }

              conn = null;

           }

       }

    }

}

 

 

 

2,部署Servlet:

 

 

<!-- GetDBInfoServlet.java -->

 

<servlet>

    <servlet-name>GetDBInfoServlet</servlet-name>

    <servlet-class>cn.apache.pl.GetDBInfoServlet</servlet-class>

</servlet>

 

<servlet-mapping>

    <servlet-name>GetDBInfoServlet</servlet-name>

    <url-pattern>/getdbinfo</url-pattern>

</servlet-mapping>

 

 

 

3,运行GetDBInfoServlet

启动Tomact服务器,在浏览器中打开: http://localhost:8080/ch08/getdbinfo

 

 

选择account表后,点”提交”,打开

         表的结构

字段名

字段类型

最大字符宽度

userid

VARCHAR

20

balance

FLOAT

6

 

 表中的数据

userid

balance

彭磊

500.00

徐璐

1000.50

 

再选”bookinfo, 点”提交”,打开

           表的结构

字段名

字段类型

最大字符宽度

id

INTEGER

11

title

VARCHAR

100

author

VARCHAR

100

bookconcern

VARCHAR

200

publish_date

DATE

10

price

FLOAT

4

amount

SMALLINT

6

remark

VARCHAR

400

 

                                     表中的数据

id

title

author

bookconcern

publish_date

price

amount

remark

1

JAVA从入门到精通

孙卫琴

电子工业出版社

2004-06-01

34.00

35

null

2

JSP应用开发详解

刘小华

清华大学出版社

2005-10-03

56.00

20

null

3

MySQL数据库编程

孙鑫

人民邮电出版社

2006-06-29

78.00

10

null

4

JAVA 国际认证

margin: 0cm

分享到:
评论

相关推荐

    基于OpenGL的C语言的魔方项目.zip

    C语言是一种广泛使用的编程语言,它具有高效、灵活、可移植性强等特点,被广泛应用于操作系统、嵌入式系统、数据库、编译器等领域的开发。C语言的基本语法包括变量、数据类型、运算符、控制结构(如if语句、循环语句等)、函数、指针等。在编写C程序时,需要注意变量的声明和定义、指针的使用、内存的分配与释放等问题。C语言中常用的数据结构包括: 1. 数组:一种存储同类型数据的结构,可以进行索引访问和修改。 2. 链表:一种存储不同类型数据的结构,每个节点包含数据和指向下一个节点的指针。 3. 栈:一种后进先出(LIFO)的数据结构,可以通过压入(push)和弹出(pop)操作进行数据的存储和取出。 4. 队列:一种先进先出(FIFO)的数据结构,可以通过入队(enqueue)和出队(dequeue)操作进行数据的存储和取出。 5. 树:一种存储具有父子关系的数据结构,可以通过中序遍历、前序遍历和后序遍历等方式进行数据的访问和修改。 6. 图:一种存储具有节点和边关系的数据结构,可以通过广度优先搜索、深度优先搜索等方式进行数据的访问和修改。 这些数据结构在C语言中都有相应的实现方式,可以应用于各种不同的场景。C语言中的各种数据结构都有其优缺点,下面列举一些常见的数据结构的优缺点: 数组: 优点:访问和修改元素的速度非常快,适用于需要频繁读取和修改数据的场合。 缺点:数组的长度是固定的,不适合存储大小不固定的动态数据,另外数组在内存中是连续分配的,当数组较大时可能会导致内存碎片化。 链表: 优点:可以方便地插入和删除元素,适用于需要频繁插入和删除数据的场合。 缺点:访问和修改元素的速度相对较慢,因为需要遍历链表找到指定的节点。 栈: 优点:后进先出(LIFO)的特性使得栈在处理递归和括号匹配等问题时非常方便。 缺点:栈的空间有限,当数据量较大时可能会导致栈溢出。 队列: 优点:先进先出(FIFO)的特性使得

    QT-qtablewidget表头添加复选框QHeaderView

    在 Qt 框架中,要在 QTableWidget的表头中添加复选框,可以通过继承 QHeaderView 并重写 paintSection 方法来实现。 介绍一种继承 QHeaderView的方法分别实现QTableWidget中添加复选框,可全选/全不选/部分选。

    分段划线测量表格通用版.doc

    分段划线测量表格通用版.doc

    扫雷小游戏(JAVA SE).zip

    该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 该资源内项目源码是个人的课程设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

    啊哈算法哈磊基于队列的优化Bellman-ford算法搜索单源最短路径-Java实现

    本资源源自《啊哈算法》的高级算法实践,专注于讲解基于队列优化的Bellman-Ford算法在单源最短路径问题上的应用,并提供了Java语言的实现代码。哈磊老师以其独特的教学视角,不仅详细解析了传统Bellman-Ford算法的原理及其在处理含有负权边图中的优势,还深入介绍了如何通过队列优化(通常指SPFA算法)来加速这一过程,减少不必要的松弛操作,提高算法效率。 Java实现部分,代码实现清晰,注释详尽,从初始化距离数组、设置源节点开始,逐步展示如何维护一个队列来记录待检查的顶点,并通过队列进行有效的顶点遍历和松弛操作。本资源通过实例演示了如何高效地更新路径长度,检测负权环,并最终确定从源点到图中所有其他顶点的最短路径。 这份资源特别适合对图算法有深入学习需求的学生、工程师以及算法爱好者,尤其是那些关注算法性能优化和实际应用的人士。通过学习这份资源,你不仅能掌握Bellman-Ford算法的核心逻辑,还将理解如何通过队列优化策略提升算法的执行效率,为解决复杂的网络最短路径问题提供有力工具。在算法学习和软件开发的道路上,这将是一块宝贵的垫脚石,助你攀登更高的算法高峰。

    基于一阶倒立摆线性二次型最优控制

    基于一阶倒立摆线性二次型最优控制

    Java课程设计,做个扫雷游戏.zip

    该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 该资源内项目源码是个人的课程设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

    计算机毕业设计-asp网上体育用品商店的设计与实现(LW+源代码).zip

    计算机毕业设计资源包含(项目部署视频+源码+LW+开题报告等等),所有项目经过助教老师跑通,有任何问题可以私信博主解决,可以免费帮部署。

    springboot学生考勤系统.rar

    基于Java的教师考勤管理系 统 成绩查看 请假申请 考勤管理 用户 注册登录 个人中心 系统管理 学生管理 管理员 老师管理 成绩管理 考勤信息管理 请假信息管理 个人中心 公告管理 个人中心 学生考勤管理 教师 学生请假申请管理 成绩管理 班级管理 公告管理

    Delphi 12 控件之EhLib.v10.2.42 for Delphi 5-12.src.rar

    EhLib.v10.2.42 for Delphi 5-12.src.rar

    chromedriver-win64_118.0.5957.0.zip

    chromedriver-win64_118.0.5957.0.zip

    基于Selenium的Java爬虫实战(内含谷歌浏览器Chrom和Chromedriver版本124.0.6350.0)

    资源包括: 1.Java爬虫实战代码 2.selenium学习笔记 3.代码演示视频 4.谷歌浏览器chrom124.0.6350.0 chrome-linux64.zip chrome-mac-arm64.zip chrome-mac-x64.zip chrome-win32.zip chrome-win64.zip 5.谷歌浏览器驱动器Chromedriver124.0.6350.0 chromedriver-linux64.zip chromedriver-mac-arm64.zip chromedriver-mac-x64.zip chromedriver-win32.zip chromedriver-win64.zip 特别说明:Chrome 为测试版(不会自动更新) 仅适用于自动测试。若要进行常规浏览,请使用可自动更新的标准版 Chrome。)

    【C/C++免费资源】无尽之剑V3.5

    无尽之剑3.5震撼来袭!自创游戏,完美还原我的世界细节! 更新日志 3.5:更新图签,优化战斗盔甲防御机制 3.0:更新附魔,更改合成机制 2.5:更新撸树功能 2.0:更新盔甲 1.5:更新工作台(合成)功能 1.0:更新打怪,挖矿功能 0.5:框架搞好了

    应届生单页简历模版15份

    【单页简历模版15份】 一份优秀的简历能为求职就业的过程做好铺垫。 简历模版 一份简历最关键的地方之一就是一个简历模板,选择一个好的简历模版最为关键。在选择的时候一定要选择比较清晰直观的模版。 有的反例就是:个人信息在左边一栏,总的来说,没有那么直观。 简历是不断迭代优化的,所以个人比较喜欢WORD版本的简历模版。当然,也有人喜欢用类似超级简历之类的软件网站来生成简历,有时候也是可以的。 简历一般不宜过长,要保证简洁,一般1到2页即可。一般一页最好,但如果个人亮点足够多(比如多段高含金量的实习经历),也可以扩展到2页,没有必要为了一页删减去自己的亮点。 一份合格的简历应该怎么写:https://blog.csdn.net/qq_33445788/article/details/139545096?spm=1001.2014.3001.5502 如何让简历如虎添翼,如何应对面试游刃有余? 解锁这几个秘技!【后端篇】:https://blog.csdn.net/qq_33445788/article/details/139691619?spm=1001.2014.3001.5502

    基于JSP+Servlet+JavaBean的超市进销存管理系统.zip

    该资源内项目源码是个人的课程设计、毕业设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 该资源内项目源码是个人的课程设计,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。

    php+sql成绩查询系统(系统+论文+答辩PPT).zip

    php+sql成绩查询系统(系统+论文+答辩PPT).zip

    用C语言写的基于控制台的一个天气客户端.zip

    C语言是一种广泛使用的编程语言,它具有高效、灵活、可移植性强等特点,被广泛应用于操作系统、嵌入式系统、数据库、编译器等领域的开发。C语言的基本语法包括变量、数据类型、运算符、控制结构(如if语句、循环语句等)、函数、指针等。下面详细介绍C语言的基本概念和语法。 1. 变量和数据类型 在C语言中,变量用于存储数据,数据类型用于定义变量的类型和范围。C语言支持多种数据类型,包括基本数据类型(如int、float、char等)和复合数据类型(如结构体、联合等)。 2. 运算符 C语言中常用的运算符包括算术运算符(如+、、、/等)、关系运算符(如==、!=、、=、<、<=等)、逻辑运算符(如&&、||、!等)。此外,还有位运算符(如&、|、^等)和指针运算符(如、等)。 3. 控制结构 C语言中常用的控制结构包括if语句、循环语句(如for、while等)和switch语句。通过这些控制结构,可以实现程序的分支、循环和多路选择等功能。 4. 函数 函数是C语言中用于封装代码的单元,可以实现代码的复用和模块化。C语言中定义函数使用关键字“void”或返回值类型(如int、float等),并通过“{”和“}”括起来的代码块来实现函数的功能。 5. 指针 指针是C语言中用于存储变量地址的变量。通过指针,可以实现对内存的间接访问和修改。C语言中定义指针使用星号()符号,指向数组、字符串和结构体等数据结构时,还需要注意数组名和字符串常量的特殊性质。 6. 数组和字符串 数组是C语言中用于存储同类型数据的结构,可以通过索引访问和修改数组中的元素。字符串是C语言中用于存储文本数据的特殊类型,通常以字符串常量的形式出现,用双引号("...")括起来,末尾自动添加'\0'字符。 7. 结构体和联合 结构体和联合是C语言中用于存储不同类型数据的复合数据类型。结构体由多个成员组成,每个成员可以是不同的数据类型;联合由多个变量组成,它们共用同一块内存空间。通过结构体和联合,可以实现数据的封装和抽象。 8. 文件操作 C语言中通过文件操作函数(如fopen、fclose、fread、fwrite等)实现对文件的读写操作。文件操作函数通常返回文件指针,用于表示打开的文件。通过文件指针,可以进行文件的定位、读写等操作。 总之,C语言是一种功能强大、灵活高效的编程语言,广泛应用于各种领域。掌握C语言的基本语法和数据结构,可以为编程学习和实践打下坚实的基础。

    chromedriver-win64_116.0.5804.0.zip

    chromedriver-win64_116.0.5804.0.zip

    fdsfdsfdsfdsfdsfdsfdsfds

    fdsa

    计算机毕业设计-ASP求职招聘网站设计(源代码+LW+开题报告+外文翻译+文献综述).zip

    计算机毕业设计资源包含(项目部署视频+源码+LW+开题报告等等),所有项目经过助教老师跑通,有任何问题可以私信博主解决,可以免费帮部署。

Global site tag (gtag.js) - Google Analytics