Exception

[Exception] Caused by: org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "\000d\000a

헤르메스의날개 2023. 2. 26. 00:12
728x90

개발환경 :

Spring Boot 2.7.9

Database : H2-2.1.214

JDK : 11.0.18 x64

JPA


H2 Database 를 이용해서, User 라는 JPA Entity 를 생성하는 테스트를 하던 중 아래와 같은 오류가 발생했습니다.

package octopus.entity;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;

import org.hibernate.annotations.Proxy;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonProperty;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;

@Builder // builder를 사용할수 있게 합니다.
@Entity // jpa entity임을 알립니다.
@Getter // user 필드값의 getter를 자동으로 생성합니다.
@Setter
@NoArgsConstructor // 인자없는 생성자를 자동으로 생성합니다.
@AllArgsConstructor // 인자를 모두 갖춘 생성자를 자동으로 생성합니다.
@Table(name = "user") // 'user' 테이블과 매핑됨을 명시
@JsonIgnoreProperties({ "hibernateLazyInitializer", "handler" }) // Post Entity에서 User와의 관계를 Json으로 변환시 오류 방지를 위한 코드
@Proxy(lazy = false)
public class User extends CommonDateEntity {
	/**
     * 
     */
    private static final long serialVersionUID = 1246865649224168898L;

    @Id // pk
	@GeneratedValue(strategy = GenerationType.IDENTITY)
	private long seq;
	
	@Column(nullable = false, unique = true, length = 50)
	private String user_id;
	
    @Column(nullable = false, length = 100)
    private String name;
	
	@JsonProperty(access = JsonProperty.Access.WRITE_ONLY)
	@Column(length = 100)
	private String password;
	
}
INFO  23-02-25 23:22:415[restartedMain] org.hibernate.dialect.Dialect.<init>[175]: - HHH000400: Using dialect: org.hibernate.dialect.H2Dialect
WARN  23-02-25 23:22:739[restartedMain] org.hibernate.tool.schema.internal.ExceptionHandlerLoggedImpl.handleException[27]: - GenerationTarget encountered exception accepting command : Error executing DDL "
    create table user (
       seq bigint generated by default as identity,
        created_at timestamp,
        modified_at timestamp,
        name varchar(100) not null,
        password varchar(100),
        user_id varchar(50) not null,
        primary key (seq)
    )" via JDBC Statement
Caused by: org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "\000d\000a    create table [*]user (\000d\000a       seq bigint generated by default as identity,\000d\000a        created_at timestamp,\000d\000a        modified_at timestamp,\000d\000a        name varchar(100) not null,\000d\000a        password varchar(100),\000d\000a        user_id varchar(50) not null,\000d\000a        primary key (seq)\000d\000a    )"; expected "identifier"; SQL statement:

    create table user (
       seq bigint generated by default as identity,
        created_at timestamp,
        modified_at timestamp,
        name varchar(100) not null,
        password varchar(100),
        user_id varchar(50) not null,
        primary key (seq)
    ) [42001-214]

구글링을 많이 해봤지만, 뚜렸한 해답이 아니였습니다. 혹시 해서 User 를 Users 로 변경하니 해결되었습니다.

오히려, Users 가 더 위험 한거 아닌가 싶긴 합니다.

INFOMATION_SCHEMA에 USERS 테이블이 존재합니다. 그럼에도 일단 생성이 됩니다.

시간 날때 확인해봐야 하겠습니다.


User 를 Member 로 변경했습니다.

package octopus.entity;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;

import org.hibernate.annotations.Proxy;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonProperty;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;

@Builder // builder를 사용할수 있게 합니다.
@Entity // jpa entity임을 알립니다.
@Getter // user 필드값의 getter를 자동으로 생성합니다.
@Setter
@NoArgsConstructor // 인자없는 생성자를 자동으로 생성합니다.
@AllArgsConstructor // 인자를 모두 갖춘 생성자를 자동으로 생성합니다.
@Table(name = "member") // 'user' 테이블과 매핑됨을 명시
@JsonIgnoreProperties({ "hibernateLazyInitializer", "handler" }) // Post Entity에서 User와의 관계를 Json으로 변환시 오류 방지를 위한 코드
@Proxy(lazy = false)
public class Member extends CommonDateEntity {
	/**
     * 
     */
    private static final long serialVersionUID = 1246865649224168898L;

    @Id // pk
	@GeneratedValue(strategy = GenerationType.IDENTITY)
	private long seq;
	
	@Column(nullable = false, unique = true, length = 50)
	private String id;
	
    @Column(nullable = false, length = 100)
    private String name;
	
	@JsonProperty(access = JsonProperty.Access.WRITE_ONLY)
	@Column(length = 100)
	private String password;
	
}
728x90