분류 전체보기

반응형
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
<%@ taglib prefix="spring" uri="http://www.springframework.org/tags" %>
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %>

JSTL 태그 라이브러리 설정 코드

 

결론부터 말하자면 인터넷 없이도 사용 가능합니다.

 

uri


여기서 말하는 uri *CDN 방식처럼 인터넷 주소로 찾아가 라이브러리를 얻어오는 것이 아니고,

JSTL 라이브러리에서 지원되는 기능을 태그별로 구분해주는 구분자이다.

 

JSTL 라이브러리에 존재하는 주소(?) 찾아간다고 생각하면 된다. 

외부에서 돌아다니는게 아니고, 내부 라이브러리에서 찾아댕김

 

jsp page 에서는 uri 에 입력된 값을 통해 태그라이브러리를 식별하여 해당 라이브러리로 찾아가기 때문에

정확히 입력해주어야 한다.

 라이브러리

uri

코어 

 http://java.sun.com/jsp/jstl/core

 XML

 http://java.sun.com/jsp/jstl/xml

 국제화

 http://java.sun.com/jsp/jstl/fmt

 데이터베이스

 http://java.sun.com/jsp/jstl/sql

 함수

 http://java.sun.com/jsp/jstl/functions

 

*CDN : CDN(Contents Delivery Network)은 지리적 물리적으로 떨어져 있는 사용자에게 컨텐츠 제공자의 컨텐츠를 더 빠르게 제공할 수 있는 기술.

느린 응답속도 / 다운로딩 타임 을 극복하기 위한 기술.

 

prefix


만약 코어(core) 라이브러리를 쓴다고 가정하자.

prefix 여기서 꼭 c 일 필요는 없다.

, 다른 문자를 해줘도 된다.

 

 

문법 예시 


<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
    <c:if test="true"></c:if>
    
<%@ taglib prefix="cw" uri="http://java.sun.com/jsp/jstl/core" %>
 <cw:if test="true"></cw:if>

이런식으로 변경해도 정상 작동한다.

 

 

식겁했던 사례


얼마전 사이트에서 !!! 렉이 발생했다.

 

문제는 *CDN 방식이였다. 왜냐하면 납품 사이트가 내부 인터넷 환경이였기 때문이다.

외부로 나가 정보를 받아와야하는데 그것이 안돼서 진짜 끔찍한 렉을 발생시켰다

중요한 아예 못받아와야 정상아닌가… 정말 느리지만 돼긴 됬다.

 

나머지 코드들도 *CDN 방식 있나 확인 하던 도중.

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>
<%@ taglib uri="http://java.sun.com/jstl/core_rt" prefix="c-rt" %>
<%@ taglib uri="http://java.sun.com/jstl/fmt" prefix="fmt" %>
<%@ taglib uri="http://java.sun.com/jstl/fmt_rt" prefix="fmt-rt" %>

눈에 JSTL taglib 방식 JSTL 걷어내야 하는줄 알고 정말 식겁했다.

 

바로 인터넷에 구글링 겁나했는데 나오질 않는다….내부 인터넷 환경이 별로없는것인가..

해서 직접 실험해봤다 결과는 아주 됩니다.

 

 

정리

JSTL 태그 라이브러리 인터넷 없이도 사용 가능합니다.

반응형
반응형

시작하기에앞서 참고 자료

 

*ibatis 비교문 지원 태그

 

isNull : "널일경우"

isNotNull : "널이아닐경우"

isEmpty : "공백일경우"

isNotEmpty : "공백이아닐경우"

isGreaterTan : ">"

isGreaterEqual : ">="

isLessThan : "<"

isLessEqual : "<="

isEqual : "=="

isNotEqual : "!="

 


*ibatis : mybatis 버전


MyBatis 비교문 지원 태그

 

<if>  : 단일 조건문

<choose> <when> <otherwise> : 다중 조건문

 

*ibatis에는 isNull, isEmpty가 있었지만 MyBatis에는 없다.

 

 

문자열 비교


paraName1 이라는 파라미터가 null이 아니면서 값이 "test"와 동일한가?

 <if test='paraName1 != null  and(paraName1 eq "test".toString())'>

 </if>

paraName1 이라는 파라미터가 "all" 이라는 문자와 동일 하지 않은가?

<if test='!paraName1.equals("all")'>
   
</if>

 

대소문자 관계없이 비교


paraName1 이라는 파라미터가 null이 아니면서 값이 "test" or "TEST"와 동일한가?

<if test='paraName1 !=null  and paraName1.equalsIgnoreCase("test")'>

 </if>

 

특정 비교


paraName1 이라는 파라미터의 값이 "Y"인지 검사할 경우

<if test='paraName1== "Y"'></if>

 

paraName1 이라는 파라미터의 값이 공백인지 검사할 경우

<if test='paraName1 == " "'></if>

 

주의 : 작은 따옴표가 있어야 한다.

 

 

숫자 비교


paraName1 이라는 파라미터의 값이 3보다 큰가?

<if test='paraName1 > 3'></if>    

paraName1 이라는 파라미터의 값이 3보다 크거나 같은가?                                     

<if test='paraName1 >= 3'></if>

paraName1 이라는 파라미터의 값이 3보다 작은가?  

<if test='paraName1 < 3'></if>

paraName1 이라는 파라미터의 값이 3보다 작거나 같은가?

<if test='paraName1 <= 3'></if>

paraName1 이라는 파라미터의 값이 숫자로 문자열일 경우

<if test='paraName1 > "3"'></if>
//비교할 값을 쌍 따옴표로 묶어준다.

 

주의

요소 유형 "null"과(와) 연관된 "test" 속성의 값에는 '<' 문자가 포함되지 않아야 합니다.

이러한 예외가 발생하였다면?

 

원인

if 태그 안에 ">" 괄호를 인식하지 못하는 거다. 그렇다면 CDATA를 쓰면 어떨까? 역시 적용되지 않는다.

일단 원인은 ">" 괄호를 XML Parsing으로 인식한 건데, XML Parsing을 Text로 바꿔주는 CDATA 마저 적용되지 않는 현상

 

해결

기호

 대체식

예제

lt 

 <if test="paraName1 lt 0">

>

gt

<if test="paraName1 gt 0"> 

<= (또는 =<)

lte 

 <if test="paraName1 lte 0">

 >= (또는 =>)

gte

 <if test="paraName1 gte 0">

 

or


||가 아닌 or로 쓰셔야 합니다.

or (O)

|| (X)

 

paraName1 값이 Y이거나 paraName2의 값이 N인 경우

 

<if> 문

<if test='paraName1 == "Y" or paraName2 == "N"'></if>

<choose> 문

<choose>
<when test='paraName1 == "Y" or paraName2 == "N"'>
</choose>

 

굳이 || 사용하실 분들이 있다면 굳이!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

|amp;|amp;

<if test='paraName1 == "Y" |amp;|amp; paraName2 == "N"'></if>

 

and


&&가 아닌 and로 쓰셔야 합니다.

and (O)

&& (X)

 

paraName1 값이 Y이고 paraName2의 값이 N인 경우

 

<if> 문

<if test='paraName1 == "Y" and paraName2 == "N"'></if>

<choose> 문

<choose>
<when test='paraName1 == "Y" and paraName2 == "N"'>
</choose>

 

굳이 && 사용하실 분들이 있다면 굳이!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

&amp;&amp;

<if test='paraName1 == "Y" &amp;&amp; paraName2 == "N"'></if>

 

null,nullString 체크


<if test='paraName1 == null'></if>
<if test="paraName1 == null"></if>

<if test="!paraName1.equals('') and paraName1!=null">

</if>

<if test="paraName1!=null and !paraName1.equals('')">

</if>

 

정리

1.문자열 비교

2.특정 비교

3.숫자 비교

4.or

5.and

6.null 체크

JPA 쓰자!!!!!!!!!!!!!!!!!!!!!

 

 

MyBatis 속성

다음은 MyBatis에서 제공 해주는 속성들을 알아보겠습니다.

반응형
반응형

오늘은 Java 기본형(primitive type)과 참조형(reference type) 종류 및 특징,사용 이유에 대해 시작하겠습니다.

 

자바는 크게 기본형(primitive type), Wrapper Class 참조형(reference type)으로 나눠진다.

Primitive(머티브) 자료형(기본형 타입)

종류


byte

short

int

long

float

double

char

boolean

void

 

이것들을 Primitive 자료형이라 부른다.

 

 

특징


모두 첫 글자가 소문자

산술 연산이 가능함.

null 초기화 없음.

int a = null; (x)
int a = 0; (o)

 

Wrapper 클래스(포장 클래스)

 

종류


Byte 

Short 

Integer 

Long 

Float 

Double 

Charater 

Boolean 

Void

 

 

특징


모두 첫 글자가 대문자
산술
연산 불가

null 초기화 있음.

DB 연동시 DTO 객체에 null 필요한 경우 사용 있음

 

 

사용 이유


1. 매개변수로 객체가 요구 될때.

2. 기본형 값이 아닌 객체로 저장해야 할 때.

3. 객체간의 비교가 필요할 때.

 

 

그리고

Boxing과 Unboxing의 개념을 알아야 합니다.

Boxing

개념


Primitive 자료형 -> Wrapper 클래스

기본형 자료형을 포장 클래스로 변환한다.

int primitive_age = 30;
Integer wrapper_age = new Integer(primitive_age);

 

Unboxing

개념


Wrapper 클래스 -> Primitive 자료형

포장 클래스를 기본형 자료형으 변환한다.

Integer wrapper_age = new Integer(30);
int primitive_age= wrapper_age.intValue();

 

 

정리

객체 박스(Wrapper 클래스) 정수를 담는다. (Boxing)

박스에 담겼으니 안에 내용물을 바꾸는건 불가능하다.

 

바꾸려면 박스에서 내용물을 꺼낸다. (Unboxing)

내용물을 다시 꺼냈으니 바꾸는게 가능해짐.

 

Integer - Wrapper 클래스

int - 기본 자료형

 

여기서 잠깐!

Integer obj = new Integer(61); 아니라

Integer obj = 61;로 해도 61 정수가 자동으로 박스에 담긴다.

이건 무엇일까??

 

[JDK 1.5 버전 이후 사용 가능]

그것이 바로 AutoBoxing AutoUnBoxing 기능이다.

 

AutoBoxing

 

개념


int num1 = 61;
Integer obj = num1;

int num1의 값을 Integer 객체에 넣기 위해서는(Boxing) new Integer(num1) 과 같이 객체를 생성해야 하지만,

위와 같이 대입하면 AutoBoxing이 자동으로 진행된다.

 

 

AutoUnBoxing

 

개념


Integer obj2 = new Integer(69);
int num1 = obj2;

Integer 객체에 있는 int 값을 가져오기 위해서는(UnBoxing) obj2.intValue() 메소드를 사용하여 가져와야 하지만,

위와 같이 int 형 변수에 Integer 객체를 대입하면 자동으로 UnBoxing이진행된다.

 


주의

AutoBoxing과 AutoUnBoxing 은 단지 기본형 타입과 상응하는 Wrapper class에만 일어난다.

다른 경우에 대입을 시도하면 컴파일 에러가 발생한다.

- Integer intValue(), Double doubleValue() 등만 AutoBoxing과 AutoUnBoxing이 발생한다.

Double obj = 3.14;
int num1 = obj.intValue() ; (O)
int num1 = obj; (X)

 

* Wrapper 클래스의 기본 메소드들

 메소드

반환값 

설명 

 booleanValue()

boolean 

기본형 데이터를 문자열로 바꾼 뒤에 반환 

 byteValue()

byte 

객체의 값을 byte 값으로 변환하여 반환 

doubleValue() 

double 

객체의 값을 double 값으로 변환하여 반환 

floatValue() 

float

객체의 값을 float 값으로 변환하여 반환 

intValue() 

int 

객체의 값을 int 값으로 변환하여 반환 

longValue() 

long 

객체의 값을 long 값으로 변환하여 반환 

 shortValue()

short 

객체의 값을 short 값으로 변환하여 반환 

Wrapper class 객체에서 해당 메소드를 사용은 형변환이 가능한 메소드만 사용이 가능하다.

 

+추가

Integer.parseInt("100") , Integer.valueOf("100") 이 둘의 차이점이 헷갈린다면 참고

 

[Java] parseInt()와 intValue()

오늘은 Java parseInt() && intValue() 개 (개념) 이 (사용 이유) 문 (문법 및 예시) 시작하겠습니다 . parseInt() 개념 static 이다, 그러므로 Integer 생성안하고 parameter만 넣어주면 메소드를 수행할 수 있다..

java119.tistory.com

 

반응형
반응형

우리를 괴롭히지만 백엔드 개발자라면 반드시 마주해야 하는

REST와 REST API와 RESTful의 개념을 확실히 알아보자.

 

REST (Representational State Transfer)

 

개념


하나의 URI는 하나의 고유한 리소스를 대표하도록 설계된다는 개념이다.

 

하나의 URI는 하나의 고유한 리소스를 대표하도록 설계!

 

자원을 이름(자원의 표현)으로 구분하여 해당 자원의 상태(정보)를 주고받는 모든 것을 의미한다.

 

기본적으로 웹의 기존 기술과 HTTP 프로토콜을 그대로 활용하기 때문에,

웹의 장점을 최대한 활용할 수 있는 아키텍처 스타일이다.

 

HTTP 통신을 한다는 말.

 

REST는 네트워크 상에서 Client와 Server 사이의 통신 방식 중 하나이다 통신 방식이랍니다. 통신 방식

 

 

TMI


2000년도에 로이 필딩 (Roy Fielding)의 박사학위 논문에서 최초로 소개되었습니다. 로이 필딩은 HTTP의 주요 저자 중 한 사람으로 그 당시 웹(HTTP) 설계의 우수성에 비해 제대로 사용되지 못하는 모습에 안타까워하며 웹의 장점을 최대한 활용할 수 있는 아키텍처로써 REST를 발표했다고 합니다.

 

 

사용 이유


HTTP 프로토콜의 인프라를 그대로 사용하므로 REST API 사용을 위한 별도의 인프라를 구축할 필요가 없다.

웹 서버+소프트 웨어(설치)가 아니라 웹 서버+REST API가 된다는 말.

 

HTTP 표준 프로토콜이기 때문에 HTTP 통신만 되는 플랫폼이라면

플랫폼의 영향을 받지 않는다.

 

REST API 메시지가 의도하는 바를 명확하게 나타내므로 의도하는 바를 쉽게 파악할 수 있다.

 

서버와 클라이언트의 명확한 역할 분리.

 

다양한 브라우저 및 모바일 디바이스에서 통신 가능.

 

애플리케이션 분리 및 통합 가능.

 

 

종류


METHOD

역할

POST(Create)

POST를 통해 해당 URI를 요청하면 리소스를 생성합니다.

GET(Read)

GET를 통해 해당 리소스를 조회합니다. 리소스를 조회하고 해당 도큐먼트에 대한 자세한 정보를 가져온다.

PUT(Update)

PUT를 통해 해당 리소스를 수정합니다.

DELETE(Delete)

DELETE를 통해 리소스를 삭제합니다.

HEAD

Header 정보를 조회(HEAD) 합니다.

 

종류는 무조건 외우는 걸로!

 

 

특징


1.Server-Client(서버-클라이언트 구조)

 

자원 요청(Request) Client

-사용자 인증, 세션, 로그인,토큰 정보 등을 관리

 

자원 응답(Response) Server

-API 제공 , 비즈니스 로직 처리 및 저장

 

1-1.Stateless(무상태)

 

HTTP 프로토콜은 *Stateless Protocol이므로

REST 역시 무상태성을 갖는다. (HTTP 프로토콜이니까)

 

*Stateless Protocol (무상태 프로토콜)

 

- 서버와 클라이언트의 이전 통신 상태 (state)를 저장하지 않는 프로토콜  

  - 서버의 현재 상태에 따라 요청 (request)에 대한 응답(response)이 달라질 수 있음

  - 연속된 상태정보를상태 정보를 저장하지 않기 때문에 HTTP는 application 구현 상에서 상태 정보를 저장해야 함 

 

1-2.Client의 context를 Server에 저장하지 않는다.

(그러므로 할 일이 줄어듬 구현이 단순해짐)

 

1-3.Server는 각각의 요청을 완전히 별개의 것으로 인식하고 처리.

(이 부분은 Stateless Protocol 설명에 나와있다.)


 

2.Cacheable(캐시 처리 가능)

 

2-1. 웹 표준 HTTP 프로토콜을 그대로 사용하므로 웹에서 사용하는 기존의 인프라를 그대로 활용할 수 있다.

-HTTP 캐싱 기능 적용 가능

-HTTP 프로토콜 표준 *Last-Modified 태그나 *E-Tag 이용 캐싱 구현 가능

-대량의 요청을 캐시 사용에 의해 응답 시간 ↑ 성능 ↑ 서버 자원 이용률 ↑ REST Server 트랜잭션 발생 X

동일한 GET 메서드 실행 -> 캐시에서 가져옴 -> 속도 향상

 

*Last-Modified

응답은 HTTP 헤더에 서버가 알고 있는 가장 마지막 수정된 날짜와 시각을 담고 있습니다. 

이미지/CSS/JS와 같은 정적 파일들은 아파치에서 자동적으로 Last-Modified, If-Modified-Since 헤더를 붙여줌

문법

Last-Modified: <day-name>, <day> <month> <year> <hour>:<minute>:<second> GMT

 

*E-Tag

HTTP 응답 헤더는 특정 버전의 리소스를 식별하는 식별자입니다. 웹 서버가 내용을 확인하고 변하지 않았으면, 웹 서버로 full 요청을 보내지 않기 때문에, 캐시가 더 효율적이게 되고, 대역폭도 아낄 수 있습니다. 하나, 만약 내용이 변경되었다면, "mid-air collions"이라는 리소스 간의 동시 다발적 수정 및 덮어쓰기 현상을 막는데 유용하게 사용됩니다.

 

아파치에서는 이미지/CSS/JS와 같은 정적 파일은 자동으로 ETag 헤더를 붙여줌

 

같은 내용을 보냈으면 캐시로 있던 거 보내고 아니면 데이터 업데이트해준다는 말.


3.Layered System(계층화)

 

3-1.Client는 REST API Server만 호출.

3-2.REST Server는 다중 계층으로 구성될 수 있다.

3-3.API Server는 순수 비즈니스 로직을 수행하고 그 앞단에 보안, 로드밸런싱, 암호화, 사용자 인증 등을 추가하여 구조상의 유연성을 줄 수 있다.

또한 로드밸런싱, 공유 캐시 등을 통해 확장성과 보안성을 향상할 수 있다.

PROXY, 게이트웨이 같은 네트워크 기반의 중간 매체를 사용할 수 있다.


4.Uniform Interface(인터페이스 일관성)

 

URI로 지정한 Resource에 대한 조작(CRUD)을 통일되고 한정적인 인터페이스로 수행.

HTTP 표준 프로토콜에 따르는 모든 플랫폼에서 사용이 가능.

특정 언어나 기술에 종속 X.

 

 

이제 REST 설명 끝났고…………………….

 

REST API

 

개념


위 내용에서 실컷 설명한 { REST } 기반으로 서비스 API를 구현한 것!

 

 

사용 이유


사내 시스템들도 REST 기반으로 시스템을 분산해 확장성과 재사용성을 높여 유지보수 및 운용을 편리하게 할 수 있다.

REST는 HTTP 표준을 기반으로 구현하므로, HTTP를 지원하는 프로그램 언어로 클라이언트, 서버를 구현할 수 있다.

 

계속 반복되는 말

REST는 HTTP 표준 기반 HTTP가 사용되는 데는 모두 다 사용할 수 있다.

 

 

설계 규칙


도큐먼트 : 객체 인스턴스나 데이터베이스 레코드와 유사한 개념, 단수 명사를 사용.

컬렉션 : 서버에서 관리하는 디렉터리라는 리소스, 복수 명사를 사용.

스토어 : 클라이언트에서 관리하는 리소스 저장소, 복수 명사를 사용.

 

URI는 정보의 자원을 표현해야 한다.

 

Resource

 

동사보다는 명사, 대문자보다는 소문자를 사용.

GET /Member/1 -> GET /members/1

 

자원에 대한 행위는 HTTP Method(GET, PUT, POST, DELETE 등)로 표현한다.

 

URI에 HTTP Method가 들어가면 안 된다.

GET /members/delete/1 -> DELETE /members/1

URI에 행위에 대한 동사 표현이 들어가면 안 된다.(즉, CRUD 기능을 나타내는 것은 URI에 사용하지 않는다.)

GET /members/show/1 -> GET /members/1
GET /members/insert/2 -> POST /members/2

경로 부분 중 변하는 부분은 유일한 값으로 대체한다.(즉, :id는 하나의 특정 resource를 나타내는 고윳값이다.)

student를 생성하는 route: POST /students
id=12인 student를 삭제하는 route: DELETE /students/12

 

슬래시 구분자(/ )는 계층 관계를 나타내는 데 사용한다.

http://restapi.example.com/houses/apartments

URI 마지막 문자로 슬래시(/ )를 포함하지 않는다.

http://restapi.example.com/houses/apartments/ (X)

 

하이픈(- )은 URI 가독성을 높이는 데 사용

불가피하게 긴 URI경로를 사용하게 된다면 하이픈을 사용해 가독성을 높인다.

 

밑줄(_ )은 URI에 사용하지 않는다.

밑줄은 보기 어렵거나 밑줄 때문에 문자가 가려지기도 하므로 가독성을 위해 밑줄은 사용하지 않는다.

 

파일 확장자는 URI에 포함하지 않는다.

REST API에서는 메시지 바디 내용의 포맷을 나타내기 위한 파일 확장자를 URI 안에 포함시키지 않는다.

Accept header를 사용한다.

http://restapi.example.com/members/soccer/345/photo.jpg (X)
GET / members/soccer/345/photo HTTP/1.1 Host: restapi.example.com Accept: image/jpg (O)

리소스 간에는 연관 관계가 있는 경우

/리소스명/리소스 ID/관계가 있는 다른 리소스명

GET : /users/{userid}/devices

 

RESTful

 

개념


RESTful은 일반적으로 REST라는 아키텍처를 구현하는 웹 서비스를 나타내기 위해 사용되는 용어이다.

 

REST API를 제공하는 웹 서비스를 RESTful 하다고 할 수 있다.

 

RESTful은 REST를 REST 답게 쓰기 위한 방법으로, 누군가가 공식적으로 발표한 것이 아니다.

즉, REST 원리를 따르는 시스템은 RESTful이란 용어로 지칭된다

 

이해하기 쉽고 사용하기 쉬운 REST API를 만드는 것

 

서드 파티 웹 콘텐츠를 만드는 경우, 그들에게 제공해줄 수 있을 만큼의 REST API를 제공하는 것.


정리

 

REST

1. 로이 필딩이라는 사람이 2000년에 발표함.

2. 하나의 URI 하나의 고유한 리소스를 대표하도록 설계한 개념

3.HTTP 프로토콜을 사용하는 곳이면 사용 가능

4.Server-Client 명 확 히 구분됨

5. 종류는 GET, POST, PUT, DELETE가 있음.


REST API

1.REST 기반으로 만들어진 API

2.URI는 정보의 자원을 표현해야 한다.

3. 자원에 대한 행위는 HTTP Method(GET, POST, PUT, DELETE)로 표현한다.


RESTful

1. 여긴 REST API 제공합니까? 네.라고 할 수 있다면 RESTful

 

다음엔 개념 말고 실제 문법과 사용법에 대해 포스팅하겠습니다.

반응형
반응형

궁금은 했지만 알아보기 귀찮은 #{} ${} 개념과 차이점을 아주 명확하고 확실하게 알아보도록 하겠습니다.

 

먼저 PreparedStatement 와 Statement를 알아야 한다.

 

간단하게 할게요;;

 

 

PreparedStatement


String sqlstr = "SELECT name, memo FROM TABLE WHERE num = ? " 
PreparedStatement stmt = conn.prepareStatement(sqlstr); 
pstmt.setInt(1, num);
ResultSet rst = pstmt.executeQuerey(); 

메모리에 올라가게 되므로 동일한 쿼리의 경우 , 매번 컴파일 되지 않아도 된다는 이점 성능

 

Statement


String sqlstr = "SELECT name, memo FROM TABLE WHERE num = " + num 
Statement stmt = conn.credateStatement(); 
ResultSet rst = stmt.executeQuerey(sqlstr); 

executeQuerey() 마다 매번 컴파일함 성능

 

주인공 아니니까 여기까지 자세한건 검색~

 

#{}

 

사용 과정


1.#{} 사용시 PreparedStatement 생성

2.PreparedStatement 매개 변수 안전하게 설정

3. PreparedStatement 제공하는 set 계열의 메소드를 사용하여 물음표(?) 대체할 값을 지정.

4.들어오는 데이터 문자열로 인식하기 때문에 자동 따옴표 붙음

들어오는 데이터 문자열로 인식하기 때문에 자동 따옴표 붙음

들어오는 데이터 문자열로 인식하기 때문에 자동 따옴표 붙음

 

 

사용 이유


안전하고 빠르기 떄문에 선호

빠를까??

Prepared (준비)

여기서 말하는 준비는 컴파일(Parsing) 을 이야기하며, 컴파일이 미리 되어있는 녀석이기에 Statement 에 비해 성능상 이점

 

 

문법


SELECT count(*) FROM 
ExUSER_TB
WHERE USER_ID = #{id} AND USER_PW = #{pw}
SELECT count(*) FROM ExUSER_TB 
WHERE 
USER_ID = ? AND USER_PW = ?

 

${}

 

사용 과정


1.${} 사용시 Statement 생성

2.Statement 매개변수 그대로 전달

그 대 로

3.전달 하기 떄문에 문자열에 따옴표가 붙지 않는다.

예) select * from Extable where Statementparameter = 홍길동

4.테이블 컬럼 타입이 varchar여도 숫자 그대로 들어가기 떄문에

예) select * from Extable where Statementparameter(varchar 타입) = 1

 

사용 이유


다른 이유도 있겠지만 가장 이유는 이거인거 같다.

바로 ORDER BY 함수를 사용할 오히려 자동 따옴표가 붙으면

함수가 안먹기 때문에 ${} 써야한다.

 

 

문법


SELECT count(*) FROM 
ExUSER_TB 
WHERE USER_ID = "${id}" AND USER_PW = "${pw}"
ORDER BY $ {columnName}

굳이

굳이!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

 

 

단점


SQL Injection 같은 문제에 취약하다. 왜냐하면 문자열을 직접 삽입하기 때문이다.

 

 

*SQL Injection : 나쁜놈들이 DB 옆구리 찌르는 기술.

 

 

정리

1.#{} 자동으로 값에 따옴표가 붙고 성능 좋음

2.${} 그대로 전달 따옴표 안붙음 성능 좋지 않음 보안 취약

3.ORDER BY 아니면 #{} 쓰기.

 

반응형
반응형

오키에 어떤 멋진 선배님이 덧글로 남긴 거 퍼옵니다. 

 

사항들만 지켜도 오류(예외) 해결 됩니다.

하나하나 다시 되돌아보시기 바랍니다.

 

1. 에러 출력되는 부분은 없습니까?

 

2. 디비 설정이 디비명, 테이블명 칼럼명 등 대소문자 구분합니까?

 

  - 디비 설정에서 리눅스 혹은 다른 OS 마다 설정이 다를 수 있습니다.

 

3. 파라미터 타입이 Object 인지 String인지 Integer HashMap 등 적절하게 작성되어있습니까?

  - 잘 맵핑되지 않아서 로그 출력상에는 정상적이지만 mybatis 딴에는 문제가 있을 수 있습니다.

 

4. 파라메타 변수가 ${}와 #{}를 적절히 사용하셨습니까?

 

5. 마이 바티스 설정 시 드라이버나 파라미터 값은 정상적이게 기입되어있습니까?

 

  - MySQL / MariaDB 등 호환은 되지만 가끔 의문의 오류가 있을 때가 있습니다.

  - UTF-8 등 세팅을 정상적으로 하지 않으면 오류가 있을 수 있습니다.

 

6. 칼럼 타입은 문제가 없습니까?

 

7. 서버와 로컬 MySQL 버전이 틀리지는 않습니까?

  - 버전별로 쿼리문에 변화가 약간 있어야 합니다.(ex : inet6 같은 함수가 지원되는지 안되는지 등)

반응형
반응형

MariaDB Select문으로 여러 카운터 데이터를 받을 게 있어서 한번 쓸건대,

DTO 만들기 뭐해서 "HashMap으로 받자~" 했는데

겁나 삽질한 적이 있었다. 다음 사람은 그러지 말라고 글을 재빠르게 올리겠습니다.

 

이 글은 Spring MVC , MyBatis , MySQL(MariaDB) 기준으로 설명하는 글입니다.

 

문법


클라이언트 (ajax)

function getUserCount() {
$.ajax({
url : "/jquery/getUserCount.do",
success : function(data) {
var html = '';
html += '<span>'+data['DB 조회된 컬럼명']+'</span>';
html += '<span>'+data['DB 조회된 컬럼명']+'</span>';
$("#jspTagView").empty();
$("#jspTagView").append(html);
}

//데이터는 data['DB 조회된 컬럼명']으로 뽑으면 됩니다.

 

Controller

@RequestMapping("jquery/getUserCount.do")
public @ResponseBody HashMap<String, Object> getUserCount() {	
HashMap<String, Object> result = service.getUserCount();
return result;
}

Service

HashMap<String, Object> getUserCount();

ServiceImpl

@Override
public HashMap<String, Object> getUserCount() {
return dao.getUserCount();
}

DAO

public HashMap<String, Object> getUserCount() {
return sqlSession.selectOne(NS+"getUserCount");
}
//여러 줄의 DB 데이터를 받을꺼면 sqlSession.selectList();

MyBatis

<select id="getUserCount" resultType="hashmap">
	Query 작성
</select>

Select 문 여러 개 Count 조회하기 DB 쿼리

 

 

[Mysql || MariaDB] Select 문 한번에 여러 개 Count()카운트 조회

사용 이유 Select 문으로 다양한 Count 개수를 뽑아 낼 때 문법 및 예시 select count(CASE WHEN column=조건 THEN 1 END) as 별명(생략가능), count(CASE WHEN column=조건 THEN 1 END) as 별명(생략가능) from..

java119.tistory.com

 

반응형
반응형

사용 이유


Select 문으로 다양한 Count 개수를 뽑아

 

 

 

문법 및 예시


select count(CASE WHEN column=조건 THEN 1 END) as 별명(생략가능),
count(CASE WHEN column=조건 THEN 1 END) as 별명(생략가능) from 테이블명;

 

먼저 예시로 사용할 테이블 및 데이터 하나 만들겠습니다.

create table expenditure(

id varchar(64),
timestamp timestamp,
money int,
primary key(id,timestamp)

);

insert into expenditure values('gildong','2019-10-19',100000);
insert into expenditure values('gildong','2019-10-20',70000);
insert into expenditure values('gildong','2019-10-21',3000);
insert into expenditure values('gildong','2019-10-22',7700);
insert into expenditure values('gildong','2019-10-23',50100);
insert into expenditure values('samsam','2019-10-19',50000);
insert into expenditure values('samsam','2019-10-20',60000);
insert into expenditure values('samsam','2019-10-21',90000);
insert into expenditure values('samsam','2019-10-22',1110000);
insert into expenditure values('samsam','2019-10-23',31000);
insert into expenditure values('YUMDDA','2019-10-19',11200000);
insert into expenditure values('YUMDDA','2019-10-20',122300000);
insert into expenditure values('YUMDDA','2019-10-21',10330000);
insert into expenditure values('YUMDDA','2019-10-22',3541100);
insert into expenditure values('YUMDDA','2019-10-23',10000000);

 

 

#기본 MySQL 카운트 함수

select count(*) from expenditure;

 

상황1. id gildong인 사람만 카운트 , id samsam인 사람만 카운트

SELECT COUNT(CASE WHEN id='gildong' THEN 1 END) AS gildongCnt,
COUNT(CASE WHEN id='samsam' THEN 1 END) AS samsamCnt
FROM expenditure;

 

#조건 여러개(다중) 카운트

상황2. id YUMDDA인 사람이 돈을 1천만이상 쓴 데이터만 카운트 , id samsam인 사람만 카운트

SELECT COUNT(CASE WHEN id='YUMDDA' THEN 1 END AND CASE WHEN money > 10000000 THEN 1 END) AS YUMDDACnt, 
COUNT(CASE WHEN id='samsam' THEN 1 END) AS samsamCnt
FROM expenditure;

상황3. 다른 테이블의 특정 컬럼 Count 개수 구하기

SELECT COUNT(CASE WHEN id='gildong' THEN 1 END) AS gildongCnt,
COUNT(CASE WHEN id='samsam' THEN 1 END) AS samsamCnt,
(SELECT COUNT(*)
FROM RelationTable) AS relationCnt
FROM expenditure;

 

예제 파일 제공


[MariaDB] Select 문 여러개 Count 구하기.sql
0.00MB

반응형

+ Recent posts