继往开来 吐故纳新
日历
网志分类
· 所有网志 (990)
· 个人作品 (62)
· 软件设计 (33)
· 面向对象编程 (22)
· JavaAPI (39)
· Java开源工具 (31)
· Swing (34)
· Java语法细节 (39)
· 样式表CSS (12)
· XML (10)
· J2EE(JavaEE) (23)
· 算法数据结构 (64)
· 正则表达式 (4)
· 软件知识 (6)
· Java线程 (9)
· Web开发.Jsp/Servlet/Struts (20)
· 程序随想录 (7)
· Spring (5)
· Hibernate (7)
· J2SE 高级 (2)
· J2SE 高级 (0)
· Web开发.Ajax (16)
· Web开发.JavaScript (43)
· DB4O (2)
· Web开发.CSS/Html (22)
· C# (20)
· ERP (4)
· JDBC (1)
· 编程资源 (16)
· 编程感悟 (29)
· DB/Sql (13)
· VB (29)
· VC (2)
· 桌面脚本 (3)
· 新兴软件 (3)
· 英语学习 (21)
· 网文转载 (159)
· 职场风云 (39)
· 诗词歌赋 (32)
· 生活感言 (77)
· 奇文共赏 (13)
· 财经纵横 (6)
· 未分类 (11)
站内搜索
友情链接
· 歪酷博客
· 我的歪酷 非非共享界
· 偶要雷锋
· 豆瓣
· nczonline
· 当当网
· easyjf中文站
· Donews
· 天极Java文章列表
· W3CSchool
· taiten的BLOG
· Dojo中国
· Dojo
· Extjs.com
· Lifehack中文网志
· JaveEye的一个AS专题
· Banq's JDon
· Java 中文网址大全
· 梦想Java
· 360Doc个人图书馆
· java开源大全
· 我在硅谷动力的软件下载站
· 站长中国
· 随意贴
· CSS教学素材站
· java 参考中文站
· 面向构件与SOA社区
· 彩字生成
· 派派小说论坛
· 如坐春风
· 英语学习网
· BBC CHina
· www.dlbang.com
· 古文竖排格式在线转化工具
· 免费家谱
· 图片上传基地
· 风景壁纸
· 和风细雨
· MyC#BlogInCsdn

订阅 RSS

0207467

歪酷博客

开此博一为经验积累,二为资料收集,三为同道交流,四为资源共享.
« 上一篇: 取得表空间,表空间下表信息,表中字段信息的Sql语句(oracle,sql server) 下一篇: jtable怎样设置某列或整张表的值不能被修改 »
Junglesong @ 2007-02-15 19:53

  上一篇文章讲到了用Sql语句取得表空间,表空间下的表,表的字段信息的方法,但是我们还有更加通用的方法,那就是用Jdbc API直接操作,请看下面三个函数.

  /**
   * 取得数据库中所有Schema
   *
   * @return
   */
  public List getTableSchemas(){
    List retval = new ArrayList();
    try {
      Connection connection = getConnection();
      DatabaseMetaData dbmd = connection.getMetaData();
      ResultSet resultSet = dbmd.getSchemas();

      while (resultSet.next()) {
        String tableName = resultSet.getString(1);
        retval.add(tableName);
      }
    } catch (SQLException e) {     
      e.printStackTrace();
    }

    return retval;
  }

  /**
   * 取得某Schema下所有表名
   *
   * @param schema
   * @return
   */
  public List getTablesInSchema(String schema){
    List retval = new ArrayList();

    try {
      Connection connection = getConnection();
      DatabaseMetaData dbmd = connection.getMetaData();
      String[] types = { "TABLE" };
      ResultSet resultSet = dbmd.getTables(null, null, "%", types);

      // Get the table names
      while (resultSet.next()) {
        // Get the table name
        String tableName = resultSet.getString(3);
        String tableSchema = resultSet.getString(2);

        if (tableSchema.equals(schema)) {
          retval.add(tableName);
        }
      }
    } catch (SQLException e) {
      e.printStackTrace();
    }

    return retval;
  }

  /**
   * 取得某表下的所有字段信息
   *
   * @param table
   * @return
   */
  public List getColumnInfoesInTable(String table){
    List retval = new ArrayList();

    try {
      Connection connection = getConnection();

      // Create a result set
      Statement stmt = connection.createStatement();
      ResultSet rs = stmt.executeQuery("SELECT * FROM " + table);

      // Get result set meta data
      ResultSetMetaData rsmd = rs.getMetaData();
      int numColumns = rsmd.getColumnCount();

      // Get the column names; column indices start from 1
      for (int i = 1; i < numColumns + 1; i++) {
        ColumnInfoBean columnInfoBean = new ColumnInfoBean();

        // 字段名
        columnInfoBean.setName(rsmd.getColumnName(i));

        // 字段类型
        columnInfoBean.setTypeName(rsmd.getColumnTypeName(i));

        // 字段类型对应的java类名
        columnInfoBean.setClassName(rsmd.getColumnClassName(i));

        // 显示的长度
        columnInfoBean.setDisplaySize(String.valueOf(rsmd
            .getColumnDisplaySize(i)));

        // Precision
        columnInfoBean.setPrecision(String
            .valueOf(rsmd.getPrecision(i)));

        // Scale
        columnInfoBean.setScale(String.valueOf(rsmd.getScale(i)));

        retval.add(columnInfoBean);
      }
    } catch (SQLException e) {
      e.printStackTrace();
    }

    return retval;
  }





评论 / 个人网页 / 扔小纸条
* 昵称

已经注册过? 请登录

新用户请先注册 以便能显示头像及追踪评论回复

Email
网址
* 评论
表情
 


 

分类小组论坛
杂谈 , 娱乐、八卦 , 文学、艺术 , 体育 , 旅游、同城 , 象牙塔 , 情感 , 时尚、生活 , 星座 , 科技

请注意遵守中华人民共和国法律法规, 如威胁到本站生存, 将依法向有关部门报告, 同时本站的相关记录可能成为对您不利的证据.

相关法律法规
全国人大常委会关于维护互联网安全的决定
中华人民共和国计算机信息系统安全保护条例
中华人民共和国计算机信息网络国际联网管理暂行规定
计算机信息网络国际联网安全保护管理办法
计算机信息系统国际联网保密管理规定