inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Real MySQL 시즌 1 - Part 1

Ep.11 Prepared Statement

prepardStatement 질문있습니다.

해결된 질문

230

km9311

작성한 질문수 8

0

11강 Prepared Statment 강의를 듣다가 제일 마지막에

 

server-side preparedstatment는 메모리 부작용이 많으니 client-sid preparestatment를 권장한다고 하셨는데..

 

client-sid preparestatment를 사용하면 mysql 서버측에서는 statement로 받아들이잖아요. 그러면 바인드 변수값이 아니라 상수값으로 인식하니까

동일한 컨넥션 내에서 파싱트리도 공유가 안될테고..

 

그런 단점이 있는데도 client-sid preparestatment가 유리한건가요??

 

계속 오라클 기준으로 생각해서 그런지 해깔리네요..

오라클은 oltp에서 바인딩 변수가 아니라 상수로 사용하면

literal sql로 인식해 커서 공유가 안되니까 항상 바인드 변수를 사용하라고 권장하니까 statment 보다 preparestatment를 자주사용하잖아요..

 

두설없이 말씀드려서 죄송합니다. ㅠㅠ 해깔리네요 너무

 

mysql dbms/rdbms backend query-tuning mysql-query

답변 1

0

이성욱

안녕하세요.

우선, PreparedStatement의 효율에 대해서, Oracle RDBMS와 MySQL 서버의 비교는 큰 의미가 없어 보입니다. MySQL 서버에서는 ParseTree까지만 공유된다고 소개드렸는데, ParseTree는 실행 계획이 아니라, SQL 문장을 토큰 단위로 잘라서 의미를 해석해 둔 자료 구조일 뿐입니다.

 

그래서 MySQL 서버에서는 PreparedStatement가 다른 사용 DBMS 대비 효율이 그다지 좋지 않으면서, 차지하는 메모리 사용량까지 고려하게 만들어서 ... 각 서비스별로 효율성을 확인해볼 필요가 있다는 관점으로 이해해주시면 좋을 것 같아요. 혹시 더 궁금하신 내용은 다시 질문주세요.

 

감사합니다.

 

Commit 응답받기 전 네트워크 문제가 발생하면

1

64

1

14분44초에 쿼리 질문드립니다.

0

73

2

ep12. (2) LEFT JOIN 사용 방법 준수 - 오타 질문

0

75

2

ep.12 count(*) 질문

0

67

2

레코드 수정시 저장공간이 부족하면

0

81

2

복합 index 문의

0

87

2

강의

0

82

1

LEFT JOIN 시 드라이빙 테이블을 왜 ALL로 읽나요?

0

107

2

GAP 락에 대한 질문 드립니닷..!

0

195

1

ORDER BY가 필요한 이유

0

177

2

[오타 제보] 선행 데이터를 기반으로 한 데이터 분석

0

167

1

2강. VARCHAR(255) 저장되는 데이터의 길이 정보 질문

0

448

2

LIMIT, OFFSET을 사용하는 것과 범위 기반 방식의 성능 차이

0

319

2

MySQL Where절 내 조건의 순서

0

393

2

1강. delete marking된 데이터의 정리 주기는 어느 정도인가요?

0

238

2

Mysql table avg_row_length

0

144

1

12강 FULL GROUP BY

0

135

2

ep11) Prepared Statement에서 질문

0

145

2

7)select for update 강의에서 질문

0

229

2

12강. LEFT JOIN 사용 방법 준수 5:42

0

240

2

6강. Top N 데이터 조회와 관련해 질문있습니다.

0

195

2

5강에서 사례로 언급하신 DETERMINISTIC 예제에 대해 질문있습니다.

0

145

1

deternmistic 질문

0

174

2

1강 CHAR타입에 대해 질문드립니다

0

230

1