DB2-テーブル

テーブルは、データベースマネージャによって維持される論理構造です。テーブルでは、各垂直ブロックは列(Tuple)と呼ばれ、各水平ブロックは行(Entity)と呼ばれます。列と行の形式で格納されたデータのコレクションは、テーブルと呼ばれます。テーブルでは、各列のデータ型が異なります。テーブルは、永続データを格納するために使用されます。

テーブルの種類

  • Base Tables:永続的なデータを保持します。ベーステーブルには、次のようなさまざまな種類があります。
    • Regular Tables:汎用テーブル、インデックス付きの共通テーブルは汎用テーブルです。
    • Multidimensional Clustering Table (MDC):このタイプのテーブルは、複数のキーに物理的にクラスター化されており、大規模なデータベース環境を維持するために使用されていました。これらのタイプの表は、DB2pureScaleではサポートされていません。
    • Insert time clustering Table (ITC):MDCテーブルと同様に、行はテーブルに挿入されるまでにクラスター化されます。それらはパーティション化されたテーブルにすることができます。それらもpureScale環境をサポートしていません。
    • Range-Clustered tables Table (RCT):これらのタイプのテーブルは、データへの高速で直接的なアクセスを提供します。これらはシーケンシャルクラスターとして実装されます。テーブル内の各レコードにはレコードIDがあります。これらのタイプのテーブルは、データがテーブル内の1つ以上の列と密にクラスター化されている場合に使用されます。このタイプの表は、DB2pureScaleでもサポートされていません。
    • Partitioned Tables:これらのタイプのテーブルは、テーブルデータが複数のストレージオブジェクトに分割されるデータ編成スキーマで使用されます。データパーティションは、パーティションテーブルに追加、アタッチ、およびデタッチできます。1つのテーブルスペースのテーブルから複数のデータパーティションを格納できます。
    • Temporal Tables:データベース内のテーブルの履歴は、以前に行われた変更の詳細などの一時テーブルに保存されます。
  • Temporary Tables:さまざまなデータベース操作の一時的な作業には、一時テーブルを使用する必要があります。一時テーブル(DGTT)はシステムカタログに表示されません。XML列は作成された一時テーブルでは使用できません。
  • Materialized Query Tables:MQTを使用して、クエリのパフォーマンスを向上させることができます。これらのタイプのテーブルは、テーブル内のデータを決定するために使用されるクエリによって定義されます。

テーブルの作成

次の構文でテーブルが作成されます。

Syntax:[新しいテーブルを作成するには]

db2 create table <schema_name>.<table_name>
(column_name column_type....) in <tablespace_name>

Example:「professional」のスキーマに「employee」の詳細を格納するためのテーブルを作成します。このテーブルには「id、name、jobrole、joindate、salary」フィールドがあり、このテーブルデータはテーブルスペース「ts1」に格納されます。

db2 create table professional.employee(id int, name 
varchar(50),jobrole varchar(30),joindate date, 
salary double) in ts1

Output:

DB20000I The SQL command completed successfully.

リストテーブルの詳細

次の構文は、テーブルの詳細を一覧表示するために使用されます。

Syntax:[スキーマで作成されたテーブルのリストを表示するには]

db2 select tabname, tabschema, tbspace from syscat.tables

Example:[現在のデータベースのテーブルのリストを表示するには]

db2 select tabname, tabschema, tbspace from syscat.tables

Output:

TABNAME      TABSCHEMA     TBSPACE 
------------ ------------- -------- 
EMPLOYEE     PROFESSIONAL    TS1  


 1 record(s) selected.

テーブル内の列の一覧表示

次の構文は、テーブルの列を一覧表示します。

Syntax:[テーブルの列とデータ型を表示するには]

db2 describe table <table_name>

Example:[テーブル 'employee'の列とデータ型を表示するには]

db2 describe table professional.employee

Output:

Data type                   Column 
Column name  schema    Data type name    Length    Scale Nulls 
------ ----- --------- ----------------- --------- ----- ------ 
ID           SYSIBM    INTEGER             4         0     Yes 
NAME         SYSIBM    VARCHAR             50        0     Yes 
JOBROLE      SYSIBM    VARCHAR             30        0     Yes 
JOINDATE     SYSIBM    DATE                4         0     Yes 
SALARY       SYSIBM    DOUBLE              8         0     Yes  

  5 record(s) selected.

隠し列

テーブルの列全体を非表示にすることができます。「select * from」クエリを呼び出すと、非表示の列は結果のテーブルに返されません。テーブルにデータを挿入する場合、列リストのない「INSERT」ステートメントは、暗黙的に非表示になっている列の値を予期しません。これらのタイプの列は、マテリアライズ照会表で高度に参照されます。これらのタイプの列は、一時テーブルの作成をサポートしていません。

非表示の列を持つテーブルの作成

次の構文は、非表示の列を持つテーブルを作成します。

Syntax:[非表示の列を持つテーブルを作成するには]

db2 create table <tab_name> (col1 datatype,col2 datatype 
implicitly hidden)

Example:[非表示の列 'phone'を持つ 'customer'テーブルを作成するには]

db2 create table professional.customer(custid integer not 
null, fullname varchar(100), phone char(10) 
implicitly hidden)

テーブルにデータ値を挿入する

次の構文は、テーブルに値を挿入します。

Syntax:[テーブルに値を挿入するには]

db2 insert into <tab_name>(col1,col2,...)
 values(val1,val2,..)

Example:['customer'テーブルに値を挿入するには]

db2 insert into professional.customer(custid, fullname, phone) 
values(100,'ravi','9898989')


db2 insert into professional.customer(custid, fullname, phone) 
values(101,'krathi','87996659')


db2 insert into professional.customer(custid, fullname, phone) 
values(102,'gopal','768678687')

Output:

DB20000I  The SQL command completed successfully.

テーブルから値を取得する

次の構文は、テーブルから値を取得します。

Syntax:[テーブルから値を取得するには]

db2 select * from &lttab_name>

Example:['customer'テーブルから値を取得するには]

db2 select * from professional.customer

Output:

CUSTID      FULLNAME 
----------- ------------------------ 
        100 ravi
		
        101 krathi
		
        102 gopal  
		
  3 record(s) selected.

非表示の列を含むテーブルから値を取得する

次の構文は、選択した列から値を取得します。

Syntax:[選択した非表示の列の値をテーブルから取得するには]

db2 select col1,col2,col3 from <tab_name>

Example:[選択した列の値を取得するには、テーブルから結果を取得します]

db2 select custid,fullname,phone from professional.customer

Output:

CUSTID  FULLNAME    PHONE 
------- ---------   ------------ 
100     ravi        9898989
 
101     krathi      87996659 

102     gopal       768678687 

  3 record(s) selected.

非表示の列のデータを表示する場合は、「DESCRIBE」コマンドを実行する必要があります。

Syntax

db2 describe table <table_name> show detail

Example:

db2 describe table professional.customer show detail

Output:

Column name     Data type schema     Data type name  Column
           column    Partitionkey  code 
                                       Length   Scale    Nulls     
number     sequence      page     Hidden      Default 
--------------- -------------------- --------------- -------- ----
---- -------- ---------- ------------- -------- ----------- ------ 
---  
CUSTID          SYSIBM               INTEGER         4        0 
No       0          0         0        No 
FULLNAME        SYSIBM               VARCHAR         100      0
Yes      1          0        1208     No     

PHONE           SYSIBM               CHARACTER       10       0     
Yes      2          0             1208     Implicitly  
  
3 record(s) selected.

テーブル列のタイプの変更

この「alter」コマンドを使用して、次のようにテーブル構造を変更できます。

Syntax

db2 alter table <tab_name> alter column <col_name> set data type <data_type>

Example: [従業員テーブルの列「id」のデータ型を「int」から「bigint」に変更するには]

db2 alter table professional.employee alter column id set data type bigint

Output:

DB20000I The SQL command completed successfully.

列名の変更

以下に示すように、列名を変更できます。

Syntax:[列名をテーブルの古い名前から新しい名前に変更するには]

db2 alter table <tab_name> rename column <old_name> to <new_name>

Example: [「customers」テーブルの列名を「fullname」から「custname」に変更します。]

db2 alter table professional.customer rename column fullname to custname

テーブルを落とす

テーブルを削除するには、次のように「DROP」コマンドを使用する必要があります。

Syntax

db2 drop table <tab_name>

Example: [顧客テーブルフォームデータベースを削除するには]

db2 drop table professional.customers

テーブルの階層全体(トリガーとリレーションを含む)を削除するには、「DROPTABLEHIERARCHY」コマンドを使用する必要があります。

Syntax

db2 drop table hierarchy <tab_name>

Example: [テーブル 'customer'の階層全体を削除するには]

db2 drop table hierarchy professional.customers