首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何对不同的SQL查询使用相同的Java类

如何对不同的SQL查询使用相同的Java类
EN

Stack Overflow用户
提问于 2019-03-03 06:08:37
回答 1查看 190关注 0票数 1

我正在设计一个Java report应用程序,它可以接收任何SQL查询(在已经定义的数据库上),然后在Vue.js应用程序的表格网格中显示结果。

对于如何加载Java泛型/混合类以适应不同的SQL查询,我有一些疑问。

我的意思是,有没有可能在Java中创建一个可以在运行时更改/变异的类,这样我就可以在其中映射不同的SQL查询?

我知道可以使用java.sql.ResultSetMetaData来获取列名、表名、列类名等(我不知道hibernate是否可行),但我不知道如何将结果映射到唯一的类中。

例如:

我有3个不同的查询,它们可能会更多:

代码语言:javascript
运行
复制
1) SELECT ID, COUNTRY_NAME FROM COUNTRY;

2) SELECT CODE, NAME, PRICE FROM PRODUCT;

3) SELECT P.CODE, P.NAME, S.NAME 
     FROM PRODUCT P
     JOIN SUPPLIER S
       ON S.ID = P.SUPPLIER_ID
     WHERE P.PRICE > 25;

我需要将这个查询结果(显然是一次一个)映射到一个泛型类中,然后将其传递给Vue应用程序,以便在网格中显示它。

这是一种实现这一目标的方法吗?

EN

回答 1

Stack Overflow用户

发布于 2019-03-03 06:31:37

不要重复发明轮子,使用已经可用的和经过良好测试的东西。

您正在寻找的是Spring JDBC,或者更高层次的Java Persistence API

使用Spring JDBC提取一组记录可能如下所示

代码语言:javascript
运行
复制
final List<YourClass> results =
          jdbcTemplate.queryForList(
                   "Native SQL statement",
                   queryArguments,
                   YourClass.class
          );

使用JPA实现(例如,HibernateEclipseLinkObjectDb),操作可能如下所示

代码语言:javascript
运行
复制
final TypedQuery<YourClass> query = entityManager.createQuery("JPQL statement", YourClass.class);
final List<YourClass> results = query.getResultList();
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54963502

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档