SQL Server에서 최솟값과 최댓값을 구하기 위해선는 MIN, MAX 함수를 사용하면 됩니다. MIN, MAX 함수는 집계 함수이며 GROUP BY 절과 함께 많이 사용됩니다. OVER 절과 함께 사용하면 분석 함수의 역할을 하며, 조금 더 다양한 쿼리문을 작성할 수 있습니다. 아래의 예제를 참고하여 첨부된 파일을 다운로드하여서 직접 연습해 보세요. 목차 전체 데이터 최솟값, 최댓값 구하기 그룹별 최솟값, 최댓값 구하기 (GROUP BY 절) 분석함수를 사용하여 최솟값, 최댓값 구하기 (OVER 절) 전체 데이터 최솟값, 최댓값 구하기 최솟값 구하기 (MIN) SELECT MIN(sal) FROM emp WHERE job = 'SALESMAN' 직업(job)이 "SALESMAN"인 직원의 최저급여(s..
SQL Server에서 EXISTS 연산자는 서브쿼리에 데이터가 존재하는지 체크하고 존재할 경우 TRUE를 반환하며, 대표적으로 EXISTS 구문과 NOT EXISTS 구문이 있다. EXISTS 연산자는 IN 연산자와 비슷한 용도로 사용할 수 있으며, IN 연산자는 비교할 값을 직접 대입할 수 있지만 EXISTS 연산자는 서브쿼리만 사용할 수 있다. 서브쿼리를 사용할 경우 상황에 따라서 IN 연산자 보다 EXISTS 연산자의 성능이 좋을 수 있다. 목차 기본적인 EXISTS, NOT EXISTS 사용법 CASE 표현식에서 EXISTS 사용법 IN 연산자와 비교 및 EXISTS 연산자의 성능 기본적인 EXISTS, NOT EXISTS 사용법 EXISTS SELECT * FROM dept a WHERE a...
SQL Server에서 GROUP BY 절은 특정 칼럼을 기준으로 집계 함수를 사용하여 건수(COUNT), 합계(SUM), 평균(AVG) 등 집 계성 데이터를 추출할 때 사용한다. GROUP BY 절에서 기준 칼럼을 여러 개 지정할 수 있으며, HAVING 절을 함께 사용하면 집계 함수를 사용하여 WHERE 절의 조건절처럼 조건을 부여할 수 있다. GROUP BY 절은 중복제거를 할 때도 사용 가능하다. SQL Server에서는 GROUP BY 절을 사용할 경우 그룹 칼럼을 기준으로 자동으로 ORDER BY가 되지만 명시적으로 ORDER BY를 사용하여 쿼리문을 작성하는 것이 좋다. 목차 기본적인 GROUP BY 절 사용법 GROUP BY 절에서 조건절(HAVING) 사용법 GROUP BY 절에서 자주 ..
SQL Server에서 SELECT 된 데이터를 정렬하기 위해서는 ORDER BY 절을 사용하면 된다. 정렬할 칼럼을 오름차순(ASC), 내림차순(DESC)으로 조회 순서를 지정할 수 있다. MySQL에서 LIMIT를 사용하듯 SQL Server에서는 TOP을 사용하여 정렬된 데이터에서 특정 개수만큼만 조회할 수 있으며, CASE WHEN 연산자나 함수 등을 사용하여 조금 더 다양한 정렬 순서를 지정할 수 있다. ORDER BY 칼럼은 2개 이상 지정하여 복합 정렬이 가능하다. ORDER BY의 기본 정렬은 오름차순이며 칼럼명만 명시하면 오름차순으로 정렬되고, 칼럼명 뒤에 DESC를 붙이면 내림차순으로 정렬된다. 칼럼명 뒤에 ASC를 붙여도 오름차순으로 정렬되지만 대부분 오름차순은 ASC를 붙이지 않는다..
SQL Server에서 테이블의 데이터를 삭제하기 위해서는 DELETE 문을 사용하면 된다. SQL Server에서는 DELETE 문에서 조인을 하여 데이터를 삭제할 수 있으며, 서브쿼리를 사용하여 삭제할 데이터 범위를 조회하여 데이터를 삭제할 수도 있다. MERGE 문을 사용하면 INSERT, UPDATE, DELETE를 동시에 수행할 수 있다. 목차 기본적인 DELETE 방법 다른 테이블과 조인하여 DELETE 방법 서브쿼리를 사용하여 DELETE 방법 기본적인 DELETE 방법 DELETE FROM dbo.dept WHERE deptno = 40 부서(dept) 테이블에서 부서코드(deptno) "40"에 해당하는 행을 삭제하는 예제이다. DELETE dbo.dept WHERE deptno = 40..
SQL Server에서 테이블이 데이터를 수정하기 위해서는 UPDATE 문을 사용하면 된다. SQL Server에서는 UPDATE 문에서 FROM 절을 사용할 수 있어서 다른 테이블과 조인을 하여 업데이트를 할 수 있다. 조인을 사용하지 않을 경우 서브쿼리를 사용하여 여러 개의 데이터를 업데이트하면 된다. SELECT 해서 UPDATE 하는 방법은 조인 또는 서브쿼리를 사용하면 된다. 목차 기본적인 UPDATE 방법 다른 테이블과 조인하여 UPDATE 방법 서브쿼리를 사용하여 UPDATE 방법 기본적인 UPDATE 방법 UPDATE dbo.dept SET dname = 'SALES TEAM' , loc = 'TEXAS' WHERE deptno = 30 부서명(dname)과 지역명(loc)을 업데이트하는 ..
SQL Server에서 데이터를 입력하기 위해서는 INSERT 문을 사용한다. SQL Server 2008부터 여러 행을 입력할 수 있는 기능이 추가되었으며, SELECT 해서 INSERT 하는 방법으로도 여러 건의 데이터를 입력할 수 있다. INSERT와 UPDATE를 동시에 수행하기 위해서는 MERGE 문을 사용하거나 프로시저를 생성하여 사용하면 된다. 목차 기본적인 INSERT 방법 동시에 여러 행 INSERT 방법 SELECT 결과 INSERT 방법 기본적인 INSERT 방법 INSERT INTO dbo.dept (deptno, dname, loc) VALUES (50, 'IT TEAM', 'SEOUL') INSERT INTO [테이블명] ([칼럼1], [칼럼2], [칼럼3] ...) VALUES..
SQL Server에서 칼럼의 NOT NULL 제약조건을 추가하여 NULL을 입력하지 못하게 하거나, NULL을 허용하도록 하기 위해서는 ALTER TABLE~ALTER COLUMN~ 구문을 사용하면 된다. 신규 칼럼을 추가할 때 NOT NULL 제약조건을 부여하여 추가할 수 있지만, 이미 존재하는 칼럼의 속성을 바꿀 때는 아래를 참고하면 된다. 목차 칼럼 NOT NULL 제약 조건 추가, 제거 칼럼 NOT NULL 추가 시 주의사항 칼럼 NOT NULL 제약 조건 추가, 제거 NOT NULL 추가 ALTER TABLE dbo.emp ALTER COLUMN ret_yn VARCHAR(1) NOT NULL ALTER TABLE [테이블명] ALTER COLUMN [칼럼명] [데이터타입] NOT NULL 테..
SQL Server에서 테이블의 칼럼 위치를 변경하기 위해서는 SSMS 관리 툴을 사용해야 한다. 오라클이나 MySQL처럼 쿼리문으로 칼럼의 위치를 변경할 수 없다. 칼럼의 위치를 변경하기 전에 디자이너 옵션을 변경 후 작업을 수행하는 것이 좋다. (도구 메뉴 → 옵션 → 디자이너 → 테이블을 다시 만들어야 하는 변경 내용 저장 안 함 해제) 목차 테이블 칼럼 위치 변경 방법 디자이너 설정 변경 방법 (오류 해결) 테이블 칼럼 위치 변경 방법 1. 변경할 테이블에서 마우스 오른쪽 메뉴 "디자인" 클릭 2. 위치를 변경할 칼럼을 클릭해서 드래그하여 이동시킨다 3. 상단 디스켓 모양의 "저장 버튼"을 눌러서 저장한다 디자이너 옵션을 변경하지 않았다면, 아래의 오류 메시지가 발생할 수 있다. 변경 내용을..
SQL Server에서 테이블 인덱스 정보를 조회해야 할 경우가 있다. sp_helpindex 시스템 저장 프로시저와 sys.indexes 시스템 테이블을 활용하면 인덱스 정보를 쉽게 조회할 수 있다. 아래의 2가지 방법을 사용하면 인덱스명과 인덱스 칼럼을 확인할 수 있으니 참고하면 된다. 목차 시스템 저장 프로시저로 인덱스 조회 (sp_helpindex) 시스템 테이블로 인덱스 조회 (sys.indexes) 시스템 저장 프로시저로 인덱스 조회 (sp_helpindex) EXEC sp_helpindex 'emp' EXEC sp_helpindex [테이블명] 시스템 저장 프로시저를 사용하면 인덱스명과 인덱스 칼럼을 빠르고 간편하게 조회할 수 있다. 시스템 테이블로 인덱스 조회 (sys.indexes) SE..