IT/SQL
MySQL[4] - 쿼리결과 중복제거, 논리연산자, 결과정렬, 그외
올빼밋.
2022. 5. 24. 20:51
728x90
목차
1. 쿼리결과 중복제거
2. 논리연산자
3. 결과정렬
4. 결과값 일부 조회
5. 집합함수
6. 유용한 함수
1. 쿼리결과 중복제거
DISTINCT
- SELECT문의 결과값에서 특정 컬럼만 출력할 경우 중복된 값들이 나오는 경우에 이를 제거해서 표시하는 기능
- SELECT DISTINCT 컬럼명 FROM 테이블명 WHERE 조건절;
2. 논리연산자
논리연산자(AND, OR, NOT)
- SELECT문의 조건절에 논리 조건 적용해서 적용할 수 있는 연산자
- SELECT * FROM 테이블명 WHERE (NOT) 조건1 AND/OR (NOT) 조건2
select * from city where CountryCode=‘KOR’ and Population >= 10000;
select * from city where CountryCode=‘KOR’ or CountryCode=‘CHN’ or CountryCode=‘JPN’;
논리연산자(IN, BETWEEN)
- 영어 표현으로 IN은 OR, BETWEEN은 A and B
select * from city where CountryCode in (‘KOR’, ‘CHN’, ‘JPN’);
select * from city where COuntryCode = ‘KOR’ and (Population between 100000 and 500000);
3. 결과정렬
결과값 정렬(ORDER BY)
- SELECT문의 결과값을 특정한 컬럼을 기준으로 오름차순/내림차순으로 정렬해서 표시
- SELECT * FROM 테이블명 WHERE 조건절 ORDER BY 컬럼명 ASC/DESC
- 기본값은 오름차순 정렬임/여러 개의 컬럼을 나열하면 순서대로 정렬
select * from city where CountryCode=‘KOR’ order by Population desc;
select CountryCode, Population from city order by CountryCode, Population desc;
-> CountryCode는 ASC 정렬 : 선언하지 않는다면 기본적으로 오름차순 정렬
4. 결과값 일부 조회
LIMIT(ROWNUM, TOP)
- SQL 쿼리 결과 중 상위 몇개만 보여주는 쿼리
- 해당 기능은 SQL에 표준이 없다. DB에 따라 다르게 쓰인다.
- SELECT 컬럼명 FROM 테이블명 WHERE 조건절 LIMIT 숫자;
5. 집합 함수
집합함수(Aggregation Function)
- 테이블의 전체레코드를 대상으로 특정 컬럼을 적용해서 한 개의 값을 리턴하는 함수
- count() : 레코드의 개수를 리턴
- sum()/avg() : 컬럼값의 합/평균을 리턴
- min()/max() : 컬럼값의 최소/최대값을 리턴
- Select aggregation_function(컬럼명) from 테이블명 where 조건절;
6. 유용한 함수
- LENGTH() : 레코드의 문자열 컬럼의 글자수를 리턴
- MID() : 문자열의 중간부분을 리턴
- UPPER()/LOWER(): 문자열을 대문자/소문자로 리턴
- ROUND() : 레코드의 숫자 컬럼값을 반올림해서 리턴
select length(Name) from country;
select upper(mid(Name, 1, 3)) from country;
select round(LifeExpentancy, 0) from country;
728x90