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 <tab_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