1.1. mysql数据库连接池使用(三)数据库元数据信息反射数据库获取数据库信息

有时候我们想要获取到数据库的基本信息,当前程序连接的那个数据库,数据库的版本信息,数据库中有哪些表,表中都有什么字段,字段都是什么类型。等等一些信息,我们称之为数据库的元数据信息。实际开发中hibernate等orm框架或者代码生成器都是通过元数据信息获取库、表的信息进行封装和操作。

元数据主要有三种:

 DatabaseMetaData元数据信息(获取数据库的信息)

 ResultSetMetaData 元数据信息(操作的表的元数据信息)

 ParameterMetaData元数据信息(参数的元数据信息)

本文下面的connection获取都是基于mysql数据库连接池使用(二)实现自己的数据库连接池实现的,不懂的可以参考,下面开始我们的学习之旅吧。

1.1.1. DatabaseMetaData元数据信息

获取数据库的元数据信息:

Connection con = JdbcUtils.getConnection(true);

// 数据库元数据信息

DatabaseMetaData dmd = con.getMetaData();

String version = dmd.getDatabaseProductVersion();

System.out.println("数据库版本" + version);

String name = dmd.getDatabaseProductName();

System.out.println("数据库名称 " + name);

String driverName = dmd.getDriverName();

System.out.println("驱动名称 " + driverName);

测试:

08:21:06.568 [main] DEBUG cn.xhgg.test.DataSourceManager - DefaultConnectionPoolName is 3000...

08:21:06.632 [main] DEBUG cn.xhgg.test.DataSourceManager - Init DataSource 3000...

08:21:06.633 [main] DEBUG cn.xhgg.test.DataSourceManager - Init DataSource 5000...

数据库版本5.6.24

数据库名称 MySQL

驱动名称 MySQL Connector Java

1.1.2. ResultSetMetaData 元数据信息

获取此 ResultSet 对象的列的编号、类型和属性。

主要是获取ResultSet中数据库表中的所以字段信息:

数据库表的定义如下图:

代码如下:

String sql = "select * from test1";

Connection con = JdbcUtils.getConnection(true);

PreparedStatement pst = con.prepareStatement(sql);

ResultSet rs = pst.executeQuery();

// 得到结果集元数据对象

ResultSetMetaData rmd = rs.getMetaData();

if (rs.next()) {

// 得到每条记录有几列

//操作的表一共有多少字段

int count = rmd.getColumnCount();

System.out.println(count);

for (int i = 0; i < count; i++) {

String name = rmd.getColumnName(i + 1); // 根据列号得到每一列的名称

String columnTypeName = rmd.getColumnTypeName(i + 1);

System.out.print(name + "    "+columnTypeName);

int type = rmd.getColumnType(i + 1);

System.out.println(type);

System.out.println("------------------------");

}

}

输出如下:

08:38:55.990 [main] DEBUG cn.xhgg.test.DataSourceManager - DefaultConnectionPoolName is 3000...

08:38:56.059 [main] DEBUG cn.xhgg.test.DataSourceManager - Init DataSource 3000...

08:38:56.060 [main] DEBUG cn.xhgg.test.DataSourceManager - Init DataSource 5000...

3

id    INT4

------------------------

name    VARCHAR12

------------------------

age    INT4

------------------------

1.1.3. ParameterMetaData元数据信息的获取

获取此 PreparedStatement 对象的参数的编号、类型和属性

ParameterMetaData主要可以获取到用户传入的参数的一些元数据信息如下:

代码如下:

String sql = "select * from test1 where name=?";

Connection con = JdbcUtils.getConnection(true);

PreparedStatement pst = con.prepareStatement(sql);

pst.setString(1, "1");

pst.executeQuery();

// 关于当前要操作的sql语句中的参数相关信息

ParameterMetaData pmd = pst.getParameterMetaData();

// 得要要执行的sql语句中有几个?

int count = pmd.getParameterCount();

System.out.println(count);

mysql数据库连接池使用(三)数据库元数据信息反射数据库获取数据库信息的更多相关文章

  1. Python实现Mysql数据库连接池

    python连接Mysql数据库: python编程中可以使用MySQLdb进行数据库的连接及诸如查询/插入/更新等操作,但是每次连接mysql数据库请求时,都是独立的去请求访问,相当浪费资源,而且访 ...

  2. python3 实现mysql数据库连接池

    首先声明一下,这篇博客进行了通过自己的代码方式,加上这篇博客,最后总结出这段代码.参考博客连接:http://blog.csdn.net/zbc1090549839/article/details/5 ...

  3. 一个简单的MySql数据库连接池的实现

    package cn.hc.connectionPool; import java.io.IOException; import java.io.InputStream; import java.sq ...

  4. MySql数据库连接池专题

    MySql数据库连接池专题 - aspirant - 博客园https://www.cnblogs.com/aspirant/p/6747238.html

  5. 【Java/JDBC】利用ResultSetMetaData从数据库的某表中获取字段信息并存到csv文件

    代码下载:https://files.cnblogs.com/files/xiandedanteng/FindNotnullColumns20191102-2.rar 这篇还不够完善,请看更完善的续篇 ...

  6. 【数据库开发】如何创建MySQL数据库连接池(一个基于libmysql的MySQL数据库连接池示例(C/C++版))

      http://blog.csdn.net/horace20/article/details/8087557 1.  一般架构说明 图 1 架构层次图 一般应用系统数据库访问模块可大致分为两层,一层 ...

  7. MySql数据库连接池

    1.传统链接(如下为示意图) 注意: (1).传统方式找DriverManager要连接,数目是有限的. (2).传统方式的close(),并没有将Connection重用,只是切断应用程序和数据库的 ...

  8. mysql数据库连接池使用(一)dbcp方式的配置

    Apache的数据库连接池 DBCP的常用配置说明,因为项目中用到了需要对其封装,所以必须先了解怎么配置以及各个配置字段的含义,理解的基础上开发我们自己的数据库连接池.可以参考官网dbcp官网. db ...

  9. mysql数据库连接池 手动编写

    源码来源于http://www.toutiao.com/a6350448676050174209/,留存以供以后参考学习 先上一张项目托普图 然后分别列出各个文件的源码: MyPool.java(就是 ...

随机推荐

  1. 洛谷mNOIP模拟赛Day1-斐波那契

    题目背景 大样例下发链接:http://pan.baidu.com/s/1c0LbQ2 密码:jigg 题目描述 小 C 养了一些很可爱的兔子. 有一天,小 C 突然发现兔子们都是严格按照伟大的数学家 ...

  2. 【Codeforces 851D Arpa and a list of numbers】

    Arpa的数列要根据GCD变成好数列. ·英文题,述大意:      给出一个长度为n(n<=5000000)的序列,其中的元素a[i]<=106,然后输入两个数x,y(x,y<=1 ...

  3. bzoj 1875: [SDOI2009]HH去散步

    Description HH有个一成不变的习惯,喜欢饭后百步走.所谓百步走,就是散步,就是在一定的时间 内,走过一定的距离. 但 是同时HH又是个喜欢变化的人,所以他不会立刻沿着刚刚走来的路走回. 又 ...

  4. (转载)总结一下SQL语句中引号(')、quotedstr()、('')、format()在SQL语句中的用法

    总结一下SQL语句中引号(').quotedstr().('').format()在SQL语句中的用法以及SQL语句中日期格式的表示(#).('')在Delphi中进行字符变量连接相加时单引号用('' ...

  5. Linux编程之内存池的设计与实现(C++98)

    假设服务器的硬件资源"充裕",那么提高服务器性能的一个很直接的方法就是空间换时间,即"浪费"服务器的硬件资源,以换取其运行效率.提升服务器性能的一个重要方法就是 ...

  6. Vegas Pro 15软件界面对比

    大家都知道Vegas是一款专业的视频制作软件,而新版的VEGAS Pro 15更是专业性十足.好了,废话不多说,接下来小编就带大家具体的看一下Vegas 15界面都有哪些更新吧! 一.软件图标 图1: ...

  7. easyui datagrid 排序问题

    $('#dg').datagrid({ remoteSort:false,④  sortName:'sysfield', ①  sortOrder:'desc',② columns:[[ {field ...

  8. width:100vh有感而发

    在看一个网页的代码是看到 width:100vh  纳尼...这这我怎么没有见过,这是个什么属性,随之有看到 min-height:calc(100vh + 51px);这尼玛又是怎么用的.... 感 ...

  9. IntelliJ IDEA设置统一编码utf-8

    File菜单->Other Settings->Default Settings->File Encodings 全改成utf-8!

  10. 整理spring定时器corn表达式

    1.结构 corn从左到右(用空格隔开):秒 分 小时 月份中的日期 月份 星期中的日期 年份 2.各字段的含义   字段 允许值 允许的特殊字符 秒 0~59 - * / 分 0~59 - * / ...