【问题标题】:org.hibernate.engine.jdbc.spi.SqlExceptionHelper - Column with name «name» isn't present in this «ResultSet» Hibernate with PostgreSQL JDBCorg.hibernate.engine.jdbc.spi.SqlExceptionHelper - 名称为 «name» 的列不存在于此 «ResultSet» Hibernate with PostgreSQL JDBC
【发布时间】:2016-05-21 14:47:12
【问题描述】:

正如主题所说,我在带有 PostgreSQL 数据库的 Hibernate 5 中遇到了这个错误。

Hibernate 返回给我的查询是: SELECT u.email, u.password FROM utenti u WHERE u.email = ?(所以是正确的) 表格是:

utenti(email (pk), password, nome, cognome, datanascita, sesso)

此外,我收到另一个错误: 异常启动过滤器struts2

Unable to load configuration. - action - file:<path>/NetBeansProjects/DBIIProject/target/DBIIProject-1.0-SNAPSHOT/WEB-INF/classes/struts.xml:15:34

我的struts.xml 是:

    <?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
    "http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>

    <constant name="struts.enable.DynamicMethodInvocation" value="false"/>
    <constant name="struts.devMode" value="true"/>

    <!-- Cambio l'estensione delle Action da .action a .do -->
    <constant name="struts.action.extension" value="do" />

    <package name="default" extends="struts-default" namespace="/">
        <action name="Login" class="org.altervista.cdpjavaexamples.dbiiproject.actions.LoginAction" method="execute">
            <result name="success">index.jsp</result>
            <result name="input">login.jsp</result>
        </action>
        <action name="Logout" class="org.altervista.cdpjavaexamples.dbiiproject.actions.LogoutAction" method="execute">
            <result name="success">index.jsp</result>
        </action>
        <action name="PasswordRecovery" class="org.altervista.cdpjavaexamples.dbiiproject.actions.PasswordRecoveryAction" method="execute">
            <result name="success">password_recovery.jsp</result>
            <result name="input">password_recovery.jsp</result>
        </action>
    </package>
</struts>

我的 pom.xml 是:

    <?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>org.altervista.cdpjavaexamples</groupId>
    <artifactId>DBIIProject</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>war</packaging>
    <name>DBIIProject</name>

    <properties>
        <struts2.version>2.3.24.1</struts2.version>
        <log4j2.version>2.2</log4j2.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <dependencies>

        <dependency>
            <groupId>org.apache.struts</groupId>
            <artifactId>struts-taglib</artifactId>
            <version>1.3.10</version>
        </dependency>

        <dependency>
            <groupId>org.apache.struts</groupId>
            <artifactId>struts2-convention-plugin</artifactId>
            <version>2.3.24.1</version>
        </dependency>

        <dependency>
            <groupId>com.sun.mail</groupId>
            <artifactId>javax.mail</artifactId>
            <version>1.5.5</version>
        </dependency>

        <dependency>
            <groupId>jstl</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>

        <dependency>
            <groupId>javax.mail</groupId>
            <artifactId>javax.mail-api</artifactId>
            <version>1.5.5</version>
        </dependency>

        <dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <version>9.4.1207.jre7</version>
        </dependency>

        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>5.0.7.Final</version>
        </dependency>

        <dependency>
            <groupId>org.apache.struts</groupId>
            <artifactId>struts2-core</artifactId>
            <version>${struts2.version}</version>
        </dependency>

        <dependency>
            <groupId>org.apache.struts</groupId>
            <artifactId>struts2-junit-plugin</artifactId>
            <version>${struts2.version}</version>
            <scope>test</scope>
        </dependency>


        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-api</artifactId>
            <version>${log4j2.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>${log4j2.version}</version>
        </dependency>

        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.8.2</version>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.4</version>
            <scope>provided</scope>
        </dependency>

        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jsp-api</artifactId>
            <version>2.0</version>
            <scope>provided</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.3</version>
                <configuration>
                    <encoding>UTF-8</encoding>
                    <source>1.5</source>
                    <target>1.5</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.mortbay.jetty</groupId>
                <artifactId>jetty-maven-plugin</artifactId>
                <version>8.1.16.v20140903</version>
                <configuration>
                    <stopKey>CTRL+C</stopKey>
                    <stopPort>8999</stopPort>
                    <systemProperties>
                        <systemProperty>
                            <name>xwork.loggerFactory</name>
                            <value>com.opensymphony.xwork2.util.logging.log4j2.Log4j2LoggerFactory</value>
                        </systemProperty>
                    </systemProperties>
                    <scanIntervalSeconds>10</scanIntervalSeconds>
                    <webAppSourceDirectory>${basedir}/src/main/webapp/</webAppSourceDirectory>
                    <webAppConfig>
                        <descriptor>${basedir}/src/main/webapp/WEB-INF/web.xml</descriptor>
                    </webAppConfig>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

最后我的 Hibernate 的文件是:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
  <session-factory>
    <property name="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</property>
    <property name="hibernate.connection.driver_class">org.postgresql.Driver</property>
    <property name="hibernate.connection.url">jdbc:postgresql://localhost:5432/testdb</property>
    <property name="hibernate.connection.username">test</property>
    <property name="hibernate.connection.password">test</property>
    <property name="hibernate.show_sql">true</property>
    <mapping class="" file="" jar="" package="" resource="org/altervista/cdpjavaexamples/dbiiproject/model/Utenti.hbm.xml"/>
  </session-factory>
</hibernate-configuration>

和:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
  <!-- Mappatura classe - tabella -->
  <class name="org.altervista.cdpjavaexamples.dbiiproject.model.Utenti" table="utenti">
    <meta attribute="class-description">
          Descrizione della classe
      </meta>
    <!-- Chiave primaria -->
    <id column="email" name="email" type="text"/>
    <!-- Campi -->
    <property column="nome" name="nome" not-null="true" type="text"/>
    <property column="cognome" name="cognome" not-null="true" type="text"/>
    <property column="password" name="password" not-null="true" type="text"/>
    <property column="sesso" name="sesso" not-null="true" type="boolean"/>
    <property column="datanascita" name="dataNascita" not-null="true" type="date"/>
  </class>

  <!-- Query -->
  <sql-query name="selectEmailPassword">
      <return class="org.altervista.cdpjavaexamples.dbiiproject.model.Utenti"/>
      <![CDATA[
        SELECT email, password FROM utenti WHERE email = :email
      ]]>
  </sql-query>
  <sql-query name="selectNomeCognomePassword">
      <return class="org.altervista.cdpjavaexamples.dbiiproject.model.Utenti"/>
      <![CDATA[
        SELECT nome, cognome, password FROM utenti WHERE email = :email
      ]]>
  </sql-query>
  <sql-query name="emailExists">
      <return class="org.altervista.cdpjavaexamples.dbiiproject.model.Utenti"/>
      <![CDATA[
        SELECT * FROM utenti WHERE email = :email
      ]]>
  </sql-query>
  <!-- Fine query -->
</hibernate-mapping>

我已经在论坛里搜索过了,但是我找到的解决方案并不能很好地解决我的问题。

【问题讨论】:

  • 它的名字。 ;) 我把它从意大利语翻译成英语时打错了。

标签: hibernate postgresql hibernate-native-query


【解决方案1】:

谢谢大家。最后我使用 Criteria 对象来执行查询。

【讨论】:

    【解决方案2】:

    您在 Hibernate 映射中使用了本机 SQL 查询与 &lt;sql-query&gt;。这些类型的查询必须使用特定于可以执行此查询的数据库的本地 SQL 方言。因此,如果您在 SQL 代码中出错或更改数据库,您的查询可能无法正常工作。在您的代码中使用本机 SQL 查询毫无意义,应将它们替换为 named queries

    使用映射文档可以使用&lt;query&gt; 节点进行配置。 如果您的查询包含字符,请记住使用 CDATA 部分 这可以解释为标记。

    以下是此类查询的示例

    <query name="selectEmailPassword"><![CDATA[
        from org.altervista.cdpjavaexamples.dbiiproject.model.Utenti as u
        WHERE u.email = :email
    ]]></query> 
    

    参数绑定

    Query q = sess.getNamedQuery("selectEmailPassword");
    q.setString("email", email);
    List<Utenti> l = q.list();
    

    【讨论】:

    • 我想使用本机查询,以便 DBA 可以更改它们而无需触及 Hibernate ;)
    • DBA 只能更改位于服务器上的查询。他无法更改应用程序代码。客户端的查询必须由开发人员更改。
    • 出于这个原因,我想将查询放在 Utenti.hbm.xml e 中而不是代码中..
    • 明白。但是为什么如果我使用 Criteria 对象它可以工作呢?例如,这没有问题:Criteria cr = session.createCriteria(Utenti.class); cr.setProjection(Projections.projectionList() .add(Projections.property("email"), "email") .add(Projections.property("password"), "password")) .add(Restrictions.eq("email", email)) .setResultTransformer(Transformers.aliasToBean(Utenti.class)); List&lt;Utenti&gt; results = cr.list();
    • 您也可以使用 Criteria 代替原生 SQL,没有投影和转换会更好。
    【解决方案3】:

    您定义了&lt;return class="org.altervista.cdpjavaexamples.dbiiproject.model.Utenti"/&gt;,看起来该类具有name 属性(例如,标记为使用的“名称”列)。执行 SQL 时,休眠尝试填充实体,但 ResultSet 没有用于填充名称的列。

    【讨论】:

    • 那么,我怎样才能只获取一些带有命名查询的列?
    • 您的 SQL 查询应该包括实体中提到的所有列
    • 您在实体中声明的所有内容。或者你可以声明另一个列更少的实体
    • 好的,我明白了。但是为什么如果我使用 Criteria 我没有得到那个错误呢?相反,如果我尝试检索一行的所有数据,我会得到一个错误? Criteria cr = session.createCriteria(Utenti.class) .add(Restrictions.eq("email", email)) .setResultTransformer(Transformers.aliasToBean(Utenti.class));列表 结果 = cr.list();存在 = !results.isEmpty();
    猜你喜欢
    • 2017-05-12
    • 2021-06-05
    • 2014-02-11
    • 2021-03-02
    • 2019-10-26
    • 2018-09-23
    • 2021-01-18
    • 2016-01-27
    • 2015-08-04
    相关资源
    最近更新 更多