DB2 - Database
Bab ini menjelaskan tentang cara membuat, mengaktifkan, dan menonaktifkan database dengan sintaks yang terkait.
Arsitektur database
Database adalah kumpulan Tabel, Skema, Bufferpools, Log, grup Penyimpanan, dan Tablespaces yang bekerja sama untuk menangani operasi database secara efisien.
Direktori database
Direktori database adalah tempat penyimpanan database yang terorganisir. Saat Anda membuat database, semua detail tentang database disimpan dalam direktori database, seperti detail perangkat penyimpanan default, file konfigurasi, dan daftar tabel sementara, dll.
Direktori global partisi dibuat di folder instance. Direktori ini berisi semua informasi global yang berhubungan dengan database. Direktori global partisi ini dinamai NODExxxx / SQLyyy, di mana xxxx adalah nomor partisi data dan yyy adalah token database.
Di direktori partisi-global, direktori khusus anggota dibuat. Direktori ini berisi informasi database lokal. Direktori khusus anggota dinamai MEMBERxxxx dengan xxxx adalah nomor anggota. Lingkungan DB2 Enterprise Server Edition berjalan pada satu anggota dan hanya memiliki satu direktori khusus anggota. Direktori khusus anggota ini secara unik dinamai MEMBER0000.
Direktori global yang dipartisi
Lokasi Direktori: <instance> / NODExxx / SQLxxx
Direktori partisi-global berisi file terkait database seperti yang tercantum di bawah ini.
- File pemantauan peristiwa tulis-ke-file kebuntuan global
- File informasi ruang tabel [SQLSPCS.1, SQLSPCS.2]
- File kontrol grup penyimpanan [SQLSGF.1, SQLSGF.2]
- File wadah ruang meja sementara. [/ jalur penyimpanan /
/T0000011/C000000.TMP/SQL00002.MEMBER0001.TDA] - File Konfigurasi Global [SQLDBCONF]
- File sejarah [DB2RHIST.ASC, DB2RHIST.BAK, DB2TSCHG.HIS, DB2TSCHG.HIS]
- File terkait pencatatan [SQLOGCTL.GLFH.1, SQLOGCTL.GLFH.2]
- Mengunci file [SQLINSLK, SQLTMPLK]
- Wadah Penyimpanan Otomatis
Direktori khusus anggota
Lokasi direktori: / NODExxxx / SQLxxxx / MEMBER0000
Direktori ini berisi:
- Objek yang berhubungan dengan database
- File informasi kolam penyangga [SQLBP.1, SQLBP.2]
- File pemantauan acara lokal
- File terkait pencatatan [SQLOGCTL.LFH.1, SQLOGCTL.LFH.2, SQLOGMIR.LFH].
- File konfigurasi lokal
- File monitor acara kebuntuan. File monitor kejadian kebuntuan rinci disimpan dalam direktori database node katalog dalam kasus ESE dan lingkungan database yang dipartisi.
Membuat database
Anda dapat membuat database secara instan menggunakan perintah "BUAT DATABASE". Semua database dibuat dengan grup penyimpanan default "IBMSTOGROUP", yang dibuat pada saat membuat mesin virtual. Di DB2, semua tabel database disimpan di "tablespace", yang menggunakan grup penyimpanan masing-masing.
Hak istimewa untuk database secara otomatis ditetapkan sebagai PUBLIK [CREATETAB, BINDADD, CONNECT, IMPLICIT_SCHEMA, dan SELECT], namun, jika opsi PEMBATASAN ada, hak istimewa tidak diberikan sebagai PUBLIK.
Membuat database non-restriktif
Perintah ini digunakan untuk membuat database non-restriktif.
Syntax: [Untuk membuat Database baru. 'database_name' menunjukkan nama database baru, yang ingin Anda buat.]
db2 create database <database name>
Example: [Untuk membuat database non-restriktif baru dengan nama 'one']
db2 create database one
Output:
DB20000I The CREATE DATABASE command completed successfully.
Membuat database yang membatasi
Database restriktif dibuat saat menjalankan perintah ini.
Syntax: [Dalam sintaks di bawah ini, "db_name" menunjukkan nama database.]
db2 create database <db_name> restrictive
Example: [Untuk membuat database restriktif baru dengan nama 'dua']
db2 create database two restrictive
Membuat database dengan lokasi yang ditentukan pengguna berbeda
Buat database dengan grup penyimpanan default "IBMSTOGROUP" di jalur berbeda. Sebelumnya, Anda menjalankan perintah "buat database" tanpa lokasi yang ditentukan pengguna untuk menyimpan atau membuat database di lokasi tertentu. Untuk membuat database menggunakan lokasi database yang ditentukan pengguna, ikuti prosedur berikut:
Syntax: [Dalam sintaks di bawah ini, 'db_name' menunjukkan 'nama database' dan 'data_location' menunjukkan di mana harus menyimpan data dalam folder dan 'db_path_location' menunjukkan lokasi driver 'data_location'.]
db2 create database '<db_name>' on '<data location>' dbpath on '<db_path_location>'
Example: [Untuk membuat database bernama 'four', dimana data disimpan di 'data1' dan folder ini disimpan di 'dbpath1']
db2 create database four on '/data1' dbpath on '/dbpath1'
Melihat file direktori database lokal atau sistem
Anda menjalankan perintah ini untuk melihat daftar direktori yang tersedia di instance saat ini.
Syntax:
db2 list database directory
Example:
db2 list database directory
Output:
System Database Directory
Number of entries in the directory = 6
Database 1 entry:
Database alias = FOUR
Database name = FOUR
Local database directory =
/home/db2inst4/Desktop/dbpath
Database release level = f.00
Comment =
Directory entry type = Indirect
Catalog database partition number = 0
Alternate server hostname =
Alternate server port number =
Database 2 entry:
Database alias = SIX
Database name = SIX
Local database directory = /home/db2inst4
Database release level = f.00
Comment =
Directory entry type = Indirect
Catalog database partition number = 0
Alternate server hostname =
Alternate server port number =
Mengaktifkan database
Perintah ini memulai semua layanan yang diperlukan untuk database tertentu sehingga database tersedia untuk aplikasi.
Syntax: ['db_name' menunjukkan nama database]
db2 activate db <db_name>
Example: [Mengaktifkan database 'one']
db2 activate db one
Menonaktifkan database
Dengan menggunakan perintah ini, Anda dapat menghentikan layanan database.
Syntax:
db2 deactivate db <db_name>
Example: [Untuk Menonaktifkan database 'satu']
db2 deactivate db one
Menghubungkan ke database
Setelah membuat database, untuk menggunakannya, Anda perlu menghubungkan atau memulai database.
Syntax:
db2 connect to <database name>
Example: [Untuk Menghubungkan Database satu ke CLI saat ini]
db2 connect to one
Output:
Database Connection Information
Database server = DB2/LINUXX8664 10.1.0
SQL authorization ID = DB2INST4
Local database alias = ONE
Memverifikasi apakah basis data dibatasi
Untuk memeriksa apakah database ini terbatas atau tidak, berikut adalah sintaksnya:
Syntax: [Dalam sintaks berikut, 'db' menunjukkan Database, 'cfg' menunjukkan konfigurasi, 'db_name' menunjukkan nama database]
db2 get db cfg for <db_name> | grep -i restrict
Example: [Untuk memeriksa apakah database 'satu' dibatasi atau tidak]
db2 get db cfg for one | grep -i restrict
Output:
Restrict access = NO
Konfigurasi manajer database dan database
Konfigurasi instance (Konfigurasi manajer database) disimpan dalam file bernama 'db2system' dan konfigurasi terkait database disimpan dalam file bernama 'SQLDBCON'. File-file ini tidak dapat diedit secara langsung. Anda dapat mengedit file ini menggunakan alat yang disebut API. Dengan menggunakan prosesor baris perintah, Anda dapat menggunakan perintah ini.
Parameter Konfigurasi Database Manager
Syntax: [Untuk mendapatkan informasi dari pengelola Database Instance]
db2 get database manager configuration
ATAU
db2 get dbm cfg
Syntax: [Untuk memperbarui pengelola database instance]
db2 update database manager configuration
ATAU
db2 update dbm cfg
Syntax: [Untuk menyetel ulang konfigurasi sebelumnya]
db2 reset database manager configuration
ATAU
db2 reset dbm cfg
Parameter Konfigurasi Basis Data
Syntax: [Untuk mendapatkan informasi tentang Database]
db2 get database configuration
ATAU
db2 get db cfg
Syntax: [Untuk memperbarui konfigurasi database]
db2 update database configuration
ATAU
db2 update db cfg
Syntax: [Untuk mengatur ulang nilai yang dikonfigurasi sebelumnya dalam konfigurasi database
db2 reset database configuration
ATAU
db2 reset db cfg
Syntax: [Untuk memeriksa ukuran Database Aktif Saat Ini]
db2 "call get_dbsize_info(?,?,?,-1)"
Example: [Untuk memverifikasi ukuran Saat Ini Aktifkan Database]
db2 "call get_dbsize_info(?,?,?,-1)"
Output:
Value of output parameters
--------------------------
Parameter Name : SNAPSHOTTIMESTAMP
Parameter Value : 2014-07-02-10.27.15.556775
Parameter Name : DATABASESIZE
Parameter Value : 105795584
Parameter Name : DATABASECAPACITY
Parameter Value : 396784705536
Return Status = 0
Memperkirakan ruang yang dibutuhkan untuk database
Untuk memperkirakan ukuran database, kontribusi faktor-faktor berikut harus dipertimbangkan:
- Tabel Katalog Sistem
- Data Tabel Pengguna
- Data Lapangan Panjang
- Data Objek Besar (LOB)
- Ruang Indeks
- Ruang Kerja Sementara
- Data XML
- Ruang file log
- Direktori database lokal
- File sistem
Memeriksa otoritas database
Anda dapat menggunakan sintaks berikut untuk memeriksa otoritas database mana yang diberikan ke PUBLIC pada database non-restriktif.
Step 1: terhubung ke database dengan otentikasi user-id dan kata sandi instance.
Syntax: [Untuk terhubung ke database dengan username dan password]
db2 connect to <db_name> user <userid> using <password>
Example: [Untuk Menghubungkan Database "satu" dengan id pengguna 'db2inst4' dan kata sandi 'db2inst4']
db2 connect to one user db2inst4 using db2inst4
Output:
Database Connection Information
Database server = DB2/LINUXX8664 10.1.0
SQL authorization ID = DB2INST4
Local database alias = ONE
Step2: Untuk memverifikasi otoritas database.
Syntax: [Sintaks di bawah ini menunjukkan hasil layanan otoritas untuk database saat ini]
db2 "select substr(authority,1,25) as authority, d_user, d_group,
d_public, role_user, role_group, role_public,d_role from table(
sysproc.auth_list_authorities_for_authid ('public','g'))as t
order by authority"
Example:
db2 "select substr(authority,1,25) as authority, d_user, d_group,
d_public, role_user, role_group, role_public,d_role from table(
sysproc.auth_list_authorities_for_authid ('PUBLIC','G'))as t
order by authority"
Output:
AUTHORITY D_USER D_GROUP D_PUBLIC ROLE_USER ROLE_GROUP ROLE_PUBLIC D_ROLE
------------------------- ------ ------- -------- --------- ---------- ----------- ------
ACCESSCTRL * * N * * N *
BINDADD * * Y * * N *
CONNECT * * Y * * N *
CREATETAB * * Y * * N *
CREATE_EXTERNAL_ROUTINE * * N * * N *
CREATE_NOT_FENCED_ROUTINE * * N * * N *
CREATE_SECURE_OBJECT * * N * * N *
DATAACCESS * * N * * N *
DBADM * * N * * N *
EXPLAIN * * N * * N *
IMPLICIT_SCHEMA * * Y * * N *
LOAD * * N * * N *
QUIESCE_CONNECT * * N * * N *
SECADM * * N * * N *
SQLADM * * N * * N *
SYSADM * * * * * * *
SYSCTRL * * * * * * *
SYSMAINT * * * * * * *
SYSMON * * * * * * *
WLMADM * * N * * N *
20 record(s) selected.
Menjatuhkan Database
Dengan menggunakan perintah Drop, Anda dapat menghapus database kami dari direktori database instance. Perintah ini dapat menghapus semua objek, tabel, spasi, wadah, dan file terkait.
Syntax: [Untuk melepaskan database apa pun dari sebuah instance]
db2 drop database <db_name>
Example: [Menghapus database 'enam' dari instance]
db2 drop database six
Output:
DB20000I The DROP DATABASE command completed successfully