- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在使用 spring-jdbc 模板
来查询 Hive-0.11.0
以下代码效果很好。
public List<Student> listStudents() {
String SQL = "select * from Student";
List <Student> students = jdbcTemplateObject.query(SQL,
new StudentMapper());
return students;
}
public class StudentMapper implements RowMapper<Student> {
public Student mapRow(ResultSet rs, int rowNum) throws SQLException {
Student student = new Student();
student.setId(rs.getInt("id"));
student.setName(rs.getString("name"));
student.setAge(rs.getInt("age"));
return student;
}
}
升级到 Hive-0.14.x,一切保持不变。但是程序没有运行。抛出以下异常:
org.springframework.jdbc.UncategorizedSQLException: StatementCallback; uncategorized SQLException for SQL []; SQL state [null]; error code [0]; null; nested exception is java.sql.SQLException
at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:84)
at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:81)
at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:81)
at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:413)
at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:468)
at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:478)
Caused by: java.sql.SQLException
org.apache.hive.jdbc.HiveBaseResultSet.findColumn(HiveBaseResultSet.java:93)
at org.apache.hive.jdbc.HiveBaseResultSet.getString(HiveBaseResultSet.java:609)
at org.clinical3PO.model.StudentMapper.mapRow(StudentMapper.java:15)
at org.clinical3PO.model.StudentMapper.mapRow(StudentMapper.java:8)
at org.springframework.jdbc.core.RowMapperResultSetExtractor.extractData(RowMapperResultSetExtractor.java:93)
at org.springframework.jdbc.core.RowMapperResultSetExtractor.extractData(RowMapperResultSetExtractor.java:60)
at org.springframework.jdbc.core.JdbcTemplate$1QueryStatementCallback.doInStatement(JdbcTemplate.java:457)
at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:402)
... 5 more
从 Hive-0.11.0 到 Hive-0.14.x 是否有代码更改?
最佳答案
Hive 0.14.0 按原样返回查询的列名。深入研究:考虑 2 个表 abc
和 xyz
。查询是:- SELECT abc.id, xyz.age, abc.name from db.abc JOIN ON db.xyz WHERE abc.id=xyz.id;
Hive-0.11.0 的结果集:
student.setId(rs.getInt("id"));
student.setName(rs.getString("name"));
student.setAge(rs.getInt("age"));
Hive-0.14.0 的结果集:
student.setId(rs.getInt("abc.id"));
student.setName(rs.getString("abc.name"));
student.setAge(rs.getInt("xyz.age"));
这就是它对我有用的方式。
关于java - Hive jdbc.query(sql, rowmapper) 抛出 UnCatogarized 异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31286128/
在 Spring 和 Hibernate 中,当我使用自定义 RowMapper 时,它会抛出以下错误 javax.servlet.jsp.JspException: java.lang.NoSuch
我定义了两个服务: Class cars model, year, mileage Class driver name, age, licExpDate 我已经在他们自己的服务中对每个查询进行了查
我使用 RowMapper 将数据库表映射到 java 对象 我的请求如下所示 SELECT SUM(quantity) FROM table1 t1 WHERE t1.x = 723834
我正在阅读 Spring in Action 并发现类似这样的内容,如果它是按照 RowMapper 的接口(interface),任何人都可以解释我们如何将 RowMapper 用作匿名类。文档。
我正在使用 SpringBatch 从 Oracle 读取数据并写入 ElasticSearch。 我的代码适用于静态查询。示例:select emp_id, emp_name from employ
我正在开发此应用程序来从现有 Oracle 数据库的单个表中获取数据。 这里我们得到了实体: public class OrdemDeServicoCount { private Long o
我在 JDBC 中使用 RowMappers 时遇到问题(尤其是 ParameterizedSingleColumnRowMapper): 我正在使用以下命令从数据库中查询现有 ID 列表: List
我有一个包含变量的域对象,作为来自 netezza 的值列表和另外 4 个变量,这些变量是普通变量,将使用行映射器从 oracle db 获取分配的值。 下面的语句抛出错误:类型不匹配:无法从 Lis
Spring 文档指出: "If the last two snippets of code actually existed in the same application, it would ma
我想知道 JdbcTemplate 和 RowMapper 是否支持复杂的对象检索。我在谷歌上找不到任何关于此事的信息(标准错误?)。 :( 示例: public class Person() {
我正在尝试实现 SO here 中提到的解决方案但是,我收到错误消息“Rowmapper is abstract cannot be instantiated”和“illegal start of e
我尝试四处寻找问题的答案,但未能解决。 我的应用程序在第 46 行的 RowMapper 类中抛出 NPE: orderLineRepository.sqlGetOrderLinesForOrder(
在 java 中,我会做类似下面的事情来迭代 resultset 并形成查询, public Map> fun(){ Map> map = new TreeMap>(); L
我的行映射器如下: private static final class UserRowMapper implements RowMapper { User user = new User()
当通过 SpringJdbcTemplate 从数据库中获取结果时,我到处都看到它们每次都在传递 RowMapper` 的新对象。 这是必需的吗?或者我们可以只使用一个对象并一次又一次地传递它吗? 例
问题是关于 RowMapper 在我们希望使用 spring jdbc 急切获取详细信息的主/详细场景中的最佳实践用法。 假设我们同时拥有 Invoice 和 InvoiceLine 类。 publi
我正在使用 JDBI 的 SQL 对象声明性 API 来映射包含一对多关系的对象: class Foo { private String id; private String name;
这是我的类(class) @Repository public class JdbcRolesDao implements RolesDao{ private JdbcTemplate jdbcTem
我正在使用 Spring Boot 构建连接到 Oracle DB 的 REST 服务。我也在使用 Spring JDBC。 我有以下代码: jdbcCall.declareParameters(ne
我使用 Spring jdbcTemplate 进行数据库获取调用,要获取的行数约为 100 万行。在结果集中迭代需要太多时间。调试行为后,我发现它像批处理一样处理一些行,然后等待一段时间,然后再次获
我是一名优秀的程序员,十分优秀!