[SQLD] 19. ORDER BY 절
제 8절 ORDER BY 절 1. ORDER BY 정렬 ORDER BY 절은 SQL 문장으로 조회된 데이터들을 다양한 목적에 맞게 특정 칼럼을 기준으로 정렬하여 출력하는데 사용한다. SELECT 칼럼명 [ALIAS명]FROM 테이블명[WHERE 조건식][GROUP BY 칼럼이나 표현식][HAVING 그룹조건식][ORDER BY 칼럼이나 표현식 [ASC 또는 DESC]]; - ORDER BY 절에 칼럼명 대신 SELECT 절에서 사용한 별명 사용 가능- 또한, 칼럼 순서를 나타내는 정수 사용 가능하나, 유지보수성이나 가독성이 떨어짐- ORDER BY 절에서 칼럼명, 별명, 칼럼순서(정수)를 같이 혼용하는 것도 가능- 기본적으로 오름차순 적용(ASC), 내림차순은 DESC- SQL 문장 맨 마지막 위치- 숫..
2016.08.18
no image
[SQLD] 18. GROUP BY, HAVING 절
제 7절 GROUP BY, HAVING 절 1. 집계 함수(Aggregate Function) 여러 행들의 그룹이 모여서 그룹당 단 하나의 결과를 돌려주는 다중행 함수 중 집계 함수(Aggregate Function)의 특성은 다음과 같다. - 여러 행들의 그룹이 모여서 그룹당 단 하나의 결과를 돌려주는 함수- GROUP BY 절은 행들을 소그룹화- SELECT절, HAVING절, ORDER BY절에 사용 가능- WHERE절에 사용하지 않음 - 일반적으로 집계함수는 GROUP BY 절과 같이 사용되지만, 테이블 전체가 하나의 그룹이 되는 경우에는 GROUP BY 절 없이 단독으로 사용 가능 집계함수명([DISTINCT | ALL] 칼럼이나 표현식) - COUNT(*) 는 NULL 값을 포함한 행의 수를 ..
2016.08.18
no image
[SQLD] 17. 함수 (Function)
제 6절 함수(FUNCTION) 1. 내장 함수(Built-in function) 개요 함수는 벤더에서 제공하는 함수인 내장함수와 사용자가 정의할 수 있는 함수(User Defined Function)로 나눌 수 있다. 본 절에서는 SQL 내장함수에 대해서 설명하기로 한다. 내장함수는 SQL을 더욱 강력하게 해주고 데이터 값을 간편하게 조작하는데 사용된다. 내장함수는 다시 함수의 입력 값이 단일행 값이 입력되는 단일행함수(Single-Row Function)와 여러 행의 값이 입력되는 다중행 함수(Multi-Row Function)로 나눌 수 있다. 다중행 함수는 다시 집계 함수(Aggregate Function), 그룹함수(Group Function), 윈도우 함수(Window Function)로 나눌..
2016.08.18
no image
[SQLD] 16. WHERE 절
제 5절 WHERE 절 1. WHERE 조건절 개요 자료를 검색할 때 SELECT 절과 FROM 절만을 사용하여 기본적인 SQL 문장을 구성한다면, 테이블에 있는 모든 자료들이 결과로 출력되어 실제로 원하는 자료를 확인하기 어려울 수 있다. 사용자들은 자신이 원하는 자료만을 검색하기 위해서 SQL 문장에 WHERE 절을 이용하여 자료들에 대한 제한을 할 수 있다. SELECT [DISTINCT/ALL] 칼럼명 [ALIAS명]FROM 테이블명WHERE 조건식; 이러한 형식으로 WHERE절을 이용한 조건적 SELECT문을 작성할 수 있다. 이와 같이 조건절은 FROM절 다음에 위치할 수 있으며, 조건식은 칼럼명, 비교연산자, 문자, 숫자, 표현식, 비교 칼럼명(JOIN 사용 시) 등이 나올 수 있다. 2. ..
2016.08.16
no image
OpenCV 직선 그리기, 사각형 그리기, 직선 클리핑
이제 지겨운 OpenCV 자료형 공부는 끝내고 그나마 재미있는(?) 직선그리기, 사각형그리기, 직선 클리핑을 해보겠다. 직선, 사각형을 그리고 직선 클리핑을 할 수 있는 함수에 대해서 소개하도록 하겠다. 직선 그리는 함수 line()void line(Mat& img, Point pt1, Point pt2, const Scalar& color, int thickness=1, int lineType=8, int shift=0);차례대로, 영상Mat, 좌표점1, 좌표점2, 색상, 두께, 타입(CV_AA 이면 안티에일리징 라인), 좌표 시프트연산을 한 결과를 나타낸다. 사각형 그리는 함수 rectanglevoid rectangle(Mat& img, Point pt1, Point pt2, const Scalar&..
2016.08.13
OpenCV 기본클래스 (3)
벌써 세번째 Mat 포스팅이다. 기본클래스의 마지막 포스팅이 될 것 같다. 책에 수록되어있는 Mat에 대한 함수들이 너무 많아서, 자주 쓸 것 같고, 자주 쓰이는 것만 다뤄보도록 하겠다 ㅠㅠ 3.3 Mat 행렬 정보 행렬에 대한 정보들은 영상처리 프로그래밍을 할 때 필수적이다. 쭉 훑어보면 좋을 것 같다. 자주 쓰이는 것은 굵은색으로 표시해두었다. - Mat::rows 행의 개수- Mat::cols 열의 개수- Mat::data 행렬 데이터의 포인터- Mat::dims 행렬의 차원(2보다 같거나 크다)- Mat::isContinuous 각 행의 마지막에 공백없이 연속으로 데이터가 저장되었는지를 확인- Mat::total() 행렬 요소의 전체 개수- Mat:: elemSize() 행렬 요소 하나의 바이트 ..
2016.08.13
no image
OpenCV 기본클래스 (2)
OpenCV 기본클래스 두번째 포스팅이다. 첫번째 포스팅 바로가기 클릭 2. Matx Vec, Scalar_, Range, Ptr 클래스 2.1 Matx 클래스 이 클래스는 고정된 작은 크기의 행렬을 위한 템플릿 클래스이다. 1x1에서 6x6 까지 작은 크기의 행렬과 다양한 행렬 연산함수를 제공한다. 예를 들어 Matx33f 자료형은 3x3 의 float 행렬이다. 더욱 더 일반적인 행렬의 형태는 알다시피 Mat 클래스로 변환하여 사용한다. 이 Matx 클래스에서는 '
2016.08.13
no image
OpenCV 기본클래스 (1)
OpenCV를 공부하는데 앞서 제일 기본적인 OpenCV 기본 클래스에 대해서 간단히 정리해보기로 한다. 개발을 하다보면 제일 먼저 클래스가 어떤건지, 어떤식으로 돌아가는건지 기본적인 이해가 있어야 나중에 간단한 오류를 범하지 않게 된다. 책은 가메출판사의 "C++API OpenCV 프로그래밍"을 쓰고 있고, 앞으로 이 폴더에 있는 대부분의 OpenCV 코드나, 내용은 이 책을 기반으로 한다. 내가 생각하기에 현재 나와있는 OpenCV 3.0 기반으로 제일 명확하고 자세하게 잘 나와있는 책이 아닌가싶다. 1. DataType, Point, Point3 클래스 1.1 기본 자료형 및 DataType 클래스 OpenCV는 uchar, bool, char, unsigned short, signed short,..
2016.08.13
OpenCV 응용프로그램을 제대로 시작하지 못했습니다(0xc000007b) 오류 해결법
OpenCV 3.0을 visual studio 2013, windows 10, 64bit 환경에서 설치하다 에러가 났다."응용프로그램을 제대로 시작하지 못했습니다. (0xc000007b)" 라는 오류가 발생했는데 컴파일(ctrl+f7)엔 문제가 없는데 빌드(ctrl+f5)하는 과정에서 에러가 발생했다. 문장 그대로 구글링해보니 해결법이 다섯가지 정도가 있었다.급하면 4번의 방법을 참고해주길 바란다. 1. Dependency Walker 프로그램 사용 이 프로그램을 사용하면 어떤 dll 이 없어서 프로그램 실행이 안되는지 알려준다고 한다.모두 영어로 설명되어있어서 귀찮아서 일단 다운로드 한다음에 최후의 수단으로 보류해 두었다. 2. 자신의 개발툴 컴파일러에 맞게 환경을 설정 프로젝트 - 옵션 에서 설정해야..
2016.08.13
no image
[SQLD] 2016년 SQLD 시험일정 및 시험내용
제22회 SQL 개발자(SQLD) 자격시험을 드디어 결제했다.선공부 후결제... 1. 시험 비용비용도 학생으로서는 조금 부담스러운 가격인 50,000원이다. 재시험 비용은 40,000원 ! 꼭 열심히 공부해서 한방에 붙어야겠다는 생각이 들도록 가격을 책정한 듯... 2. 시험 일정SQLD 및 SQLP 시험 일정은 다음과 같고 앞으로의 시험은 2번이 남았다. 3. 시험 주요 내용SQLD (SQL 개발자 자격시험) 의 과목은 총 2과목으로 구성되어 있으며 내용은 데이테베이스가이드넷 에서 발췌해왔다. 1. 데이터 모델링의 이해 1.1 데이터 모델링의 이해 1.2 데이터 모델과 성능 2. SQL 기본 및 활용 2.1 SQL 기본 2.2 SQL 활용 2.3 SQL 최적화 기본 원리 이렇게 두가지 파트로 나누어 시..
2016.08.13
no image
[SQLD] 15. TCL(Transaction Control Language)
제 4절 TCL(Transaction control language) 1. 트랜잭션 개요 - 트랜잭션은 데이터베이스의 논리적 연산단위- 밀접히 관련되어 분리될 수 없는 한 개 이상의 데이터베이스 조작- 하나의 트랜잭션에는 하나 이상의 SQL 문장이 포함- 분할 할 수 없는 최소의 단위- ALL OR NOTHING 개념 1.1 트랜잭션의 특성 1.2 잠금(LOCKING) 트랜잭션의 특성을 충족하기 위해 데이터베이스는 다양한 레벨의 잠금 기능을 제공하고 있는데 잠금은 기본적으로 트랜잭션이 수행하는 동안 특정 데이터에 대해서 다른 트랜잭션이 동시에 접근하지 못하도록 제한하는 기법이다. 잠금이 걸린 데이터는 잠금을 실행한 트랜잭션만 독점적으로 접근할 수 있고 다른 트랜잭션으로부터 간섭이나 방해를 받지 않는 것이..
2016.08.12
no image
[SQLD] 14. DML(Data Manipulation Language)
제 3절 DML(Data Manipulation Language) 1. INSERT테이블에 데이터를 입력하는 방법은 두 가지 유형이 있으며 한번에 한건만 입력된다. 첫번째 유형 : 몇 개의 컬럼에만 데이터를 삽입하는 경우- INSERT INTO 테이블명 (컬럼리스트) VALUES (컬럼리스트에 넣을 값리스트); 두번째 유형 : 모든 칼럼에 데이터를 삽입하는 경우- INSERT INTO 테이블명 VALUES (전체컬럼리스트에 넣을 값리스트); - 데이터 유형이 문자일 경우 ' (single quotation)로 입력할 값을 입력- 데이터 유형이 숫자일 경우 그냥 입력- Primary key나 not null로 지정된 칼럼은 null이 허용되지 않는다.- 두번째 유형은 칼럼의 순서대로 빠짐없이 데이터가 입력..
2016.08.11