mysql databasemetadata_DatabaseMetaData和ResultSetMetaData接口获取元数据的方法

mysql databasemetadata_DatabaseMetaData和ResultSetMetaData接口获取元数据的方法DatabaseMeta 和 ResultSetMet 就是两个常用的获取数据库元数据相关信息的接口 本文讲解 DatabaseMeta 和 ResultSetMet 接口获取元数据的方法 packagewww wlkankan com importjava sql Connection importjava sql DatabaseMeta importja

DatabaseMetaData和ResultSetMetaData就是两个常用的获取数据库元数据相关信息的接口,本文讲解DatabaseMetaData和ResultSetMetaData接口获取元数据的方法。

package www.wlkankan.com;

import java.sql.Connection;

import java.sql.DatabaseMetaData;

import java.sql.DriverManager;

import java.sql.ResultSet;

import java.sql.SQLException;

public class testMatadata {

public static void main(String[] args) {

Connection conn=null;

//1. JDBC连接MYSQL的代码很标准。

String DRIVER=”com.mysql.jdbc.Driver”;

String URL=”jdbc:mysql://127.0.0.1:3306/test”;

String USER=”root”;

String PASSWORD=”root”;

try {

//1.加载驱动程序

Class.forName(DRIVER);

//2.获得数据库链接

conn=DriverManager.getConnection(URL, USER, PASSWORD);

DatabaseMetaData dbmd = conn.getMetaData();

ResultSet rs = null;

System.out.println(“数据库已知的用户: “+ dbmd.getUserName());

System.out.println(“数据库的系统函数的逗号分隔列表: “+ dbmd.getSystemFunctions());

System.out.println(“数据库的时间和日期函数的逗号分隔列表: “+ dbmd.getTimeDateFunctions());

System.out.println(“数据库的字符串函数的逗号分隔列表: “+ dbmd.getStringFunctions());

System.out.println(“数据库供应商用于 ‘schema’ 的首选术语: “+ dbmd.getSchemaTerm());

System.out.println(“数据库URL: ” + dbmd.getURL());

System.out.println(“是否允许只读:” + dbmd.isReadOnly());

System.out.println(“数据库的产品名称:” + dbmd.getDatabaseProductName());

System.out.println(“数据库的版本:” + dbmd.getDatabaseProductVersion());

System.out.println(“驱动程序的名称:” + dbmd.getDriverName());

System.out.println(“驱动程序的版本:” + dbmd.getDriverVersion());

System.out.println(“数据库中使用的表类型”);

rs = dbmd.getTableTypes();

while (rs.next()) {

System.out.println(rs.getString(“TABLE_TYPE”));

}

// 获取连接

PreparedStatement pstmt = conn.prepareStatement(“select * from test.user “);

rs = pstmt.executeQuery();

// 得到结果集元数据

//目标:通过结果集元数据,得到列的名称

ResultSetMetaData rs_metaData = rs.getMetaData();

while (rs.next()) {

int count = rs_metaData.getColumnCount();

for (int i=0; i

// 得到列的名称

String columnName = rs_metaData.getColumnName(i + 1);

// 获取每一行的每一列的值

Object columnValue = rs.getObject(columnName);

System.out.print(columnName + “=” + columnValue + “,\n”);

}

}

} catch (ClassNotFoundException e) {

e.printStackTrace();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

输出

数据库已知的用户: root@localhost

数据库的系统函数的逗号分隔列表: DATABASE,USER,SYSTEM_USER,SESSION_USER,PASSWORD,ENCRYPT,LAST_INSERT_ID,VERSION

数据库的时间和日期函数的逗号分隔列表: DAYOFWEEK,WEEKDAY,DAYOFMONTH,DAYOFYEAR,MONTH,DAYNAME,MONTHNAME,QUARTER,WEEK,YEAR,HOUR,MINUTE,SECOND,PERIOD_ADD,PERIOD_DIFF,TO_DAYS,FROM_DAYS,DATE_FORMAT,TIME_FORMAT,CURDATE,CURRENT_DATE,CURTIME,CURRENT_TIME,NOW,SYSDATE,CURRENT_TIMESTAMP,UNIX_TIMESTAMP,FROM_UNIXTIME,SEC_TO_TIME,TIME_TO_SEC

数据库的字符串函数的逗号分隔列表: ASCII,BIN,BIT_LENGTH,CHAR,CHARACTER_LENGTH,CHAR_LENGTH,CONCAT,CONCAT_WS,CONV,ELT,EXPORT_SET,FIELD,FIND_IN_SET,HEX,INSERT,INSTR,LCASE,LEFT,LENGTH,LOAD_FILE,LOCATE,LOCATE,LOWER,LPAD,LTRIM,MAKE_SET,MATCH,MID,OCT,OCTET_LENGTH,ORD,POSITION,QUOTE,REPEAT,REPLACE,REVERSE,RIGHT,RPAD,RTRIM,SOUNDEX,SPACE,STRCMP,SUBSTRING,SUBSTRING,SUBSTRING,SUBSTRING,SUBSTRING_INDEX,TRIM,UCASE,UPPER

数据库供应商用于 ‘schema’ 的首选术语:

数据库URL: jdbc:mysql://127.0.0.1:3306/test

是否允许只读:false

数据库的产品名称:MySQL

数据库的版本:5.7.26-log

驱动程序的名称:MySQL Connector Java

驱动程序的版本:mysql-connector-java-5.1.32 ( Revision: -848-mlwabor66widht1n )

数据库中使用的表类型:

LOCAL TEMPORARY

SYSTEM TABLE

SYSTEM VIEW

TABLE

VIEW

user_id=1,

user_name=fanny,

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/232926.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Ubuntu18 安装yum

    Ubuntu18 安装yum一.先执行一下命令更新软件源sudoapt-getupdatesudoapt-getupgrade二.检测是否安装build-essential包sudoapt-getinstallbuild-essential

    2022年6月24日
    23
  • java程序出现问题:java.sql.SQLException: ORA-01008: 并非所有变量都已绑定

    java程序出现问题:java.sql.SQLException: ORA-01008: 并非所有变量都已绑定异常提示是并非所有变量都已绑定,实际上从sql语句上看是没有问题,直接使用在数据库也是有效的,那么他为什么会报ORA-01008:并非所有变量都已绑定,这个这个问题一般出现在sql语句,因为程序写的sql语句可能出现所查询没有的字段,而此处sql语句没有错误,出问题的地方是preparedStatemnt.executeUpdate(sql)这条语句,这是使用PreparedStateme…

    2025年9月2日
    9
  • 获取和分析Dump的几种工具简介[通俗易懂]

    获取和分析Dump的几种工具简介[通俗易懂]最近在进一步学习support技能的时候,了解到分析Dump的重要性,经过学习,做一些笔记。一、什么是Dump文件。Dump文件时进程的内存镜像。可以把程序的执行状态保存到Dump文件中。Dump文件分为内核模式Dump和用户模式Dump。其中内核模式Dump是操作系统创建的崩溃转储,例如蓝屏Dump。而在我们调试或Troubleshooting过程中使用的Dump是用户模式Dump,又分为F…

    2022年10月2日
    2
  • 支持向量机通俗导论(理解SVM的三层境界)

    支持向量机通俗导论(理解SVM的三层境界)支持向量机通俗导论(理解SVM的三层境界)作者:July。致谢:pluskid、白石、JerryLead。说明:本文最初写于2012年6月,而后不断反反复复修改&优化,修改次数达上百次,最后修改于2016年11月。声明:本文于2012年便早已附上所有参考链接,并注明是篇“学习笔记”,且写明具体参考了pluskid等人的文章。文末2013年的PDF是为证。另…

    2022年6月14日
    31
  • 电路驱动能力

    电路驱动能力1.在电子电路中为什么有的地方电压会被拉低2,驱动能力是什么意思,如何提高驱动能力在很多资料上看到说驱动能力不够是因为提供的电流太小,为什么不说电压呢?在很多限制的条件都是电流而不是电压,为什么?电压和电流满足欧姆定律,考虑谁不是都一样吗?还有就是,在什么情况下要考虑驱动能力,是不是只有在集成电路输出口要考虑?那你怎么知道这个集成电路驱动能力是不是不够?在平常的电路中(非集成电路I

    2022年5月13日
    56
  • UMLet的安装及使用

    UMLet的安装及使用

    2022年3月11日
    134

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号