inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바와 스프링 부트로 생애 최초 서버 만들기, 누구나 쉽게 개발부터 배포까지! [서버 개발 올인원 패키지]

강의 준비 영상 - 스프링 프로젝트를 시작하는 첫 번째 방법

도서관 애플리케이션 실행 오류

744

qwe_e0606

작성한 질문수 3

1

도서관 애플리케이션을 실행하는 도중 아래와 같은 긴 오류가 떴습니다. 검색을 해도 잘 모르겠습니다 ㅠ어떻게 해야 할까요?

 

Error executing DDL "drop table if exists user cascade " via JDBC Statement

Caused by: org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "drop table if exists [*]user cascade "; expected "identifier"; SQL statement:

Error executing DDL "create table user (id bigint generated by default as identity, age integer, name varchar(20) not null, primary key (id))" via JDBC Statement

Caused by: org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "create table [*]user (id bigint generated by default as identity, age integer, name varchar(20) not null, primary key (id))"; expected "identifier"; SQL statement:

Error executing DDL "alter table if exists user_loan_history add constraint FKa17jbf1po26eytdyvyj73b4rw foreign key (user_id) references user" via JDBC Statement

Caused by: org.h2.jdbc.JdbcSQLSyntaxErrorException: Syntax error in SQL statement "alter table if exists user_loan_history add constraint FKa17jbf1po26eytdyvyj73b4rw foreign key (user_id) references [*]user"; expected "identifier"; SQL statement:

 

java spring aws mysql spring-boot jpa

답변 1

0

최태현

안녕하세요! 질문 주셔서 감사드립니다~~ 😊

 

해당 에러는 H2 DB를 사용해 "User"라는 테이블을 만들려고 할 때 발생하는 에러에요!!

Caused by: org.h2.jdbc.JdbcSQLSyntaxErrorException:
Syntax error in SQL statement "alter table if exists user_loan_history
add constraint FKa17jbf1po26eytdyvyj73b4rw foreign key (user_id)
references [*]user"; expected "identifier"; SQL statement:

라는 에러에서 끝 부분 user; expected "identifier 라는 의미가 user 라는 이름은 DB의 키워드로 잡혀 있어 사용할 수 없다 라는 뜻이거든요!

키워드로 잡혀 있다는 의미는 Java의 ifelse 처럼 특수한 문자로써 동작한다는 의미입니다. Java에서는 저희가 if 라는 이름으로 변수를 만들 수 없죠!

 

H2 DB는 <38강. profile과 H2 DB>에서 처음 소개드리고 있으며, 해당 에러를 발생시키지 않도록 옵션을 주고 있습니다.

 

현재 사용하고자 하신 DB가 MySQL이라면, MySQL 설정이 잘 되어있는지 확인해주시면 해결될 것 같고요!

만약 H2 DB를 사용하고자 하신거라면, <38강. profile과 H2 DB> 에 나온 url 을 적용하시면 해결될겁니다!

 

꼭 해결되셨으면 좋겠습니다, 감사합니다 🙇🙇

5

seohyeonjin787

저도 같은 오류가 떴습니다. h2데이터베이스에서 'user'라는 키워드가 예약어라서 사용을 못한다고 합니다. 해결방법은 src/main/java/com/group/libraryapp/domain/user/User 클래스로 오셔서

public class User{ 이 바로 윗줄에

@Table(name="UERS") 를 추가하시고 ctrl+S(저장) 후 다시 LibraryAppApplication 의 메인메서드 실행하시면 동작합니다

패키지 구분에 대해 궁금한게 있습니다

0

20

2

리액트 관련 질문이 있습니다.

0

64

2

스프링부트 버전

0

73

2

7강 강의를 들으려고 했는데 오류가 나서 서버가 안 켜지는거 같아요.

0

59

2

33강. UserLoanHistory의 관계성에 대한 질문

1

56

2

Java JDK 버전 문의의 건

0

132

2

ec2 에서 Linux버전이 달라져서 설치가 안되는것 같은데 자료 최신화좀 해주세요.

0

89

3

h2 console 접속했을 테이블 질문

1

65

1

ec2 서버에서 스프링 실행도 되고 인바운드 설정까지 했는데 index.html 안됨

0

75

2

15강. updateUser() 질문

0

55

2

깃허브 질

0

82

2

여기까지 다 끝냈다고 하셨는데

0

79

2

왜안될까요

0

70

2

MySQL 창이안ㄴ뜹니다

0

59

2

포스트맨

0

50

1

spring 개념적인 질문

0

71

2

인텔리제이 샘플코드 실행 안됨 오류

0

140

2

aws 배포할때 .env 파일에 저장한 환경변수에 관하여 여쭤볼게 있습니다

0

85

1

마이그레이션 오류입니다.

0

171

3

Whitelabel Error Page 오류가 났습니다.

0

163

2

안녕하십니까! 오류가 났습니다.. 도와주세요 ㅜㅜ

1

93

3

궁금한게 있습니다.

0

60

2

DTO 관련

0

70

2

궁금한게 있습니다!

0

68

2