inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[개정판 2023-11-27] Spring Boot 3.x 를 이용한 RESTful Web Services 개발

테이블 insert

348

srl

작성한 질문수 1

0

Spring Data JPA 를 이용한 Entity 설정과 초기 데이터 생성 강의를 학습하는 도중에

data.sql에 insert into users values(1, now(), 'User1', 'test111', '701010-1111111'); 라고 하면 Error executing DDL insert into users values 이런 오류가 생성되는데 users에 파라미터를 써주고 하니 테이블에 잘 올라갔습니다. 무슨 차이가 있는지 궁금합니다!

insert into users(id, join_date, name, password, ssn) values(1, now(), 'User1', 'test111', '701010-1111111');

rest-api spring-boot

답변 1

0

인프런 AI 인턴

안녕하세요 srl 님, 인프런 AI 인턴이에요.

JPA에서 테이블에 데이터를 insert할 때, SQL 문법을 사용하여 직접 쿼리를 작성할 수 있습니다. 첫 번째 쿼리를 실행하면 “Error executing DDL”이라는 오류가 발생하는데, 이는 JPA가 데이터베이스의 스키마를 생성하거나 변경하는 DDL(Data Definition Language) 쿼리로 해석하기 때문입니다.

따라서, CREATE TABLE과 같은 스키마 변경 쿼리에서는 사용할 수 없지만, 두 번째 쿼리처럼 INSERT INTO 문을 사용하면 데이터를 테이블에 추가할 수 있습니다. JPA에서 제공하는 ORM(Object-Relational Mapping)을 통해 Entity 객체를 테이블의 레코드로 매핑하므로, Entity에 맞는 필드와 값을 지정하여 insert를 할 수 있습니다.

즉, 첫 번째 쿼리는 DDL로 해석되어 스키마를 생성하려고 시도하며 실패한 것이고, 두 번째 쿼리는 데이터를 직접 테이블에 삽입하는 INSERT INTO 쿼리입니다. INSERT INTO 문을 사용하여 직접 삽입하는 방법은 JPA의 ORM 기능을 우회하는 방법으로, 데이터를 직접 삽입할 때는 필요한 경우에만 사용하는 것이 좋습니다.

감사합니다!

JPA

0

57

1

jpa dependency를 추가하고 SecurityConfig클래스에서 오류가 납니다.

0

68

1

웹 브라우저 400 bad request

0

71

1

@Size는 되는데 @Past는 안 됩니다.

0

61

1

pdf 자료는 없나요?

0

73

2

locale 정보가 null 이면 무조건 messages_ko.properties이 호출 되는 문제

0

87

2

Swagger 강의, Unable to infer base url 이거 뜨시는 분들 도움되시라고

0

118

1

강의에서나온 화면 피피티

0

158

1

HelloWorldBean 관련 에러

0

183

2

Swagger API 3.x 오류..

0

219

1

java: variable message not initialized in the default constructor 에러는 어찌하면 좋을까요?

1

282

1

현재 GIT에 올리신 소스를 실행해봤습니다.

0

189

2

고양이 소리가 귀엽네요 !!

0

137

2

git에서 소스받고 실습중인데

0

117

1

post가 안되요

0

102

1

한국어 같은 경우 언어코드인 messages_ko.properties 로 생성하는게 더 좋지 않나요?

0

168

2

리턴타입으로서 EntityModel<User> 와 ResponseEntity질문

0

104

1

예외처리쪽 관련 질문있습니다.

0

159

2

엔티티가 바로 응답으로 나가도 되나요??

0

221

2

안녕하세여 Cannot invoke "co.kr.joneconsulting.resfulservice.repository.PostRepository.save(Object)" because "this.postRepository" is null

0

135

2

사용자 등록하고 나서 H2 에서 보면 신규 사용자의 password, ssn 이 null 로 되어 있습니다.

0

140

2

ApplictionContext 질문

0

192

2

롬북이 안먹히는것같아요

0

156

1

인텔리제이에서스프링부트 파일 실행하면

0

240

1