- 질문 게시판입니다.
Date 16/09/07 15:39:14
Name   YORDLE ONE
Subject   JPA와 Mariadb관련 질문입니다.. 뻘쭘 (해결했습니다)
안녕하세요.. 웹개발자하면서 이번에 jpa 환경에서 처음 일을 하게 될 것 같아서
간단한 프로그램 하나를 jpa +mariadb + spring boot 환경으로 만들어보고 있는데요..

현재 제가 삽질중인 상황이 좀 어이없어서 여쭤보고자 질문올립니다.

일단 쿼리를 하나 예시로 보겠습니다.

1번 쿼리 =
insert into code_table (columnA, columnB) values ('A', 'B') // 안됨

2번 쿼리 =
insert into `code_table` (`columnA`, `columnB`) values ('A', 'B') // 됨

차이를 아시겠나요. 테이블과 컬럼명에 ` 가 붙어있어야 쿼리가 정상 동작을 합니다. -_-;

근데 문제는 말이죠.... JPA에서 자동으로 쿼리를 생성해줄때 컬럼명을 도메인에서 고스란히 가져다가 쓰는데요.


@Entity
public class CodeTable {

@Id
private String columnA;
private String columnB;
}

이상태의 도메인에서 소스를 돌리면, 1번 쿼리처럼 쿼리가 생성되서 execute됩니다. 그리고 예외가 발생하죠.
그래서 이렇게 해봤습니다.


@Entity
@Table(name="`code_table`")
public class CodeTable {

@Id
@Column(name = "`columnA`")
private String columnA;

@Column(name = "`columnB`")
private String columnB;
}

뭐가 바뀌었는지 보이실까요. @Table과 Column 어노테이션을 추가해서 컬럼명을 맞춰주었는데, 저기에다가 ` 를 붙여놓았습니다.
저렇게 하고 소스를 돌리면 정상적으로 execute가 되고, commit까지 완료되면서 해피엔딩을 맞이할 수 있게 되죠.
그런데.. 제가 구글링하면서 대충 찾아본 다른 개발자 블로거분들 도메인 예제를 보면, 저런 어노테이션을 붙이지도 않을 뿐더러, 만약 붙였더라도 `를 붙이진 않았거든요.

그래서 문득 생각이 든게 `를 필수로 받아들이는 마리아디비쪽이 나쁜거 아닌가?..
마리아디비 설정을 내가 이상하게 했나?? 라는 생각이 들더군요.

그래서 드디어 질문입니다만

마리아디비에서 insert 등의 쿼리를 칠 때, `와 같은 특수문자로 컬럼명 테이블명 등을 랩핑하지 않아도 되는 설정법을 혹시 아시는 분이 계신지.. 가르침을 주세요..
혹은 위와 같은 상황을 단순히 피할 수 있는 노하우를 아시는 고수분들.. 가르침을 주십시오 흑흑..
물론 `로 랩핑해서 코딩하면 기능이야 잘 돌겠지만.. 아무리봐도 이거 이상하잖아요 으아아아

이상한 질문 읽어주셔서 감사합니다..


+ 해결

아.. 문제 해결 했습니다. 제가 예시 테이블을 컬럼이 쓸데없이 많은걸로 테스트를 하고 있었는데요.
그중에 예약어가 하나 들어있었던 모양이에요... 컬럼 이름은 order였습니다.
order를 다른 이름으로 바꿔주니 정상적으로 잘 실행이 됩니다.
위에는 예시를 위해 columnA, B로 바꿔서 썼었는데.. 결과적으로는 말도안되는 질문이 되어버렸네요

잠깐이라도 읽으셨던 분들께 혼란을 드려서 죄송해요 -_-;



0


목록
번호 제목 이름 날짜 조회 추천
5103 IT/컴퓨터지도 위의 세력변화 애니메이션 표현에 가장 적합한 툴? 7 메존일각 18/07/21 3862 0
5299 문화/예술왜 헐리웃 슈퍼 히어로 영화에선 꼭 로맨스 장면이 나오나요? 10 덕후나이트 18/08/22 3862 0
6547 IT/컴퓨터TV질문입니다! 12 DogSound-_-* 19/02/14 3862 0
7662 의료/건강디스크 수술 관련으로 질문 여쭙니다. 16 [익명] 19/08/16 3862 0
11339 의료/건강아버지가 급히 병원에 실려갔는데 어떤 증상인지 질문드립니다 3 네임넴 21/04/12 3862 0
3541 의료/건강지인이 발이 많이 저리다는데 좋은 약이 있을까요? 4 17/10/21 3863 0
5559 기타일반적이지 않은 이름 영문표기는 불편한경우가 많을까요? 5 [익명] 18/10/01 3863 0
8875 연애썬크림 바른 뒤에 피부 여드름 올라옴 15 [익명] 20/02/28 3863 0
1797 법률조건부 증여 질문입니다. 3 tannenbaum 16/11/20 3864 0
2252 IT/컴퓨터트위터가 정지되었습니다. 불타는밀밭 17/02/04 3864 0
5014 문화/예술Top 100과 Top100(clean)의 차이 2 파란 회색 18/07/11 3864 0
1638 의료/건강동생이 기면증을 걱정하고있습니다. 3 쉬군 16/10/10 3865 0
4427 기타27인치 모니터 질문입니다 2 김치찌개 18/04/08 3865 0
5261 가정/육아중국집 일회용 용기 2 [익명] 18/08/15 3865 0
7187 경제창원이나 마산에 한우집을 추천받고 싶읍니다. 6 사나남편 19/05/24 3865 0
14725 과학조명용 LED 모듈을 추천받고 싶습니다 2 ㅢㅘㅞ 23/04/22 3865 0
1568 IT/컴퓨터웹사이트 관리 초보자도 가능할까요? 9 진저에일 16/09/27 3866 0
2339 기타기업용 NAS를 구매하려고 합니다. 7 김피곤씨 17/02/17 3866 0
4612 의료/건강비전문가의 일반의약품 처방(?) 2 이브나 18/05/11 3866 0
7961 IT/컴퓨터구버전 gcc에서 vector initialization 5 kaestro 19/09/30 3866 0
8618 기타효과음을 찾습니다 천하대장군 20/01/11 3866 0
16039 진로혹시 '5년내에 내 스스로 생을 마감하겠다' 하는분들 계십니까?? 25 [익명] 24/07/31 3866 0
1983 IT/컴퓨터메일 첨부파일 용량을 늘리는 법이 있나요? 6 불타는밀밭 16/12/27 3867 0
4640 가정/육아삭제 22 [익명] 18/05/16 3867 0
6378 진로면접 후 2곳에서 출근의사를 물었는데, 여러분들 이라면 어디로?? 24 [익명] 19/01/23 3867 0
목록

+ : 최근 2시간내에 달린 댓글
+ : 최근 4시간내에 달린 댓글

댓글