小知识系列:查询数据库数据的元信息
2021/10/13 19:17:32
本文主要是介绍小知识系列:查询数据库数据的元信息,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
目录- 简介
- 使用ResultSet
- 使用ResultSetMetaData
- 总结
简介
java中数据库的操作相信大家都不陌生,JDK提供了java.sql包来规范对数据库的各种操作。我们最常用的操作就是从数据库的ResultSet中获取数据,其实这个包中还有一个非常有用的类叫做ResultSetMetaData,可以通过这个类来获取查询数据的元信息,一起来看看吧。
使用ResultSet
java.sql.ResultSet是一个通用的规范,用来表示从数据库获取到的数据。
通常来说,我们通过connection来创建Statement,然后通过执行查询语句来得到:
Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE); ResultSet rs = stmt.executeQuery("SELECT a, b FROM TABLE2");
resultSet提供了各种getter方法,来获取结果集中的各种数据。可以通过index,也可以通过column名称来获取。
当然,使用index它的效率会更高,index是从1开始的。如果是通过列名来获取数据,传入的列名是大小写不敏感的,如果结果数据中有多个匹配的类,则会返回最先匹配的那一列。
在get的过程中,JDBC driver会尝试将结果数据的数据库类型转换成为对应的java类型。
JDBC 2.0 API,ResultSet也可以进行更新和插入操作,可能我们很少这样做,一般都是先构造好数据后直接插入。
先看下更新操作:
rs.absolute(5); // 将游标移动到第5行 rs.updateString("SITE", "www.flydean.com"); // 将SITE更新为www.flydean.com rs.updateRow(); // 更新到数据库中
再看下插入操作:
rs.moveToInsertRow(); // 将游标移动到插入行 rs.updateString(1, "www.flydean.com"); // 将插入行的第一列更新为www.flydean.com rs.updateInt(2,35); // 更新第二列为35 rs.updateBoolean(3, true); // 更新第三列为true rs.insertRow(); rs.moveToCurrentRow();
使用ResultSetMetaData
有了ResultSet,我们可以通过它的getMetaData方法,来获取结果集的元数据。
什么是元数据呢?元数据又叫做Metadata,是用来描述数据属性的数据。
ResultSetMetaData getMetaData() throws SQLException;
举个具体的例子:
ResultSet rs = stmt.executeQuery("SELECT a, b, c FROM TABLE2"); ResultSetMetaData rsmd = rs.getMetaData(); int numberOfColumns = rsmd.getColumnCount(); boolean b = rsmd.isSearchable(1);
ResultSetMetaData提供了很多非常有用的元数据检测方法:
我们可以拿到列的名称、类型、字段长度、是否为空等很多有意义的数据。
这个元数据有什么用呢?
通过元数据,我们可以拿到数据库的描述文件,从而可以自动创建对应的数据库表格的映射关系,从而减少手动代码的输入,非常的方便。
用过MybatisPlus的朋友可能知道,它提供了一个AutoGenerator,可以自动生成mapper对象和对应的xml文件,非常好用,大家可以试一试。
总结
以上就是ResultSet和ResultSetMetaData的介绍,大家学会了吗?
本文已收录于 http://www.flydean.com/02-db-resultsetmetadata/
最通俗的解读,最深刻的干货,最简洁的教程,众多你不知道的小技巧等你来发现!
欢迎关注我的公众号:「程序那些事」,懂技术,更懂你!
这篇关于小知识系列:查询数据库数据的元信息的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23Springboot应用的多环境打包入门
- 2024-11-23Springboot应用的生产发布入门教程
- 2024-11-23Python编程入门指南
- 2024-11-23Java创业入门:从零开始的编程之旅
- 2024-11-23Java创业入门:新手必读的Java编程与创业指南
- 2024-11-23Java对接阿里云智能语音服务入门详解
- 2024-11-23Java对接阿里云智能语音服务入门教程
- 2024-11-23JAVA对接阿里云智能语音服务入门教程
- 2024-11-23Java副业入门:初学者的简单教程
- 2024-11-23JAVA副业入门:初学者的实战指南