繁体   English   中英

类广播异常休眠映射nvarchar

[英]Classcast exception hibernate mapping nvarchar

我正在尝试使用DetachedCriteria从SQl服务器数据库检索数据库详细信息,如下所示。 nvarcharID是字符串类型

List<POJO> pojoObj = (List<POJO>) getHibernateTemplate().findByCriteria(DetachedCriteria.forClass(
            POJO.class).add(Restrictions.idEq(nvarcharID)));

在我的POJO中,我具有以下属性

@Id
@GeneratedValue
@Column(name = "ID")
private double ID;

@Nationalized
@Column(name = "Column1")
private String string1;

@Nationalized
@Column(name = "column2")
private String string2;

column1和column 2均为SQL ServerDB中的nvarchar类型。 和上面在Criteria中使用的nvarcharID是DB中的另一个字段,在DB中的类型为nvarchar,我将其映射为String。 在填充POJO时,我不希望navarcharID字段成为POJO的一部分。

对于休眠,我的gradle文件中有以下依赖项

compile group: 'org.hibernate', name: 'hibernate-entitymanager', version: '4.3.11.Final'
compile group: 'javax.validation', name: 'validation-api', version: '1.0.0.GA'
compile group: 'org.hibernate', name: 'hibernate-validator-annotation-processor', version: '4.3.2.Final'
compile group: 'org.hibernate', name: 'hibernate-validator', version: '4.3.2.Final'
compile 'org.hibernate:hibernate-core:4.3.11.Final'

我的Spring依赖项是

 compile group: 'org.springframework', name: 'spring-orm', version:'4.1.6.RELEASE'
compile group: 'org.springframework', name: 'spring-webmvc', version: '4.1.6.RELEASE'
compile group: 'org.springframework.security', name: 'spring-security-web', version: '4.0.2.RELEASE'

我还在Hibernate配置文件中为Dialect和ddl操作设置以下属性。

   @Bean
public LocalSessionFactoryBean sessionFactoryBean() {
    LocalSessionFactoryBean localSessionFactoryBean = new LocalSessionFactoryBean();
    localSessionFactoryBean.setDataSource(dataSource);
    localSessionFactoryBean.setPackagesToScan(new String[] { "com.wk.cdi" });

    Properties properties = new Properties();
    properties.setProperty("hibernate.dialect", "org.hibernate.dialect.SQLServer2012Dialect");
    properties.setProperty("hibernate.use_nationalized_character_data", "true");
    properties.setProperty("hibernate.hbm2ddl.auto", "update");
    properties.setProperty("hibernate.format_sql", "true");
    properties.setProperty("hibernate.show_sql", "true");
    localSessionFactoryBean.setHibernateProperties(properties);
    return localSessionFactoryBean;
}

当我尝试使用hibernateTemplate检索数据时,我得到java.lang.ClassCastException:无法将java.lang.String强制转换为java.lang.Double,并且在上面使用DetachedCriteria时抛出了错误

请忽略此内容,因为还有其他问题。 恰好是Restrcition.idEq需要由Restrictions.eq替换

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM