일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 머신러닝기초
- git rebase
- 계정추상화
- ethers v6
- Vue.js
- 체인의정석
- chainlink 설명
- 러스트 기초
- multicall
- 오블완
- ethers type
- erc4337
- 스마트컨트렉트테스트
- ethers websocket
- Vue
- 스마트컨트렉트 예약어 함수이름 중복
- 스마트 컨트렉트 함수이름 중복
- 티스토리챌린지
- 스마트컨트렉트 함수이름 중복 호출
- rust 기초
- 러스트 기초 학습
- ambiguous function description
- vue기초
- ethers typescript
- erc4337 contract
- SBT표준
- ethers
- 컨트렉트 배포 자동화
- 러스트기초
- 컨트렉트 동일한 함수이름 호출
Archives
- Today
- Total
체인의정석
Mysql - null값이 섞인 같은 행하나로 합치기 본문
728x90
반응형
SQL 문에서 다음과 같이 tech_name을 2개의 테이블로 가져오는 경우에 IFNULL을 써서 NULL일 경우 2번째 값이 나오도록 만든다.
SELECT /* ?.brokerage */
br.brokerage_idx,
br.brokerage_req_start,
br.brokerage_req_end,
br.brokerage_status,
IFNULL(t.tech_name,d.tech_name) as tech_name
FROM brokerage br
LEFT OUTER JOIN tech_info t ON t.tech_idx = br.tech_idx
LEFT OUTER JOIN demand d ON d.demand_idx = br.demand_idx
where br.reg_id = "test";
CASE WHEN을 써서도 이를 구현할 수 있다.
만약 NULL이 아닌 다른 조건의 경우도 고려하려면 아래와 같이 case when절을 사용하여 하면 된다.
SELECT /* ?.brokerage */
br.brokerage_idx,
br.brokerage_req_start,
br.brokerage_req_end,
br.brokerage_status,
(CASE WHEN t.tech_name is null then d.tech_name
else t.tech_name END)tech_name
FROM brokerage br
LEFT OUTER JOIN tech_info t ON t.tech_idx = br.tech_idx
LEFT OUTER JOIN demand d ON d.demand_idx = br.demand_idx
where br.reg_id = "test";
다음처럼 tech_name이라는 한 행안에 결과 값이 로드 된다.
728x90
반응형
'개발 > database' 카테고리의 다른 글
Oracle DB 테이블 구조와 DBeaver 연결 (0) | 2021.08.20 |
---|---|
Database Error: DPI-1047: Cannot locate a 64-bit Oracle Client library 오류 해결기 , MAC / Node 환경 (0) | 2021.08.20 |
PostgreSQL와 DBeaver 연결하고 utf-8 체크 (0) | 2021.08.17 |
Mssql DBeaver연결 후 utf-8 적용 테스트 (0) | 2021.08.17 |
Mysql, Oracle DBeaver 연결 후 utf8 확인 (0) | 2021.08.17 |
Comments