그런 형태의 순서는 어떤 DB에서도 지원하지 않습니다.
where 절에서 나열한 조건들의 순서는 RDBMS 내부에서 최적화 과정에서 옵티마이저가 임의로 바꿔버리기 때문에
순서는 아무 의미가 없습니다.
따라서 [where id=2 or id=3 or id=1]이나 [where id=1 or id=2 or id=3] 이나 같은 뜻이 됩니다.
그런 순서를 주고 싶으시다면 지원하는 문법은 case문밖에 없는데...
제너레이터를 써서 업데이트하려고 하시는 걸 보면 레코드가 한두개가 아닐 거고, case의 중첩 단계수가 레코드만큼
많아질테니 불가능에 가깝겠죠.
그럼...
처음 님이 쓰신 글 :
: update 테이블 set id=gen_id(제네레이터) where id=2 or id=3 or id=1
:
: 이런식으로 sql문을 실행하고
: 순서대로
: id=2 -> id=0
: id=3 -> id=1
: id=1 -> id=2
:
: 이런식으로 값을 변경하고싶습니다.
:
: 그런데 위에처럼 실행하게 되면 자동으로 정렬해서
:
: id=1 -> id=0
: id=2 -> id=1
: id=3 -> id=2
:
: 와 같이 변경됩니다.
:
: where에 순서대로 넣은대로 값을 변경하고싶은데 어떻해야할까요?
|