기본적인 SQL 문법을 다룬다. 예시만 적어두고 필요할 때 참고하기 위함


DML (Data Manipulation Language, 데이터 조작어)


SELECT

/*모든 데이터 조회*/
Select * from {table}

/*특정 데이터 조회 - 조건 설정*/
Select * from {table} where {column} {조건}

ex) Select * from Student where Name = 'JPK'

INSERT

/*테이블에 새로운 row 삽입*/
Insert Into {table} ({column1, column2, ...}) Values ({set value1, set value2, ...})

ex) Insert Into Student (Age, Name, Rank) Values (set 15, set 'ABC', set 4.5)

UPDATE

/*테이블에서 특정 값을 수정*/
Update {table} set {column} = '{new value}' where {column} = '{before value}'

ex) Update Student set Name = 'JPK2' where Name = 'JPK'

DELETE

/*특정 value 값을 가지고 있는 Column의 row를 삭제*/
Delete from {table} where {column} = '{value}'

ex)Delete from Student where Name = 'JPK'

DDL (Data Definition Language, 데이터 정의어


CREATE

/*테이블을 생성하는 쿼리*/
CREATE Table {table} ({column1} {type}, {column2} {type}, ...)

ex) CREATE Table Student (Age int, Name varchar(50), Rank Float)

ALTER

/*테이블을 수정하는 쿼리*/
ALTER Table {table} Add ({new column} {type} {type value})

ex) ALTER Table Student Add (Address varchar (100))

DROP

/*테이블 혹은 데이터베이스를 삭제하는 쿼리*/
DROP Table {table / Database}

/*테이블 삭제*/
ex) DROP Table Student

/*데이터베이스 삭제*/
ex) DROP Database School

TRUNCATE

/*데이터를 자르기 하는 쿼리*/
/*테이블을 남겨두지만 테이블 내 모든 row를 비워버린다.*/
/*한 번 자르면 복구가 불가능하다. 데이터 뿐만 아니라 공간과 인덱스까지 삭제하기 때문*/
/*로그를 남기지 않기 때문에 속도가 빠르다.*/
DROP Table {table / Database}

ex) Truncate Table Student

DCL (Data Control Language, 데이터 제어어)


GRANT

/*데이터베이스 객체에 대한 특정 권한을 사용자에게 부여한다.*/
GRANT {QUERY COMMANDS} ON {table} TO {user}

/*user10에게 select, insert, delete 권한을 준다.*/
ex) GRANT SELECT, INSERT, DELETE ON Student TO user10

/*데이터베이스 객체에 대한 특정 권한을 사용자에게 부여한다.*/
GRANT {QUERY COMMANDS} ON {table} TO {user}

/*user10에게 select, insert, delete 권한을 준다.*/ 
ex) GRANT SELECT, INSERT, DELETE ON Student TO user10

REVOKE

/*데이터베이스 객체에 대한 특정 권한을 사용자에게 취소한다.*/
REVOKE {QUERY COMMANDS} ON {table} TO {user}

/*user10에게 select, insert, delete 권한을 취소한다.*/
ex) REVOKE SELECT, INSERT, DELETE ON Student TO user10

TCL(Transaction Control Language , 트랜잭션 제어어)


COMMIT

/*트랜잭션(작업 단위)에 이상이 없을 때 commit하는 쿼리이다.*/
ex) 
/*트랜잭션 시작을 알린다.*/
BEGIN TRAN (or TRANSACTION)

/*필요한 쿼리문을 수행한다. 이 때 변경된 사항은 메모리에만 저장된다*/
UPDATE Student set Name = 'JPPPPK' where Name = 'JPK'

/*쿼리문에 문제가 없다면 COMMIT을 통해 DB 혹은 디스크에 저장한다.*/
COMMIT TRAN

ROLLBACK

/*트랜잭션 실행에 이상이 있을 때 데이터를 원복하는 쿼리이다.*/
/*트랜잭션이 이미 커밋되었다면(디스크에 등재되었다면) 실행할 수 없다.*/

ex) 
/*트랜잭션 시작을 알린다.*/
BEGIN TRAN (or TRANSACTION)

/*BookCount라는 int type을 가진 변수를 정의한다.*/
DECLARE @BookCount int

/*AddBook이라는 이름의 트랜잭션을 시작한다.*/
BEGIN TRANSACTION AddBook

/*Books 테이블에 아래와 같은 Values를 가진 row를 생성한다.*/
INSERT INTO Books VALUES (20, 'Book15', 'Author1', 3000)

/*Books 테이블에서 책 이름이 Book15라는 이름을 가진 데이터들을 집계한다.*/
SELECT @BookCount = COUNT(*) FROM Books WHERE name = 'Book15'

/*만약 동일한 이름의 책이 2권 이상 발견되었다면 AddBook 트랜잭션을 ROLLBACK하여, 디스크에 등재하지 않고 작업을 종료한다.*/
F @BookCount > 1 BEGIN ROLLBACK TRANSACTION AddBook PRINT 'A book with the same name already exists' END

/*그렇지 않다면 COMMIT하여 디스크에 등재시킨다.*/
ELSE BEGIN COMMIT TRANSACTION AddStudent PRINT 'New book added successfully' END 

SAVEPOINT

/*트랜잭션을 일시저장하여 필요한 지점으로 롤백할 수 있도록 하게 해준다.*/
/*SAVEPOINT 이름은 중복될 수 없으며 트랜잭션 작업 도중 문제가 생긴다면 작업이 돌아갈 지점을 설정하거나 전체 rollback, 작업이 성공한 지점까지의 commit 등 여러가지 작업이 가능하다.*/

ex)
/*AA의 급여는 7000원으로 업데이트한다.*/
UPDATE employees SET salary = 7000 WHERE last_name = 'AA';

/*BB의 급여는 12000원으로 업데이트한다.*/
UPDATE employees SET salary = 12000 WHERE last_name = 'BB';

/*이 시점에 SAVEPOINT AA를 저장한다.*/
SAVEPOINT AA;

/*이 시점에 SAVEPOINT BB를 저장한다.*/
SAVEPOINT BB;

/*급여의 총 금액을 구한다. 이 구문에는 없지만 어떤 조건에 의해 BB의 급여를 다시 설정해야하는 상황이 생겼다고 가정하자.*/
SELECT SUM (salary) FROM employees;

/*SAVEPOINT AA 시점으로 되돌아간다.*/
ROLLBACK TO SAVEPOINT AA;

/*BB의 급여를 11000원으로 업데이트한다.*/
UPDATE employees SET salary = 11000 WHERE lase_name = 'BB';

/*디스크에 등재한다.*/
COMMIT;

'Server > MSSQL' 카테고리의 다른 글

MSSQL Server / SSMS(SQL Server Management Studio) 설치하기  (0) 2024.08.25

프로그램 설치

MSSQL을 설치해보도록 하자
마이크로소프트 MSSQL 공식 홈페이지에 접속하면 MSSQL을 설치할 수 있다.

여기서 필자는 상업용이 아닌 공부용으로 사용할 목적이므로 개발자 버전 (SQL Server 2022 Developer)를 다운 받아 설치한다.
설치가 끝나면 SSMS를 같이 설치할 수 있도록 설치 버튼이 존재하며 쿼리를 작성해야하니 함께 설치해준다.

SSMS 연결

서버 설치 및 SSMS 설치가 완료되었다면 SSMS를 실행해 데이터 베이스를 생성할 차례이다.


만약 위 화면에서 [SSMS 연결 도중 신뢰되지 않은 기관에서 인증서 체인을 발급했습니다.] 와 같은 오류가 발생했다면

[추가 연결 매개 변수] 탭에서 "TrustServerCertificate=True" 값을 설정해준다.


로컬에서만 테스트할 목적으로 SSMS를 사용하기 때문에 위와 같은 설정으로 넘어가지만, 실 서비스에서는 설정을 잘 해줘야한다.

'Server > MSSQL' 카테고리의 다른 글

MSSQL 기초 문법  (0) 2024.08.25

Route53이란?

Route53은 가용성과 확장성이 뛰어난 DNS 웹 서비스이다.
세 가지 주요 기능이 있는데,

  1. 도메인 등록
  2. DNS 라우팅
  3. 리소스 상태 확인
    등의 기능을 지원한다.

도메인 등록

선행으로 도메인을 가지고 있어야 한다.
AWS Route53에서 도메인들 등록할 수 있는데, 연간 12~13달러를 지불해야 한다.
필자의 경우 가비아에서 할인하는 도메인을 하나 구매했다. (훨씬 저렴함 ㅎㅎ..)
이제 내가 만든 어플리케이션을 AWS Route53을 통해 보유한 도메인에 연동할 수 있다.

DNS 라우팅

사용자가 인터넷 주소창에 도메인을 입력하거나, 그 하위 도메인을 입력했을 때 이를 라우팅해주는 기능을 지원한다.

리소스의 상태 확인

인터넷을 통해 웹 서버 같은 리소스로 자동화된 요청을 보내어 접근 및 사용이 가능하고,
정상 작동 중인지 확인한다.
리소스를 사용할 수 없게 될 때 알림을 수신하고 비정상 리소스가 아닌 다른 곳으로 인터넷 트래픽을 라우팅할 수 있다.

+ Recent posts