기본 콘텐츠로 건너뛰기

SQL Server (1) 테이블

스키마(Schema)

SQL Server는 Table, Index, Primary Key, Foreign Key, View, Check, Default, Stored procedure, Function, Trigger, Data type 등과 같은 다양한 데이터베이스 개체을 가지고 있다. 이중 실제 물리적인 크기를 갖는 개체는 Table과 Index이다. View 경우 Index를 지정하면 물리적인 크기를 갖게 된다.

SQL Server에서 개체 이름은 서버명.데이터베이스명.스키마명.개체명과 같이 전체 이름를 사용하는 방법과 부분 이름을 사용하는 방법이 있다. 분산 트랜젝션이나 원격 질의 등을 수행할 경우는 전체 이름을 사용해야 하나 대부분은 데이터베이스에 연결된 경우 스키마명.개체명 정도를 사용하는 것이 무난하다.

데이터베이스 내의 개체들을 포함하는 추상적 개념으로 스키마라는 개념을 사용한다. SQL Server 2000의 경우 테이블 등과 같은 개체를 생성할 경우 사용자에게 권한을 부여하였기 때문에 사용자명.개체명으로 개체 이름을 사용하였다. 하지만 사용자를 삭제할 경우 해당 사용자에게 권한이 부여된 개체를 모두 삭제하거나, 다른 사용자에게 권한을 이관해야만 삭제가 가능한 불편함이 있었고, 어플리케이션 내에 사용자명.개체명으로 명명된 개체 이름을 모두 찾아서 수정해야 하는 불편함마저 발생하였다.

SQL Server 2005부터는 스키마를 사용하여 이런 불편함을 없앴으며, 사용자는 스키마에 대한 권한을 지정하므로써 해당 스키마내의 개체들을 대상으로 작업을 하는 구조로 변경되었다. 데이터베이스를 만들면 기본적으로 dbo라는 이름의 스키마가 만들어지는데 dbo라는 이름은 SQL Server 2000에서 관리자 계정이 DBO라는 이름으로 지정되었기 때문에 호환성을 위해 선택된 이름이다.

스키마명은 보통 업무별로 이름을 지정하고 해당 업무 담당자를 사용자로 지정하여 권한을 주는게 일반적이다. 스키마를 삭제할 경우는 해당 스키마가 소유하는 개체들을 다른 스키마로 이관하거나 모두 삭제해야 한다.

댓글

이 블로그의 인기 게시물

아두이노 미세먼지 센서 PM2008

온습도계를 달아봤으니 이참에 미세먼지까지 한꺼번에 표시되도록 기능을 추가해보기로 했다. 마침 아두이노 전용 쉴드까지 제공하는 미세먼지 센서가 눈에 띄길래 일단 구매를 해봤다. 배송받은 센서는 거의 완제품에 가깝게 제작되었다. 다만 아쉬운 점은 아두이노 전용 쉴드의 마감이 좀 지분하다는 느낌을 받았는데, 후처리에 신경을 더 써주는 센스가 부족한 듯. PC2008 미세먼지 센서 아두이노 우노 전용 PM2008 쉴드  부착한 상태는 핀 위치도 잘 맞고 비교적 깔끔한 느낌이다. 쉴드 덕분에 지저분한 배선이 줄어들어 다른 센서들을 붙이기에도 좋을 것 같다. 쉴드와 일체형으로 제작하지 않은 건 라즈베리 파이와 같은 다른 마이크로칩 보드용의 쉴드 제작을 염두에 둔 듯하다. Arduino UNO에 장착한 모습 센서의 작동 테스트를 위해 PM2008 I2C 라이브러리를 추가하여 샘플코드를 실행시켜봤다. 성공적을 테스트를 완료. 이제 공부가 남았을 뿐. Arduino library PM2008 I2C 설치

Adafuit HUZZAH ESP8266 보드를 이용한 Arduino IDE 환경설정하기

 Espressif社의 ESP8266 마이크로컨트롤러는 Arduino 보드에 사용된 AVR 마이크로컨트롤러와 같은 종류이다. 가장 큰 장점은 WiFi 통신이 가능하며, 별도의 추가적인 하드웨어 없이 펌웨어만으로 WiFi 클라이언트와 Access Point 기능을 제공한다는 점이다. 최근 중요한 이슈로 자리잡은 사물인터넷(IoT)을 구현하는데 더없이 좋은 마이크로컨트롤러라 할 수 있다. 게다가 저렴한 가격은 덤! (8,000 ~ 10,000원 정도이니 Arduino UNO 호환보드 가격이다.)  HUZZAH 보드의 특징을 간단히 살펴보면 다음과 같다. Adafruit HUZZAH ESP8266 ESP8266 칩(64KB RAM, 96KB data RAM, 4MB QIO FLASH) 리셋 버튼 프로그램을 업로드하는데 필요한 부트로딩 모드로 전환하기 위한 버튼 프로그래밍 가능한 RED UART 통신 기능 Analog 입력 1개 (최대 1V) GPIO 핀 9개 (3.3V), I2C와 SPI 이용 가능  프로그래밍을 위해 FTDI 연결이 필요하다. 프로그래밍은 Arduino IDE를 사용할 수 있으며, Arduino와 같이 C/C++ 코드를 이용하여 개발이 가능하다. 참고로 Epressif社의 ESP8266 개발보드인 NodeMCU는 루아(LUA)라는 프로그래밍언어를 기본 제공한다. Adafruit社의 HUZZAH 보드는 기본적으로 핀헤더 없이 반제품으로 판매되며 필요에 따라 핀헤더를 직접 납땜해서 부착해야한다. 핀헤더 및 USB 포트를 기본제공하는 개발보드 형태의 제품을 별도로 판매하고 있다. Arduino IDE를 이용하여 프로그래밍을 하기 위해서는 우선 라이브러리에 ESP8266 보드를 추가해야 한다. Arduino IDE에 ESP8266 애드온 설치하기 1. 환경설정에서 "추가적인 보드 매니저 URLs"에 다음 URL을 입력한다. http://arduino.esp8266.com/sta...

Eclipse + JBoss + jBPM 개발환경 설정

상용 개발환경인 JBoss Development Studio 9.0.0 GA 개발환경과 동일한 오픈소스 환경 구성을 목표 Windows 10 64bit JDK 1.8 64bit Eclipse Mars.1 64bit Wildfly 10 (JBoss Application Server) - JDK 1.8 지원 jBPM 6 1. JDK를 내려받아 설치한다. JDK 1.8 - Windows x64  http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 2. Eclipse을 내려받아 설치한다. 1) Eclipse IDE for Java EE Developers Windows 64bit 배포판을 내려받는다. http://www.eclipse.org/downloads/ 2) 적당한 디렉터리에 압축을 푼다. Ex) d:\eclipse 3) 압축을 풀어낸 디렉터리에서 eclipse.ini를 찾아 jdk bin 디렉터리의 javaw.exe를 설정한다. [eclipse.ini] -vm C:/Program Files/Java/jdk1.8.0_65/bin/javaw.exe 3. Wildfly를 내려받아 설치한다. 1) Wildfly 10.0.0 최신버전을 내려받는다. http://wildfly.org/downloads/ 2) 적당한 디렉터리에 압축을 푼다. Ex) d:\wildfly 4. Eclipse에 JBoss Tools 4.3.0.Final 플러그인을 설치한다. Help > Install New Software... http://download.jboss.org/jbosstools/mars/stable/updates/  주소를 추가한 후 다음 소프트웨어를 설치한다. JBoss Applicastion Server Adaper JBoss Maven Int...