当前位置: 代码迷 >> java >> 如何在不同的SQL查询中使用相同的Java类
  详细解决方案

如何在不同的SQL查询中使用相同的Java类

热度:41   发布时间:2023-07-25 19:20:31.0

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

我对如何加载适合不同SQL查询的Java通用/混合类有一些疑问。

我的意思是,是否可以在Java中创建一个可以在运行时更改/更改的类,以便在其中映射不同的SQL查询?

我知道可以使用java.sql.ResultSetMetaData来获取列名,表名,列类名等(我不知道是否可以使用休眠方式),但是我不知道如何映射结果是唯一的类。

例如:

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

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应用以在网格中显示它。

有办法吗?

不要重新发明轮子,而是使用现有的和经过良好测试的东西。
您正在寻找的被称为Spring JDBC ,或者更高级的名称是Java Persistence API

使用Spring JDBC提取一组记录可能看起来像

final List<YourClass> results =
          jdbcTemplate.queryForList(
                   "Native SQL statement",
                   queryArguments,
                   YourClass.class
          );

使用JPA实现(例如HibernateEclipseLinkObjectDb ),操作可能看起来像

final TypedQuery<YourClass> query = entityManager.createQuery("JPQL statement", YourClass.class);
final List<YourClass> results = query.getResultList();
  相关解决方案