DatabaseMetaData元数据

DatabaseMetaData元数据通过java.sql.DatabaseMetaData接口,您可以获得有关您已连接到的数据库的元数据。例如,你可以看到哪些表的数据库,和什么中定义的列的每个表的数量,是否是给定功能支持等。DatabaseMetaData接口包含很多的方法,和并不是所有将在本教程中覆盖。你应该看看的JavaDoc。此文本将只是覆盖面不够,给你一种感觉,你可以用它。获得一个DatabaseMetaData实例

大家好,又见面了,我是你们的朋友全栈君。

简要概述:
数据:数据库、表、列的定义信息。

**Connection.getMetaData()
DataBaseMetaData对象**
– getURL():返回一个String类对象,代表数据库的URL
– getDatabaseProductName():返回数据库的产品名称。
– getDatabaseProductVersion():返回数据库的版本号。
– getDriverName():返回驱动驱动程序的名称。
– getDriverVersion():返回驱动程序的版本号。
– isReadOnly():返回一个boolean值,指示数据库是否只允许读操作。

通过java.sql.DatabaseMetaData接口,您可以获得有关您已连接到的数据库的元数据。例如,你可以看到哪些表的数据库,和什么中定义的列的每个表的数量,是否是给定功能支持等。

DatabaseMetaData接口包含很多的方法,和并不是所有将在本教程中覆盖。你应该看看的 JavaDoc。此文本将只是覆盖面不够,给你一种感觉,你可以用它。

获得一个 DatabaseMetaData 实例
您从Connection,这样获得的DatabaseMetaData对象 ︰

DatabaseMetaData databaseMetaData = connection.getMetaData();

一旦你得到此DatabaseMetaData实例,你可以调用方法它获取有关数据库的元数据。

数据库产品名称和版本
您可以获取数据库产品名称和版本,像这样 ︰

int    majorVersion   = databaseMetaData.getDatabaseMajorVersion();
int    minorVersion   = databaseMetaData.getDatabaseMinorVersion();

String productName    = databaseMetaData.getDatabaseProductName();
String productVersion = databaseMetaData.getDatabaseProductVersion();

如果你已经知道到底什么数据库对运行应用程序,您可能不需要这个。但是,如果你正在开发一种产品,需要能够对许多不同的数据库产品运行,此信息可以很方便地确定哪些特定的数据库功能它支持,它支持 SQL 等。

数据库驱动程序版本
你可以获得使用,像这样的 JDBC 驱动程序的驱动程序版本 ︰

int driverMajorVersion = databaseMetaData.getDriverMajorVersion();
int driverMinorVersion = databaseMetaData.getDriverMinorVersion();

再次,如果针对非常具体的数据库运行您的应用程序,这可能真的无法如此翔实。然而,对于应用程序,需要能够运行对许多不同的数据库产品和版本,知道使用驱动程序的确切版本可能一个优势。例如,某些驱动程序版本可能包含一个错误,应用程序需要变通。或者,驱动程序可能会丢失一项功能,然后,应用程序需要变通。

列出表
您可以在您的数据库中,通过DatabaseMetaData获得的已定义的表的列表。这里是如何做到这一点 ︰

String   catalog          = null;
String   schemaPattern    = null;
String   tableNamePattern = null;
String[] types            = null;

ResultSet result = databaseMetaData.getTables(
    catalog, schemaPattern, tableNamePattern, types );

while(result.next()) {
    String tableName = result.getString(3);
}

首先你调用getTables()方法,传递给它 4 参数是字段均为 null。参数可以帮助限制ResultSet返回的表的数目。但是,因为我想要返回的所有表,我传递 null 在所有这些参数。看到更具体的细节,有关参数的 JavaDoc。

从getTables()方法返回的ResultSet包含匹配 4 给定的参数 (其中全部为 null) 的表名称的列表。此ResultSet包含 10 个栏目,其中每个包含给定表的信息。带有索引 3 列包含表名称本身。检查的 JavaDoc 有关其余的列的详细信息。

列出表中的列
您也可以获得通过DatabaseMetaData表的列。这里是如何 ︰

String   catalog           = null;
String   schemaPattern     = null;
String   tableNamePattern  = "my_table";
String   columnNamePattern = null;


ResultSet result = databaseMetaData.getColumns(
    catalog, schemaPattern,  tableNamePattern, columnNamePattern);

while(result.next()){
    String columnName = result.getString(4);
    int    columnType = result.getInt(5);
}

首先你调用getColumns()方法,传递 4 个参数。其中,仅tableNamePattern设置为一个非 null 值。将其设置为您想要获取的列的表的名称。

getColumns()方法返回的ResultSet包含给定表的列的列表。带有索引 4 列包含的列的名称,并带有索引 5 列包含的列类型。列类型是整数匹配在java.sql.Types中找到的类型常量之一

要获取有关获取表的列信息的更多详细信息,请查阅 JavaDoc。

表的主键
它也是可能获得一个表的主键。你这样做,像这样 ︰

String   catalog   = null;
String   schema    = null;
String   tableName = "my_table";

ResultSet result = databaseMetaData.getPrimaryKeys(
    catalog, schema, tableName);

while(result.next()){
    String columnName = result.getString(4);
}

第一次调用getPrimaryKeys()方法,将三个参数传递给它。只有tableName为非空在这个例子中。

getPrimaryKeys()方法返回的ResultSet包含组成给定表的主键的列的列表。带有索引 4 列包含列名称。

主键可能由多个列组成。这种被称为复合键。如果您的表包含复合键,ResultSet将包含多个行。复合键中每一列的一行。

支持的功能
DatabaseMetaData对象还包含有关功能的信息,JDBC 驱动程序和数据库支持。其中的许多功能被代表的方法,可以调用,这将返回 true 或 false 根据给定的特征是否受支持。

将不会覆盖所有的功能支持相关的方法在这里。我只是会给你几个例子。功能支持方法和它们的含义的完整列表,请咨询 JavaDoc。

databaseMetaData.supportsGetGeneratedKeys();

databaseMetaData.supportsGroupBy();

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/150970.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 怎样优化电商网站_电商网站

    怎样优化电商网站_电商网站这是最近被问过最多的一个问题,很有必要整理成一篇文章来分享。本文讨论的是新接手一个电商网站,不是接手一个新电商网站。因此,网站默认为已运营一段时间,有历史数据可供参考。我一直主张基于数据分析的网站优化,特别是电商网站。同时,做事的时候,可以再加上一点点直觉。直觉是什么?直觉是一个人的学识再…

  • localdate和localdatetime互转_datetimeformatter.ofpattern

    localdate和localdatetime互转_datetimeformatter.ofpatternLocalDateTime及LocalDate是Java8的新特性,有时为了兼容Date类型需要进行转换。今天的项目就有一个需求是实现一个函数能够计算出当天在一年中的第多少天,通过搜索找到java8有LocalDateTime类就能够实现这个需求。但是需要进行时间类型的转换工作。这里把LocalDateTimeLocalDate和Date之间的转换进行了整理,方便大家使用。转换方法LocalDateTime转LocalDateLocalDate转LocalD

  • SpringBoot自定义starters

    SpringBoot自定义startersSpringBoot自定义starters1、简介2、如何自定义starter1、简介SpringBoot最强大的功能就是把我们常用的场景 抽象成一个个starter(场景启动器),我们通过引入springBoot为我们提供这些场景启动器,我们再进行少量的配置就能使用相应的功能。但是,SpringBoot不能包含所有的场景,经常需要我们自定义starter,来简化我们对springBoot的使用。2、如何自定义starter…

    2022年10月23日
  • Pycharm安装包超时:ReadTimeoutError

    Pycharm安装包超时:ReadTimeoutErrorPycharm会自动安装pip、setuptools、wheel,安装numpy等包时,由于国外服务器,导致下载延时,无法安装,可使用使用pip.exe解决。Win+R,Enter后打开cmd,在你的python工程下venv-Scripts下,pip.exe右键,ShowinExplorer,打开所在文件夹,将pip.exe拖入cmd,执行查看所有可用命令、查看当前工程已安装的包、安装包…

  • ES6数组的高阶方法,箭头函数,对象[通俗易懂]

    ES6数组的高阶方法,箭头函数,对象[通俗易懂]一.数组的高阶方法forEach(遍历)vararr=[‘我’,’和’,’我的’,’祖国’];arr.forEach(function(item,index,self){ console.log(item,index,self);})map(映射)vararr=[12,34,56];vararr2=arr.map(function(item,index,self){ console.log(item,index,self); returnitem*2;})

  • 【玩转嵌入式屏幕显示】(六)ST7789 SPI LCD硬件垂直滚动功能的使用

    一、想法萌生小熊派开发板的LCD小屏幕使用是ST7789驱动IC,之前一直有在该块屏幕上实现滚动显示的想法,最初构想在MCU侧创建一个大的队列,将整个屏幕显示内容交由队列管理,然后不停的去整屏刷新以实现屏幕滚动。理论上这样的实现比较耗资源,耗费CPU资源去操作SPI外设,耗费内存资源去存储显示数据,所以一直没有去做这件事。今天在查看ST7789数据手册写论文时,偶然发现ST7789手册种:咦?Scroll?滚动?发现新大陆!根据手册中的8.14章节描述,旋转滚动仅仅是垂直滚动的一种模式,由垂

发表回复

您的电子邮箱地址不会被公开。

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