説明
この変数はV2.1バージョンから導入されました。
機能の概要
foreign_key_checksは、DML/DDL操作時に外部キー制約をチェックするかどうかを設定します。
適用対象
この変数はOceanBaseデータベースのMySQLモードでのみ適用されます。
権限要件
変数の確認
グローバルレベル
sysテナントとすべてのユーザーテナントはSHOW VARIABLESステートメント、またはinformation_schema.GLOBAL_VARIABLESビュー(MySQLモード)を使用してグローバルシステム変数の値を確認できます。セッションレベル
sysテナントとすべてのユーザーテナントはSHOW VARIABLESステートメント、またはinformation_schema.SESSION_VARIABLESビュー(MySQLモード)を使用してセッションシステム変数の値を確認できます。
変数の変更
グローバル変更
sysテナントはグローバルシステム変数の値を直接変更できます。MySQLユーザーテナントは
SUPERまたはALTER SYSTEM権限を持っている必要があります。
セッション変更
sysテナントとすべてのユーザーテナントは、自身のテナントにおけるセッションシステム変数の値を直接変更できます。
プロパティの説明
プロパティ |
説明 |
|---|---|
| パラメータタイプ | Bool |
| デフォルト値 | 1 |
| 値の範囲 |
|
| 適用範囲 |
|
| 変更は可能か | はい。SETステートメントを使用して変更できます。 |
使用方法
OceanBaseデータベースではデフォルトで外部キー制約のチェックが有効になっています。このチェックのオン/オフはテナント変数foreign_key_checksによって制御されます。外部キー制約を作成する際、外部キー名を指定しない場合、システムは自動的に制約名を割り当てます。自動割り当てられる制約名は、テーブル名_OBFK_と作成時刻のタイムスタンプです。例:t1_OBFK_1627747200000000。
設定例
DML/DDL操作時に外部キー制約をチェックします。
セッション変更
obclient> SET foreign_key_checks = ON;または
obclient> SET foreign_key_checks = 1;グローバル変更
obclient> SET GLOBAL foreign_key_checks = ON;または
obclient> SET GLOBAL foreign_key_checks = 1;