FireBird Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
파이어버드 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
IBPhoenix
FireBird Main site
볼랜드포럼 광고 모집

FireBird Q&A
[2007] Re:순서대로 값변경하기
박지훈.임프 [cbuilder] 1554 읽음    2006-06-01 13:43
그런 형태의 순서는 어떤 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에 순서대로 넣은대로 값을 변경하고싶은데 어떻해야할까요?

+ -

관련 글 리스트
2000 순서대로 값변경하기 처음 1830 2006/05/29
2007     Re:순서대로 값변경하기 박지훈.임프 1554 2006/06/01
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.