Apache Derby-스키마

데이터베이스 스키마는 전체 데이터베이스의 논리적보기를 나타내는 골격 구조입니다. 데이터가 구성되는 방식과 데이터 간의 관계가 연결되는 방식을 정의합니다. 데이터에 적용될 모든 제약 조건을 공식화합니다.

스키마 생성

CREATE SCHEMA 문을 사용하여 Apache Derby에서 스키마를 생성 할 수 있습니다.

통사론

다음은 CREATE SCHEMA 문의 구문입니다.

CREATE SCHEMA schema_name AUTHORIZATION id

다음 예제는 Derby 데이터베이스에 my_schema라는 스키마를 작성합니다.

ij> CREATE SCHEMA AUTHORIZATION my_schema;
0 rows inserted/updated/deleted

그런 다음 아래와 같이이 스키마에 테이블을 생성 할 수 있습니다.

ij> CREATE TABLE my_schema.Emp ( Id INT NOT NULL GENERATED ALWAYS AS IDENTITY,
   Name VARCHAR(255),
   Salary INT NOT NULL,
   Location VARCHAR(255),
   Phone_Number BIGINT
);
> > > > > 0 rows inserted/updated/deleted

SHOW SCHEMAS 쿼리를 사용하여 스키마 목록을 확인할 수 있습니다. 여기에서 생성 된 스키마 목록을 찾을 수 있습니다.

ij> show schemas;
TABLE_SCHEM
------------------------------
APP
MY_SCHEMA
NULLID
SQLJ
SYS
SYSCAT
SYSCS_DIAG
SYSCS_UTIL
SYSFUN
SYSIBM
SYSPROC
SYSSTAT
12 rows selected

스키마 삭제

DROP SCHEMA 문을 사용하여 기존 스키마를 삭제할 수 있습니다.

통사론

다음은 DROPS SCHEMA 문의 구문입니다.

DROP SCHEMA my_schema RESTRICT;

스키마에 개체가없는 경우에만 스키마를 삭제할 수 있습니다. 스키마를 삭제하려면 모든 테이블을 삭제하고 스키마를 삭제하십시오.

ij> DROP TABLE my_schema.Emp;
0 rows inserted/updated/deleted

다음 예제는 위에서 생성 된 스키마를 삭제합니다.

ij> DROP SCHEMA my_schema RESTRICT;
0 rows inserted/updated/deleted

JDBC 예

다음 JDBC 예제는 my_schema라는 스키마를 만들고 삭제합니다.

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class CreateSchemaExample {
   public static void main(String args[]) throws Exception {
      //Registering the driver
      Class.forName("org.apache.derby.jdbc.EmbeddedDriver");
      //Getting the Connection object
      String URL = "jdbc:derby:sampleDB;create=true";
      Connection conn = DriverManager.getConnection(URL);

      //Creating the Statement object
      Statement stmt = conn.createStatement();

      stmt.execute("CREATE SCHEMA AUTHORIZATION my_schema");
      //Executing the query
      String query = "CREATE TABLE my_schema.Employees( "
         + "Id INT NOT NULL GENERATED ALWAYS AS IDENTITY, "
         + "Name VARCHAR(255), "
         + "Salary INT NOT NULL, "
         + "Location VARCHAR(255), "
         + "PRIMARY KEY (Id))";
      stmt.execute(query);
      System.out.println("Table created in schema");
      stmt.execute("DROP TABLE my_schema.Employees");
      stmt.execute("DROP SCHEMA my_schema RESTRICT");
      System.out.println("Schema dropped");
   }
}

산출

실행시 위의 프로그램은 다음과 같은 예제를 생성합니다.

Table created in schema
Schema dropped