모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 오유인페이지
    개인차단 상태
    문식이당님의
    개인페이지입니다
    가입 : 15-02-20
    방문 : 176회
    닉네임변경 이력
    회원차단
    회원차단해제
    게시물ID : programmer_13084
    작성자 : 문식이당
    추천 : 1
    조회수 : 401
    IP : 211.222.***.101
    댓글 : 3개
    등록시간 : 2015/09/04 15:09:00
    http://todayhumor.com/?programmer_13084 모바일
    아래에sql에서 if를 써서 쿼리를 선택이 가능할까요?에 대해 해결
    해결했습니다. 우선 기능에 대해서 왜쓰는지 알려드리겠습니다. 너무 길어질꺼 같아서
    이렇게 글을 다시 쓰게 됬습니다.


    회원, 비회원이 물건을 샀을시 장바구니 테이블에 update 하는 과정이였습니다.
    예로 들면

    회원이 물건을 산다 -> cart_D 테이블에 회원 + 장바구니 pk를 찾아서 삭제 update를 한다.
    비회원이 물건을 산다 -> be_cart_D 테이블에 비회원 + 장바구니 pk를 찾아서 삭제 update 한다.
    이과정을 해야 했습니다. pg사 연동후 결제가 완료후에 저 쿼리를 날려야 되는데 결제가 완료되면
    pg사에서는 주문번호만 날려줍니다. 그렇게 되면 주문번호 하나로 모든걸 해야 합니다.
    그래서 stored routine을 사용 했습니다. ( 쿼리를 한번 신호에 3~4개씩 동작 시키기 위해 )
    (call pay_success(); 하면 pay_success에 해당되는 쿼리를 다 발동 시킨다.)


    문제는 비회원, 회원 구분을 해야 했습니다. 그방법을 비회원일때는 회원 pk를 '000000' 회원일 때는 '00001~000xx'로설정 했습니다.
    이제 조건은 간단합니다.


    회원pk가 000000 일때
    update be_cart_D set where 회원pk=? and 장바구니pk =?;
    회원pk가 000000 아닐때
    update cart_D set where 회원pk=? and 장바구니pk =?;
    이걸 했어야 했습니다!! 그래서 if문을 물어본거였고요..... 저는 mariasql을 쓰기 때문에 도저히 방법을 떠오르지 않았습니다.
    그러다가 문뜩 생각한게 tabe명만 다르면 되니깐 tabe명을 변수로 한다면?

    바로 검색후 실행했습니다. 아래와 같이하면 
    select if (@회원pk = '00000', 'be_cat_D', 'cart_D');
    @회원pk 가 00000(비회원)일때는 'be_cart_D'를 선택 아닐때는 'cart_D' 선택을 했습니다.
    그럼 다시
    set @table_name = (select if (@회원pk = '00000', 'be_cat_D', 'cart_D')); 
    // @table_name에 be_cart_D 또는 cart_D가 들어간다.
    select * from @table_name; 을 했는데 실패... 아 왜 안될까 하다가 멍청하게
    @table_name은 문자형이기 때문에  ' ' 을 치게 되어 있습니다. 결국

    select * from 'be_cart_D'    or   select * from 'cart_D' 였기 때문에 안된거였습니다...
    그럼또 검색.... sql 테이블 변수화 검색후 또 알아낸 방법
    declare @tablename varchar(50)
    declare @sqltext varchar(max)
     
    set @tablename='상품'
    set @sqltext='update '+@tablename + ' set 상품명= ''C'''
    exec (@sqltext)

    쿼리자체를 문자형으로 쓴후 exec()로 문자된 쿼리를 실행이였습니다. 바로 헀지만 실패 이번에는 검색을
    mariasql exec 후
    PREPARE stmt FROM 'SELECT @x;';

    SET @x = 1;

    EXECUTE stmt;
    예제를 보고 어떤 형식인지 이해하고 다시 도전 
    set @table_name = 'cart_D'
    set @sql = 'select * from' + @table_name;
    select @sql; 하는데 자꾸 0만 출력;; 아 뭐지... char 랑 char끼리는 더하기 가 안되나?싶어서 혹시몰라

    set @table_name = 'cart_D'
    set @sql = 'select * from' + cast(@table_name as char);  // 이렇게 강제 type을 char로 바꾸고 출력했는데도 0이 출력...

    아 너무 힘들다 라고 생각하다가 CONCAT()을 알아냈습니다.
    set @table_name = 'cart_D'
    set @sql = CONCAT('select * from ', @table_name);
    select @sql; 를 해보았는데 다행시
    'select * from cart_D' 란 텍스트를 가져 왔습니다. 이제 여기서 아까 검색한걸 붙여서

    set @table_name = 'cart_D'
    set @sql = CONCAT('select * from ', @table_name);
    PREPARE stmt FROM @sql
    EXECUTE stmt; 하는 순간 
    'select * from cart_D' 로 만든 텍스트가 select * from cart_D의 쿼리로 실행!! 아..됐다 싶어서....
    위에 이용한 if로 be_cart_D 나 cart_D를 선택후 CONCAT(); 를 이용하여 쿼리를 완성 시켰습니다.


    어떤 쿼리를 어떻게 짯는지해 대해서는 회사 DB라서 자세히는 말할순 없지만ㅠㅠ.. 그래도 댓글에 조언으로 
    검색 키워드를 잘 따라왔고 영감을 얻어서 잘 해결했습니다 조언주신분들 감사합니다.

    이 게시물을 추천한 분들의 목록입니다.
    [1] 2015/09/04 18:50:26  175.223.***.82  배터지리안  411580
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    64
    버튼 누를시 자동 복사 기능이 원래 이렇게 어려웠나요? [21] 본인삭제금지 문식이당 15/10/01 16:48 63 0
    63
    유투브 api를 쓰고 있는데 이럴땐 어떻게 해야 하나요? [7] 본인삭제금지 문식이당 15/10/01 12:28 40 0
    62
    스크립트로 동영상의 재생을 조정 할수 있을까요? [2] 베스트금지 문식이당 15/09/25 13:37 41 0
    61
    angular js에서 SPA에 방식으로 했을시 문제점이 있습니다. [6] 문식이당 15/09/21 12:01 37 0
    60
    일산 킨택스 IT 전시회 가신분 계신가요? 저는 갔다 왔습니다. 문식이당 15/09/18 14:59 54 2
    59
    angular에서 ng-repeat 가 동작될때 함수를 불르고 싶습니다 [7] 본인삭제금지 문식이당 15/09/18 14:47 28 0
    58
    angular js에서 filter에 다른 방법을 알고 싶습니다. [3] 본인삭제금지 문식이당 15/09/17 19:35 20 0
    57
    sql 질문 드립니다. 2개의 데이터 혼합입니다. [12] 본인삭제금지 문식이당 15/09/15 14:12 41 0
    56
    node js에서 썸네일 추출에 대해서 조언을 듣고 싶습니다 [2] 본인삭제금지 문식이당 15/09/14 15:35 25 0
    55
    실무에서 C에 포인터를 진짜 쓰나요?? [26] 문식이당 15/09/11 14:33 103 0
    54
    인천에 angular js 소모임을 만들고 싶습니다. [6] 문식이당 15/09/11 14:23 39 0
    53
    angular에서 컨트롤러는 index.html에 다 불러와야 하는건가요 [9] 본인삭제금지 문식이당 15/09/10 16:47 34 0
    아래에sql에서 if를 써서 쿼리를 선택이 가능할까요?에 대해 해결 [3] 문식이당 15/09/04 15:09 27 1
    51
    sql에서 if를 써서 쿼리를 선택이 가능할까요? [13] 본인삭제금지 문식이당 15/09/04 11:31 59 0
    50
    저는 멍청한거 같습니다. 이런 동작이 될줄은 몰랐습니다.(웹) [10] 문식이당 15/08/31 14:57 122 0
    49
    form ,$.post ,ajax에 관한 질문드립니다. 너무 답답합니다ㅠ [14] 본인삭제금지 문식이당 15/08/29 20:43 29 0
    48
    혹시 여기에 현상금? 같은글 올려도 되는건가요? [2] 문식이당 15/08/24 10:47 63 0
    47
    angular로 프로젝트를 할려고 하는데 초기 설정이 어렵습니다 ㅠ [7] 본인삭제금지 문식이당 15/08/21 18:30 30 0
    46
    왜 오류가 나느냐에 대한 가능성을 알고 싶습니다 (web) [6] 본인삭제금지 문식이당 15/08/21 11:27 62 0
    45
    안녕하세요 sql 질문이 풀려서 글을 올립니다. [2] 본인삭제금지 문식이당 15/08/07 08:57 34 1
    44
    order by 문제 질문 수정입니다. 죄송합니다. [17] 본인삭제금지 문식이당 15/08/06 16:13 55 0
    43
    sql에서 order by 에 문제가 있는건가요? [8] 본인삭제금지 문식이당 15/08/06 15:33 61 0
    42
    for문안에 for문을 돌릴려고 합니다 효율적인 방법이 있을까요? [21] 본인삭제금지 문식이당 15/08/05 13:50 90 0
    41
    sql에 막혔습니다. 조금 어려운 sql 일꺼 같습니다... [9] 본인삭제금지 문식이당 15/07/30 15:13 59 0
    40
    node 사용자 입니다.js ->server로 객체로 어떻게 보내나요? [8] 본인삭제금지 문식이당 15/07/22 15:02 29 0
    39
    server로 보낸 데이터를 어떻게 나눠야 할지 모르겠습니다. [6] 본인삭제금지 문식이당 15/07/22 14:03 48 0
    38
    님들 왜 라이즈가 사기인지 알아요? [6] 문식이당 15/07/20 09:26 349 3
    37
    sql문에서 해결 방법이 생각나질 않습니다 for문을 해야 할까요? [47] 본인삭제금지 문식이당 15/07/15 17:42 63 0
    36
    node , socket.io를 개발중인데 이게 잘한것인지 모르겠습니다. [4] 본인삭제금지 문식이당 15/07/13 20:27 25 0
    35
    으...살려주세요 socket.io 관련입니다ㅠㅠ..시작도 못하고있습니다 [2] 본인삭제금지 문식이당 15/07/09 19:43 23 0
    [1] [2] [3] [4] [5]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈