IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> DatabaseMetaData 获取数据表字段注释内容 -> 正文阅读

[大数据]DatabaseMetaData 获取数据表字段注释内容

使用DataBaseMetaData获取mysql表字段注释

?

  1. DatabaseMetaData?metaData?=?connection.getMetaData();?
  2. ResultSet?rs?=?null;?
  3. ?rs?=?metaData.getColumns(dbName,?null,?tableName,?"%");
  4. while?(rs.next())?{
  5. ?????????????QueryColumn?column=new?QueryColumn(rs.getString("COLUMN_NAME"),?rs.getString("TYPE_NAME"));
  6. ?????????????column.setComment(rs.getString("REMARKS"));
  7. ????????????????columnList.add(column);
  8. ????????????}

metaData.getColumns mysql实现接口

DatabaseMetaDataUsingInfoSchema#getColumns
  1. ?sqlBuf.append("CASE?WHEN?LCASE(DATA_TYPE)='date'?THEN?10?WHEN?LCASE(DATA_TYPE)='time'?THEN?8?WHEN?LCASE(DATA_TYPE)='datetime'?THEN?19?WHEN?LCASE(DATA_TYPE)='timestamp'?THEN?19?WHEN?CHARACTER_MAXIMUM_LENGTH?IS?NULL?THEN?NUMERIC_PRECISION?WHEN?CHARACTER_MAXIMUM_LENGTH?>?2147483647?THEN?2147483647?ELSE?CHARACTER_MAXIMUM_LENGTH?END?AS?COLUMN_SIZE,?"?+?MysqlIO.getMaxBuf()?+?"?AS?BUFFER_LENGTH,"?+?"NUMERIC_SCALE?AS?DECIMAL_DIGITS,"?+?"10?AS?NUM_PREC_RADIX,"?+?"CASE?WHEN?IS_NULLABLE='NO'?THEN?"?+?0?+?"?ELSE?CASE?WHEN?IS_NULLABLE='YES'?THEN?"?+?1?+?"?ELSE?"?+?2?+?"?END?END?AS?NULLABLE,"?+?"COLUMN_COMMENT?AS?REMARKS,"?+?"COLUMN_DEFAULT?AS?COLUMN_DEF,"?+?"0?AS?SQL_DATA_TYPE,"?+?"0?AS?SQL_DATETIME_SUB,"?+?"CASE?WHEN?CHARACTER_OCTET_LENGTH?>?"?+?2147483647?+?"?THEN?"?+?2147483647?+?"?ELSE?CHARACTER_OCTET_LENGTH?END?AS?CHAR_OCTET_LENGTH,"?+?"ORDINAL_POSITION,"?+?"IS_NULLABLE,"?+?"NULL?AS?SCOPE_CATALOG,"?+?"NULL?AS?SCOPE_SCHEMA,"?+?"NULL?AS?SCOPE_TABLE,"?+?"NULL?AS?SOURCE_DATA_TYPE,"?+?"IF?(EXTRA?LIKE?'%auto_increment%','YES','NO')?AS?IS_AUTOINCREMENT,?"?+?"IF?(EXTRA?LIKE?'%GENERATED%','YES','NO')?AS?IS_GENERATEDCOLUMN?FROM?INFORMATION_SCHEMA.COLUMNS?WHERE?");

使用DataBaseMetaData获取oracle表字段注释

oracle是需要在连接JDBC获取connection时通过RemarksReporting来设置是否能获取comments.

而RemarksReporting默认为false.在获取oracle的表字段信息时需要设置为True.

 
  1. Properties?props?=newProperties();
  2. props.put("remarksReporting","true");
  3. Class.forName("oracle.jdbc.driver.OracleDriver");
  4. dbConn?=?DriverManager.getConnection(url,?props);
  5. DatabaseMetaData?dbmd?=?dbConn.getMetaData();

对于使用使用连接池时,可先判断连接数据库类型,将connection转换为OracleConnection,因为setRemarking在OracleConnection实现了。

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章           查看所有文章
加:2022-05-11 16:30:44  更:2022-05-11 16:33:35 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 23:29:05-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码