【发布时间】:2020-08-26 19:02:54
【问题描述】:
我有一个可以在 MySQL 数据库上顺利运行的程序。现在对于外部需求,我必须切换到 SQL Server。感谢 Hibernate,切换很顺利,除了错误:
java.sql.SQLException: ResultSet 只能向前访问。
我在对从数据库中获取的数据执行自定义分页时收到此错误。下面是一个尝试获取存储在数据库中的用户并对其进行分页的最小示例(以下示例假设表中至少有 3 行)。
自定义分页:
import org.hibernate.Query;
import org.hibernate.Session;
public class newMain1 {
public static void main(String[] args) {
getList(1, getSession());
getList(2, getSession());
}
private static void getList(int page, Session s) {
int rowsPerPage = 2;
String hql = "FROM User u ";
try {
Query query = s.createQuery(hql);
int start = (page - 1) * rowsPerPage;
query.setFirstResult(start);
query.setMaxResults(rowsPerPage);
//line that throws exception when int page is 2
query.list();
//line that throws exception when int page is 2
} finally {
if (s.isOpen()) {
s.close();
}
}
}
private Session getSession(){
//gets org.hibernate.Session
}
}
用户 Java POJO:
public class User {
private Long id;
private String username;
private String password;
private String email;
public User() {
}
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
}
SQL Server 的用户表:
CREATE TABLE [USER] (
ID bigint NOT NULL,
USERNAME varchar(150) NOT NULL UNIQUE,
PASSWORD varchar(150) NOT NULL,
EMAIL varchar(150) NOT NULL UNIQUE,
PRIMARY KEY (ID)
);
用户 POJO 的休眠映射:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="product.model.User" table="USER">
<id column="ID" name="id" type="long">
<generator class="increment"/>
</id>
<property column="EMAIL" name="email" type="string"/>
<property column="USERNAME" name="username" type="string"/>
<property column="PASSWORD" name="password" type="string"/>
</class>
</hibernate-mapping>
休眠配置 xml:
<session-factory>
<property name="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</property>
<property name="hibernate.connection.driver_class">net.sourceforge.jtds.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:jtds:sqlserver://127.0.0.1:1433;DatabaseName=myDB;prepareSQL=3;sendStringParametersAsUnicode=false;</property>
<property name="hibernate.connection.username">sa</property>
<property name="hibernate.connection.password">myPassword</property>
<property name="hibernate.show_sql">true</property>
<property name="hibernate.globally_quoted_identifiers">true</property>
<mapping resource="product_mapping/user.hbm.xml"/>
</session-factory>
我正在使用 SQL Server 2012、JDK 1.8、Hibernate 4.0.1.Final、jtds 驱动程序 1.3.1
请注意getList(1, getSession()) 不会抛出异常,而getList(2, getSession()) 会。
【问题讨论】:
-
我从这个最小示例中删除了总行数的计数,以使其更加简单。我已编辑帖子以指定用户表必须包含至少 3 行才能测试代码。
-
您为什么使用过时且未维护的 jTDS 驱动程序?您应该使用 Microsoft JDBC 驱动程序:github.com/microsoft/mssql-jdbc
-
@Joakim Danielson 我在执行getList方法两次指出当请求页面不是第一个时,会抛出异常。这是一个最小的例子。
-
@a_horse_with_no_name 我将尝试包含该依赖项并测试代码。无论如何,我对与 SQL Server 2012 兼容有严格的要求。我希望这种依赖不会破坏这样的要求。
-
使用微软官方驱动无法与 SQL Server 兼容
标签: java sql-server hibernate jtds