我正在设计一个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应用以在网格中显示它。
这是一种方法吗?
答案 0 :(得分:0)
不要重新发明轮子,而是使用已有的东西和经过良好测试的东西。
您正在寻找的被称为Spring JDBC
,或者更高级的称为Java Persistence API
。
使用Spring JDBC
提取一组记录可能看起来像
final List<YourClass> results =
jdbcTemplate.queryForList(
"Native SQL statement",
queryArguments,
YourClass.class
);
使用JPA
实现(例如Hibernate
,EclipseLink
,ObjectDb
),操作看起来像
final TypedQuery<YourClass> query = entityManager.createQuery("JPQL statement", YourClass.class);
final List<YourClass> results = query.getResultList();