SQL Server / Query / SELECT / 데이터 조회

예제로 사용한 데이터베이스는 AdventureWorks이다.

SELECT로 원하는 데이터를 조회한다.

SELECT FROM

기본

SELECT 뒤에는 조회할 열 이름을, FROM 뒤에는 조회할 테이블 이름을 입력한다. 모든 열을 조회한다면 *를 사용한다.

  • HumanResources.Employee 테이블의 모든 열을 조회한다.
select 
  *
from HumanResources.Employee
;

  • HumanResources.Employee 테이블에서 BusinessEntityID, JobTitle, BirthDate, HireDate를 조회한다.
select 
  BusinessEntityID,
  JobTitle,
  BirthDate,
  HireDate
from HumanResources.Employee
;

TOP

TOP으로 조회 개수를 정한다.

  • 상위 10개를 조회한다.
select top( 10 )
  *
from HumanResources.Employee
;
  • 상위 10%를 조회한다.
select top( 10 ) percent
  *
from HumanResources.Employee
;

DISTINCT

DISTINCT로 중복된 것은 하나만 조회할 수 있다.

  • 중복된 것을 제외하고 JobTitle을 조회한다.
select distinct
  JobTitle
from HumanResources.Employee
;

JOIN

WHERE

WHERE 절을 이용하여 특정 조건에 부합하는 데이터만 조회할 수 있다.

  • JobTitle이 Design Engineer인 데이터만 조회한다.
select 
  BusinessEntityID,
  JobTitle,
  BirthDate,
  HireDate
from HumanResources.Employee
where JobTitle = 'Design Engineer'
;

GROUP BY

GROUP BY 절을 이용하여 데이터를 그룹화할 수 있다. COUNT(), SUM() 등 집계함수와 함께 사용한다.

  • JobTitle로 그룹화하고 BusinessEntityID의 수를 조회한다. 즉 JobTitle별 사람 수를 의미한다.
select 
  JobTitle,
  count( BusinessEntityID ) as Count
from HumanResources.Employee
group by JobTitle
;

HAVING

집계 함수에 대해 조건은 HAVING으로 만든다.

  • 사람 수가 2보다 큰 JobTitle을 조회한다.
select 
  JobTitle,
  count( BusinessEntityID ) as Count
from HumanResources.Employee
group by JobTitle
having count( BusinessEntityID ) > 2
;

ROLLUP

ORDER BY

ORDER BY 절을 이용하여 오름차순 또는 내림차순으로 정렬할 수 있다. 오름차순일 때는 ASC를, 내림차순일 때는 DESC를 붙인다. 기본값은 ASC이므로 생략 가능하다.

  • JobTitle 오름차순으로 정렬한다.
select 
  *
from HumanResources.Employee
order by JobTitle
;
  • JobTitle 오름차순, HireDate 내림차순으로 정렬한다.
select 
  *
from HumanResources.Employee
order by
  JobTitle,
  HireDate desc
;

ntext, text, image, geography, geometry, xml 등의 데이터 형식에 대해서는 order by를 사용할 수 없다.

OFFSET, FETCH

OFFSET은 지정한 행의 수만큼 생략하고 출력하게 한다. ORDER BY와 함께 사용한다.

  • BusinessEntityID 오름차순으로 출력하되, 상위 4개의 행을 생략한다.
select
  *
from HumanResources.Employee
order by BusinessEntityID
offset 4 rows
;

FETCH로 출력할 행의 수를 제한할 수 있다.

  • BusinessEntityID 오름차순으로 출력하되, 상위 4개의 행을 생략하고, 10개를 출력한다.
select
  *
from HumanResources.Employee
order by BusinessEntityID
offset 4 rows
fetch next 10 rows only
;

 

같은 카테고리의 다른 글
SQL Server / 포트 변경하는 방법

SQL Server / 포트 변경하는 방법

SQL Server의 기본 포트는 1433이다. 보안을 비롯하여 여러 가지 이유로 포트를 변경해야 할 경우가 있다. SQL Server의 포트를 1433에서 다른 것으로 변경하는 방법은 다음과 같다. 를 연다. 에서 인스턴스를 선택한다. 을 클릭한다. 의 TCP 포트를 원하는 것으로 변경한다. 또는 ...

SQL Server / Query / 메모

최근 날짜 가져오기 Name으로 그룹화한 후 최근 날짜를 가져온다. SELECT Name, MAX( Date ) FROM Table1 GROUP BY Name 최근 날짜가 2020년인 것만 가져온다. SELECT Name, MAX( Date ) FROM Table1 GROUP BY Name HAVING MAX( Date ) BETWEEN '2020-01-01' AND '2020-12-31' 모든 데이터베이스 출력하기 EXECUTE sp_helpdb;

SQL Server / Query / GO

예를 들어 DB라는 데이터베이스를 만들고, ID라는 열을 갖는 TB라는 테이블을 만든다고 하자. 쿼리로 만드는 경우 다음과 같이 할 수 있는데... CREATE DATABASE DB; USE DB; CREATE TABLE TB ( ID int ); 다음과 같은 에러가 난다. 데이터베이스 'DB'이(가) 없습니다. 이름을 제대로 입력했는지 확인하십시오. 이런 경우 GO를 사용한다. GO를 기준으로 해서 GO 위의 쿼리 실행을 마친 후 ...

SQL Server / 버전 확인하는 두 가지 방법

SQL Server / 버전 확인하는 두 가지 방법

SQL Server 버전 확인하는 방법 1 SQL Server Configuration Manager를 연다. 왼쪽에서 를 선택한다. 오른쪽에서 을 클릭한다. 탭에서 버전을 확인할 수 있다. SQL Server 버전 확인하는 방법 2 SSMS에서 다음 쿼리를 실행한다. select @@version;

SQL Server / 논리 연산자 / IN, NOT IN

SQL Server / 논리 연산자 / IN, NOT IN

예제로 사용한 데이터베이스는 AdventureWorks이다. IN 다음은 Person.Person 테이블에서 FirstName, MiddleName, LastName을 10개 추출하는 쿼리이다. SELECT TOP(10) FirstName, MiddleName, LastName FROM Person.Person 만약 FirstName이 Syed 또는 Sam 또는 John인 사람을 추출하고 싶다면 아래처럼 쿼리한다. SELECT TOP(10) FirstName, MiddleName, LastName FROM Person.Person WHERE FirstName IN ( 'Syed', 'Sam', 'John' ) 물론 아래와 같이 해도 된다. SELECT TOP(10) FirstName, MiddleName, LastName FROM Person.Person WHERE FirstName ...

SQL Server / 데이터베이스 저장 위치 변경하는 방법

SQL Server / 데이터베이스 저장 위치 변경하는 방법

데이터베이스 기본 저장 위치 변경 데이터베이스를 만들거나 복원할 때 기본적으로 저장되는 위치는 SQL Server를 설치할 때 정합니다. 그 위치를 변경하고 싶다면 다음과 같이 합니다. 서버를 선택하고 마우스 우클릭 후 을 클릭합니다. 왼쪽 메뉴에서 을 클릭합니다. 를 원하는 위치로 변경하고... 을 클릭합니다. 서버를 재부팅하거나, 서비스에서 SQL Server를 다시 시작해야 반영됩니다. 데이터베이스 만들 때 저장 위치 ...

SQL Server / 보안 / 사용자 계정 만들고 권한 추가하는 방법

SQL Server / 보안 / 사용자 계정 만들고 권한 추가하는 방법

SQL Server의 사용자 계정은 Windows 인증을 이용한 사용자 계정, SQL Server 자체의 사용자 계정이 있습니다. 그 중 SQL Server 자체의 사용자 계정을 만들고, 권한을 부여하는 방법을 알아보겠습니다. SSMS로 SQL Server에 접속합니다. 을 선택합니다.(확장하면 전체 사용자 목록을 볼 수 있습니다.) 마우스 우클릭하고 을 클릭합니다. 사용자를 추가하는 창이 뜹니다. 을 선택하고... 로그인 ...

SQL Server / SSMS / IntelliSense / 자동 완성 기능 사용하는 방법, 설정하는 방법

SQL Server / SSMS / IntelliSense / 자동 완성 기능 사용하는 방법, 설정하는 방법

텍스트 에디터의 경우 코드의 일부분을 입력했을 때 그 문자열을 포함한 코드 리스트를 보여주는 기능이 있다. 이러한 자동 완성 기능을 SSMS에서도 제공하고 있고, IntelliSense라고 한다. 원하는 것을 쉽게 찾고, 오타를 줄일 수 있는 유용한 기능이다. 예를 들어 from 뒤에 문자열을 입력하면 그와 관련된 것이 나오고, 상하 화살표를 이용해 선택한다. 선택한 것을 사용할 ...

SQL Server / Query / SELECT / 데이터 조회

SQL Server / Query / SELECT / 데이터 조회

예제로 사용한 데이터베이스는 AdventureWorks이다. SELECT로 원하는 데이터를 조회한다. SELECT FROM 기본 SELECT 뒤에는 조회할 열 이름을, FROM 뒤에는 조회할 테이블 이름을 입력한다. 모든 열을 조회한다면 *를 사용한다. HumanResources.Employee 테이블의 모든 열을 조회한다. select * from HumanResources.Employee ; HumanResources.Employee 테이블에서 BusinessEntityID, JobTitle, BirthDate, HireDate를 조회한다. select BusinessEntityID, JobTitle, BirthDate, HireDate from HumanResources.Employee ; TOP TOP으로 조회 개수를 정한다. 상위 10개를 ...

SQL Server / 스키마 / 만들기, 조회하기, 수정하기, 삭제하기

스키마(Schema)를 이용하여 테이블을 분류하고 권한 관리를 할 수 있다. 스키마 만들기 a라는 이름의 스키마를 만든다. create schema a; 스키마 조회하기 스키마 정보를 출력한다. select * from sys.schemas; 테이블 만들기 스키마 지정 없이 테이블을 만들면 dbo 스키마가 붙는다. create table client ( id int ); 스키마를 지정하고 만들면, 그 스키마에 테이블이 만들어진다. create table a.client ( id int ); dbo.client와 a.client는 테이블 이름은 ...