Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/70.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
错误java.sql.SQLException:找不到列“id”_Java_Mysql_Hibernate_Spring Boot_Kotlin - Fatal编程技术网

错误java.sql.SQLException:找不到列“id”

错误java.sql.SQLException:找不到列“id”,java,mysql,hibernate,spring-boot,kotlin,Java,Mysql,Hibernate,Spring Boot,Kotlin,执行查询计数*后,我得到一个意外错误。我使用workbanch图形界面完成了这个请求,那里一切都很好。在我的代码中,出现了一个错误。我不明白原因 以下是对数据库执行我的工作的实体管理器: @PersistenceContext private val entityManager: EntityManager? = null fun count(request: HttpServletRequest): Int { val query = entityManage

执行查询计数*后,我得到一个意外错误。我使用workbanch图形界面完成了这个请求,那里一切都很好。在我的代码中,出现了一个错误。我不明白原因

以下是对数据库执行我的工作的实体管理器:

@PersistenceContext
    private val entityManager: EntityManager? = null

    fun count(request: HttpServletRequest): Int {
        val query = entityManager!!.createNativeQuery("SELECT COUNT(*) FROM resume r", Resume::class.java)
        return (query.getSingleResult() as Number).toInt()
    }
这是一个您需要获得的数量的类:

@Entity
@ValidWorkType
@ValidProfField
@ValidEducation
@ValidAddress
@ValidDescResume
data class Resume (

        @Id @GeneratedValue(strategy = GenerationType.IDENTITY)
        var id: Long? = null,

        @ManyToOne(fetch = FetchType.LAZY)
        var user: User? = null,

        var datecreate: LocalDateTime = LocalDateTime.now(),

        @get:Size(min = 1, max = 60, message = "{error.work.profession}")
        var profession: String? = null,

        @OneToOne(fetch = FetchType.LAZY, cascade = [CascadeType.ALL], orphanRemoval = true)
        @get:Valid
        var numberPhone: NumberPhone? = null,

        @get:Email(message = "{text.error.user.email}")
        @get:Size(min = 1, max = 100, message = "{text.error.user.email.size}")
        var email: String? = null,

        @ManyToOne(cascade = [CascadeType.MERGE])
        @get:NotNull(message = "{error.work.prof.field}")
        override var profField: ProfField? = null,

        @ManyToOne(cascade = [CascadeType.MERGE])
        @get:NotNull(message = "{error.work.work.type}")
        override var workType: WorkType? = null,

        @OneToOne(cascade = [CascadeType.ALL], orphanRemoval = true)
        @get:Valid
        var wage: Wage? = null,

        @ManyToOne
        override var education: Education? = null,

        var experience: Int? = null,

        @OneToOne(cascade = [CascadeType.ALL], fetch = FetchType.LAZY, orphanRemoval = true)
        @get:Valid
        override var description: DescriptionResume? = null,

        @OneToOne(cascade = [CascadeType.ALL], orphanRemoval = true)
        override var address: Address? = null,

        @OneToOne(fetch = FetchType.LAZY, cascade = [CascadeType.ALL], orphanRemoval = true)
        var photo: ContainerSquareImages? = null,

        @OneToOne(cascade = [CascadeType.ALL], orphanRemoval = true)
        var views: Views = Views(),

        @Transient
        var rating: Int? = null

): ParentWorkType, ParentProfField, ParentEducation, ParentAddress, ParentDescResume {

        fun getPeriodExperience(): Period? {
                if (experience!=null) {
                        return Period.between(LocalDate.now(), LocalDate.now().plusDays(experience!!.toLong()))
                } else { return null }
        }

        override fun equals(other: Any?): Boolean {
                if (this === other) return true
                if (javaClass != other?.javaClass) return false

                other as Resume

                if (user != other.user) return false
                if (profession != other.profession) return false
                if (numberPhone != other.numberPhone) return false
                if (email != other.email) return false
                if (profField != other.profField) return false
                if (workType != other.workType) return false
                if (wage != other.wage) return false
                if (education != other.education) return false
                if (experience != other.experience) return false
                if (description != other.description) return false
                if (address != other.address) return false

                return true
        }

        override fun hashCode(): Int {
                var result = user?.hashCode() ?: 0
                result = 31 * result + (profession?.hashCode() ?: 0)
                result = 31 * result + (numberPhone?.hashCode() ?: 0)
                result = 31 * result + (email?.hashCode() ?: 0)
                result = 31 * result + (profField?.hashCode() ?: 0)
                result = 31 * result + (workType?.hashCode() ?: 0)
                result = 31 * result + (wage?.hashCode() ?: 0)
                result = 31 * result + (education?.hashCode() ?: 0)
                result = 31 * result + (experience?.hashCode() ?: 0)
                result = 31 * result + (description?.hashCode() ?: 0)
                result = 31 * result + (address?.hashCode() ?: 0)
                return result
        }

        fun getYearsCalendar() {

        }

        companion object {
                const val NAME_PARAM = "resume"
        }
}
下面是错误日志本身无法理解的原因,以及原因,请帮助:

Hibernate: SELECT COUNT(*) FROM resume r
[WARN ] 2019-07-01 00:37:08.485 [http-nio-8080-exec-1] SqlExceptionHelper - SQL Error: 0, SQLState: S0022
[ERROR] 2019-07-01 00:37:08.485 [http-nio-8080-exec-1] SqlExceptionHelper - Column 'id' not found.
[ERROR] 2019-07-01 00:37:08.525 [http-nio-8080-exec-1] [dispatcherServlet] - Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: could not execute query] with root cause
java.sql.SQLException: Column 'id' not found.
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:129) ~[mysql-connector-java-8.0.15.jar:8.0.15]
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97) ~[mysql-connector-java-8.0.15.jar:8.0.15]
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:89) ~[mysql-connector-java-8.0.15.jar:8.0.15]
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:63) ~[mysql-connector-java-8.0.15.jar:8.0.15]
    at com.mysql.cj.jdbc.result.ResultSetImpl.findColumn(ResultSetImpl.java:581) ~[mysql-connector-java-8.0.15.jar:8.0.15]
    at com.mysql.cj.jdbc.result.ResultSetImpl.getLong(ResultSetImpl.java:928) ~[mysql-connector-java-8.0.15.jar:8.0.15]

createNativeQuery的文档如下所示:

查询createNativeQueryString sqlString, 类结果类

sqlString—本机SQL查询字符串

resultClass—结果实例的类

您的查询是:

SELECT COUNT(*) FROM resume r
这是在访问resume表,但它返回的是一个整数,而不是resume实例。这就是为什么找不到列“id”的原因

修复方法只是将Integer作为结果类传递,因此:

val query = entityManager!!.createNativeQuery("SELECT COUNT(*) FROM resume r")
val query=entityManager!!。CreateNativeQuerySelectCount*自简历r,Integer::class.java

由于标量未映射,因此修复方法是不传递结果类,因此:

val query = entityManager!!.createNativeQuery("SELECT COUNT(*) FROM resume r")

使用javax.persistence.Query JPA接口:选择NamedQuery或TypedQuery

范例

@javax.persistence.NamedQuery(
    name="resumeCountTest", query = "SELECT COUNT(*) FROM resume r")
    public class Resume {
 -------------
Query query = entityManager.createNamedQuery("resumeCountTest");
long resumeCount = query.getSingleResult();
return resumeCount ;

更多信息

使用JPQL解决了此问题:

@PersistenceContext
    private val entityManager: EntityManager? = null

    fun count(request: HttpServletRequest): Long {
        val query = entityManager!!.createQuery("SELECT COUNT(resume.id) FROM Resume resume")
        return query.singleResult as Long
    }

您是否在没有计数的情况下得到此错误。这意味着只是一个全选计划。或者尝试在count station中放置一个字段。打开Hibernate的SQL日志记录并显示执行的语句。not work-org.Hibernate.MappingException:未知实体:java.lang.IntegerApologies,未映射标量,因此不应传递任何映射类。我已经更新了答案。需要创建dinamic查询吗