모바일 오유 바로가기
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
    조회수 : 400
    IP : 211.222.***.101
    댓글 : 3개
    등록시간 : 2015/09/04 15:09:00
    http://todayhumor.com/?programmer_13084 모바일
    아래에sql에서 if를 써서 쿼리를 선택이 가능할까요?에 대해 해결
    <div>해결했습니다. 우선 기능에 대해서 왜쓰는지 알려드리겠습니다. 너무 길어질꺼 같아서</div> <div>이렇게 글을 다시 쓰게 됬습니다.</div> <div><br></div> <div><br></div> <div>회원, 비회원이 물건을 샀을시 장바구니 테이블에 update 하는 과정이였습니다.</div> <div>예로 들면</div> <div><br></div> <div>회원이 물건을 산다 -> cart_D 테이블에 회원 + 장바구니 pk를 찾아서 삭제 update를 한다.</div> <div>비회원이 물건을 산다 -> be_cart_D 테이블에 비회원 + 장바구니 pk를 찾아서 삭제 update 한다.</div> <div>이과정을 해야 했습니다. pg사 연동후 결제가 완료후에 저 쿼리를 날려야 되는데 결제가 완료되면</div> <div>pg사에서는 주문번호만 날려줍니다. 그렇게 되면 주문번호 하나로 모든걸 해야 합니다.</div> <div>그래서 stored routine을 사용 했습니다. ( 쿼리를 한번 신호에 3~4개씩 동작 시키기 위해 )</div> <div>(call pay_success(); 하면 pay_success에 해당되는 쿼리를 다 발동 시킨다.)</div> <div><br></div> <div><br></div> <div>문제는 비회원, 회원 구분을 해야 했습니다. 그방법을 비회원일때는 회원 pk를 '000000' 회원일 때는 '00001~000xx'로설정 했습니다.</div> <div>이제 조건은 간단합니다.</div> <div><br></div> <div><br></div> <div>회원pk가 000000 일때</div> <div>update be_cart_D set where 회원pk=? and 장바구니pk =?;</div> <div>회원pk가 000000 아닐때</div> <div>update cart_D set where 회원pk=? and 장바구니pk =?;</div> <div>이걸 했어야 했습니다!! 그래서 if문을 물어본거였고요..... 저는 mariasql을 쓰기 때문에 도저히 방법을 떠오르지 않았습니다.</div> <div>그러다가 문뜩 생각한게 tabe명만 다르면 되니깐 tabe명을 변수로 한다면?</div> <div><br></div> <div>바로 검색후 실행했습니다. 아래와 같이하면 </div> <div>select if (@회원pk = '00000', 'be_cat_D', 'cart_D');</div> <div>@회원pk 가 00000(비회원)일때는 'be_cart_D'를 선택 아닐때는 'cart_D' 선택을 했습니다.</div> <div>그럼 다시</div> <div>set @table_name = (select if (@회원pk = '00000', 'be_cat_D', 'cart_D')); </div> <div>// @table_name에 be_cart_D 또는 cart_D가 들어간다.</div> <div>select * from @table_name; 을 했는데 실패... 아 왜 안될까 하다가 멍청하게</div> <div>@table_name은 문자형이기 때문에  ' ' 을 치게 되어 있습니다. 결국</div> <div><br></div> <div>select * from 'be_cart_D'    or   select * from 'cart_D' 였기 때문에 안된거였습니다...</div> <div>그럼또 검색.... sql 테이블 변수화 검색후 또 알아낸 방법</div> <div><a target="_blank" href="http://www.sqler.com/?mid=bSQLQA&category=128531&page=16&sort_index=readed_count&order_type=desc&document_srl=270956">http://www.sqler.com/?mid=bSQLQA&category=128531&page=16&sort_index=readed_count&order_type=desc&document_srl=270956</a></div> <div>declare @tablename varchar(50)</div> <div>declare @sqltext varchar(max)</div> <div> </div> <div>set @tablename='상품'</div> <div>set @sqltext='update '+@tablename + ' set 상품명= ''C'''</div> <div>exec (@sqltext)</div> <div><br></div> <div>쿼리자체를 문자형으로 쓴후 exec()로 문자된 쿼리를 실행이였습니다. 바로 헀지만 실패 이번에는 검색을</div> <div>mariasql exec 후</div> <div><a target="_blank" href="https://mariadb.com/kb/en/mariadb/prepare-statement/#example">https://mariadb.com/kb/en/mariadb/prepare-statement/#example</a></div> <div>PREPARE stmt FROM 'SELECT @x;';</div> <div><br></div> <div>SET @x = 1;</div> <div><br></div> <div>EXECUTE stmt;</div> <div>예제를 보고 어떤 형식인지 이해하고 다시 도전 </div> <div>set @table_name = 'cart_D'</div> <div>set @sql = 'select * from' + @<span style="font-size:9pt;line-height:1.5;">table_name;</span></div> <div><span style="font-size:9pt;line-height:1.5;">select </span><span style="font-size:9pt;line-height:1.5;">@sql; 하는데 자꾸 0만 출력;; 아 뭐지... char 랑 char끼리는 더하기 가 안되나?싶어서 혹시몰라</span></div> <div><span style="font-size:9pt;line-height:1.5;"><br></span></div> <div> <div>set @table_name = 'cart_D'</div> <div>set @sql = 'select * from' + cast(@<span style="font-size:9pt;line-height:1.5;">table_name as char);  // 이렇게 강제 type을 char로 바꾸고 출력했는데도 0이 출력...</span></div></div> <div><span style="font-size:9pt;line-height:1.5;"><br></span></div> <div>아 너무 힘들다 라고 생각하다가 CONCAT()을 알아냈습니다.</div> <div> <div>set @table_name = 'cart_D'</div> <div>set @sql = <span style="font-size:9pt;line-height:1.5;">CONCAT('select * from ', @table_name);</span></div> <div><span style="font-size:9pt;line-height:1.5;">select </span><span style="font-size:9pt;line-height:1.5;">@sql; 를 해보았는데 다행시</span></div></div> <div>'select * from cart_D' 란 텍스트를 가져 왔습니다. 이제 여기서 아까 검색한걸 붙여서</div> <div><br></div> <div> <div>set @table_name = 'cart_D'</div> <div>set @sql = <span style="font-size:9pt;line-height:1.5;">CONCAT('select * from ', @table_name);</span></div></div> <div> <div>PREPARE stmt FROM @sql</div> <div>EXECUTE stmt; 하는 순간 </div></div> <div>'select * from cart_D' 로 만든 텍스트가 select * from cart_D의 쿼리로 실행!! 아..됐다 싶어서....</div> <div>위에 이용한 if로 be_cart_D 나 cart_D를 선택후 <span style="font-size:9pt;line-height:1.5;">CONCAT(); 를 이용하여 쿼리를 완성 시켰습니다.</span></div> <div><span style="font-size:9pt;line-height:1.5;"><br></span></div> <div><span style="font-size:9pt;line-height:1.5;"><br></span></div> <div>어떤 쿼리를 어떻게 짯는지해 대해서는 회사 DB라서 자세히는 말할순 없지만ㅠㅠ.. 그래도 댓글에 조언으로 </div> <div>검색 키워드를 잘 따라왔고 영감을 얻어서 잘 해결했습니다 조언주신분들 감사합니다.</div>

    이 게시물을 추천한 분들의 목록입니다.
    [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]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈