본문 바로가기

Database

(105)
728x90
반응형

MS SQL。임시 테이블(WITH) CTE(Common Table Expression), 임시로 이름을 지정하여 테이블 생성 WITH [임시테이블명] AS ( [생성 쿼리] ) SELECT * FROM [임시테이블명] 조인으로 임시 테이블 생성 후 조회 동일한 조인 쿼리로 UNION ALL한 임시 테이블 생성 후 조회
MS SQL。변수 선언(DECLARE) # 변수 선언 DECLARE @[변수명] [데이터 타입] # 변수에 값 대입 1. 일반 값 대입 SET @[변수] = [값] 2. 조회된 값 대입(단일 레코드만 대입 가능) SELECT TOP 1 @[변수] = [필드] FROM [테이블명] # 변수 조회 SELECT @[변수명] # 테이블 형식으로 선언 DECLARE @[변수명] AS TABLE ( [필드1] [데이터 타입] ... [필드n] [데이터 타입] )
MS SQL。조인(JOIN) 여러개의 테이블을 연결하여 하나의 테이블로 사용 1. INNER JOIN 교집합(A ∩ B)과 동일, 서로 일치하는 데이터 출력 SELECT * FROM [테이블명] A INNER JOIN [테이블명] B ON A.[필드] = B.[필드] 2. LEFT JOIN(= LEFT OUTER JOIN) 차집합(A - B)과 동일, 기준 테이블에 JOIN된 테이블과 조건이 맞는 기준 테이블의 데이터 출력 SELECT * FROM [테이블명] A LEFT [OUTER] JOIN [테이블명] B ON A.[필드] = B.[필드] -- C를 제외한 데이터 출력 SELECT * FROM [테이블명] A LEFT [OUTER] JOIN [테이블명] B ON A.[필드] = B.[필드] WHERE B.[필드] IS NULL..
MS SQL。집합 연산자(EXCEPT) 차집합(A - B), 테이블 A에서 테이블 B와 일치하는 데이터를 제외한 테이블 A의 데이터 출력 SELECT [필드1], [필드2], ..., [필드n] FROM [테이블명1] EXCEPT SELECT [필드1], [필드2], ..., [필드n] FROM [테이블명2] [Database/Theory] - Database。관계대수(Relational Algebra) - 집합 연산 [Database/MS SQL] - MS SQL。집합 연산자(UNION, UNION ALL) [Database/MS SQL] - MS SQL。집합 연산자(INTERSECT)
MS SQL。집합 연산자(INTERSECT) 교집합(A ∩ B), 두 테이블에서 서로 일치하는 데이터 출력 SELECT [필드1], [필드2], ..., [필드n] FROM [테이블명1] INTERSECT SELECT [필드1], [필드2], ..., [필드n] FROM [테이블명2] [Database/Theory] - Database。관계대수(Relational Algebra) - 집합 연산 [Database/MS SQL] - MS SQL。집합 연산자(UNION, UNION ALL) [Database/MS SQL] - MS SQL。집합 연산자(EXCEPT)
MS SQL。집합 연산자(UNION, UNION ALL) 합집합(A ∪ B), 두 테이블의 전체 데이터를 출력하며 모든 필드의 개수와 데이터 타입은 일치해야 함 # 중복 제거(UNION) SELECT [필드1], [필드2], ..., [필드n] FROM [테이블명1] UNION SELECT [필드1], [필드2], ..., [필드n] FROM [테이블명2] # 중복 허용(UNION ALL) SELECT [필드1], [필드2], ..., [필드n] FROM [테이블명1] UNION ALL SELECT [필드1], [필드2], ..., [필드n] FROM [테이블명2] [Database/Theory] - Database。관계대수(Relational Algebra) - 집합 연산 [Database/MS SQL] - MS SQL。집합 연산자(INTERSECT) [Da..
Database。삽입 SQL(Embedded SQL) - 다이나믹 SQL(Dynamic SQL) 특별히 일반 대화식 온라인 응용을 실행 시간(Runtime)에 구성할 수 있는 삽입 SQL 1) 터미널로부터 명령문 접수 2) 입력된 멸령문의 분석 3) 데이터베이스에 대한 적절한 SQL 명령문 지시 4) 터미널로 메세지나 결과 회송 실행 시간에 동적으로 작성하여 곧바로 실행 시키는 것 -- 호스트 변수 VARCHAR [dynamicSQL 변수명]; -- 문자 스트링 변수 [dynamicSQL 변수명] = "DELETE FROM [테이블명] WHERE [조건]"; EXEC SQL PREPARE objSQL FROM :[dynamicSQL 변수명]; EXEC SQL EXECUTE objSQL; objSQL : 호스트 프로그램 변수가 아니라 별도의 선언 없이 사용된 SQL 변수(SQL Variable)로서 ..
Database。삽입 SQL(Embedded SQL) - 커서(Cursor) 호스트 언어들은 한 번에 하나의 레코드만 취급하는 데 커서(Cursor)는 레코드 집합을 처리하는 데 사용되는 일종의 포인터로 응용 프로그램의 삽입 SQL에만 사용되는 새로운 객체 집합에 있는 각 레코드들을 한 번에 하나씩 지시할 수 있게 해서 그 레코드 집합 전체를 처리 1. 커서가 필요 없는 데이터 조작 단일 레코드 검색 EXEC SQL SELECT Name, Phone INTO :sName, :sPhone FROM [테이블명] WHERE Name = :Name 1. SQLSTATE 변수 값 : 00000 2. WHERE절을 만족하는 레코드가 없는 경우 SQLSTATE 변수 값 : 02000 3. 레코드가 둘 이상인 경우 에러 SQLSTATE 변수 값 : 오류 코드 # 삽입 EXEC SQL INSER..
728x90
반응형