📣
TiDB Cloud Essential はパブリックプレビュー中です。このページは自動翻訳されたものです。原文はこちらからご覧ください。

その他の機能



TiDB は、MySQL 8.0 で利用可能なその他の関数のほとんどをサポートしています。

サポートされている関数

名前説明
ANY_VALUE()ONLY_FULL_GROUP_BY値の拒否を抑制します
BIN_TO_UUID()UUIDをバイナリ形式からテキスト形式に変換する
DEFAULT()テーブル列のデフォルト値を返します
GROUPING()GROUP BY操作の修飾子
INET_ATON()IPアドレスの数値を返します
INET_NTOA()数値からIPアドレスを返します
INET6_ATON()IPv6アドレスの数値を返します
INET6_NTOA()数値からIPv6アドレスを返します
IS_IPV4()引数が IPv4 アドレスかどうか
IS_IPV4_COMPAT()引数が IPv4 互換アドレスであるかどうか
IS_IPV4_MAPPED()引数が IPv4 マップド アドレスであるかどうか
IS_IPV6()引数が IPv6 アドレスかどうか
IS_UUID()引数がUUIDかどうか
NAME_CONST()列名を変更するために使用できます
SLEEP()指定された秒数だけスリープします。TiDB TiDB Cloud StarterおよびTiDB Cloud Essentialインスタンスの場合、 SLEEP()関数には制限があり、最大スリープ時間は 300 秒までしかサポートされないことに注意してください。
UUID()ユニバーサル一意識別子(UUID)を返します。
UUID_TO_BIN()UUIDをテキスト形式からバイナリ形式に変換する
VALUES()INSERT時に使用される値を定義します

任意の値()

ANY_VALUE()関数は、値のグループから任意の値を返します。通常、 SELECTステートメントに集計されていない列をGROUP BY句とともに含める必要があるシナリオで使用されます。

CREATE TABLE fruits (id INT PRIMARY KEY, name VARCHAR(255)); Query OK, 0 rows affected (0.14 sec) INSERT INTO fruits VALUES (1,'apple'),(2,'apple'),(3,'pear'),(4,'banana'),(5, 'pineapple'); Query OK, 5 rows affected (0.01 sec) Records: 5 Duplicates: 0 Warnings: 0 SELECT id,name FROM fruits GROUP BY name; ERROR 1055 (42000): Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'test.fruits.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by SELECT ANY_VALUE(id),GROUP_CONCAT(id),name FROM fruits GROUP BY name; +---------------+------------------+-----------+ | ANY_VALUE(id) | GROUP_CONCAT(id) | name | +---------------+------------------+-----------+ | 1 | 1,2 | apple | | 3 | 3 | pear | | 4 | 4 | banana | | 5 | 5 | pineapple | +---------------+------------------+-----------+ 4 rows in set (0.00 sec)

前述の例では、 SELECT列が非集計列であり、 id句に含まれていないため、TiDB は最初のGROUP BYステートメントに対してエラーを返します。この問題を解決するために、2 番目のSELECTクエリでは、 ANY_VALUE()を使用して各グループから任意の値を取得し、 GROUP_CONCAT()を使用して各グループ内のid列のすべての値を単一の文字列に連結します。この方法により、非集計列の SQL モードを変更することなく、各グループから 1 つの値とグループ内のすべての値を取得できます。

BIN_TO_UUID()

BIN_TO_UUID()UUID_TO_BIN()は、テキスト形式の UUID とバイナリ形式の UUID を相互に変換するために使用できます。どちらの関数も 2 つの引数を受け取ります。

  • 最初の引数は、変換する値を指定します。
  • 2番目の引数(オプション)は、バイナリ形式におけるフィールドの順序を制御します。
SET @a := UUID(); Query OK, 0 rows affected (0.00 sec) SELECT @a; +--------------------------------------+ | @a | +--------------------------------------+ | 9a17b457-eb6d-11ee-bacf-5405db7aad56 | +--------------------------------------+ 1 row in set (0.00 sec) SELECT UUID_TO_BIN(@a); +------------------------------------+ | UUID_TO_BIN(@a) | +------------------------------------+ | 0x9A17B457EB6D11EEBACF5405DB7AAD56 | +------------------------------------+ 1 row in set (0.00 sec) SELECT BIN_TO_UUID(0x9A17B457EB6D11EEBACF5405DB7AAD56); +-------------------------------------------------+ | BIN_TO_UUID(0x9A17B457EB6D11EEBACF5405DB7AAD56) | +-------------------------------------------------+ | 9a17b457-eb6d-11ee-bacf-5405db7aad56 | +-------------------------------------------------+ 1 row in set (0.00 sec) SELECT UUID_TO_BIN(@a, 1); +----------------------------------------+ | UUID_TO_BIN(@a, 1) | +----------------------------------------+ | 0x11EEEB6D9A17B457BACF5405DB7AAD56 | +----------------------------------------+ 1 row in set (0.00 sec) SELECT BIN_TO_UUID(0x11EEEB6D9A17B457BACF5405DB7AAD56, 1); +----------------------------------------------------+ | BIN_TO_UUID(0x11EEEB6D9A17B457BACF5405DB7AAD56, 1) | +----------------------------------------------------+ | 9a17b457-eb6d-11ee-bacf-5405db7aad56 | +----------------------------------------------------+ 1 row in set (0.00 sec)

UUID()およびUUIDのベストプラクティスも参照してください。

デフォルト()

DEFAULT()関数は、列のデフォルト値を取得するために使用されます。

CREATE TABLE t1 (id INT PRIMARY KEY, c1 INT DEFAULT 5); Query OK, 0 rows affected (0.15 sec) INSERT INTO t1 VALUES (1, 1); Query OK, 1 row affected (0.01 sec) UPDATE t1 SET c1=DEFAULT(c1)+3; Query OK, 1 row affected (0.02 sec) Rows matched: 1 Changed: 1 Warnings: 0 TABLE t1; +----+------+ | id | c1 | +----+------+ | 1 | 8 | +----+------+ 1 row in set (0.00 sec)

前述の例では、 UPDATEステートメントはc1列の値を、列のデフォルト値 ( 5 ) に3を加えた値に設定し、結果として8という新しい値になります。

グループ化()

GROUP BY修飾子を参照してください。

INET_ATON()

INET_ATON()関数は、ドット付き四分音符表記の IPv4 アドレスを、効率的に保存できるバイナリ バージョンに変換します。

SELECT INET_ATON('127.0.0.1');
+------------------------+ | INET_ATON('127.0.0.1') | +------------------------+ | 2130706433 | +------------------------+ 1 row in set (0.00 sec)

INET_NTOA()

INET_NTOA()関数は、バイナリ IPv4 アドレスをドット付き四角形表記に変換します。

SELECT INET_NTOA(2130706433);
+-----------------------+ | INET_NTOA(2130706433) | +-----------------------+ | 127.0.0.1 | +-----------------------+ 1 row in set (0.00 sec)

INET6_ATON()

INET6_ATON()関数はINET_ATON()と似ていますが、 INET6_ATON() IPv6 アドレスも処理できます。

SELECT INET6_ATON('::1');
+--------------------------------------+ | INET6_ATON('::1') | +--------------------------------------+ | 0x00000000000000000000000000000001 | +--------------------------------------+ 1 row in set (0.00 sec)

INET6_NTOA()

INET6_NTOA()関数はINET_NTOA()と似ていますが、 INET6_NTOA() IPv6 アドレスも処理できます。

SELECT INET6_NTOA(0x00000000000000000000000000000001);
+------------------------------------------------+ | INET6_NTOA(0x00000000000000000000000000000001) | +------------------------------------------------+ | ::1 | +------------------------------------------------+ 1 row in set (0.00 sec)

IS_IPV4()

IS_IPV4()関数は、指定された引数が IPv4 アドレスであるかどうかをテストします。

SELECT IS_IPV4('127.0.0.1');
+----------------------+ | IS_IPV4('127.0.0.1') | +----------------------+ | 1 | +----------------------+ 1 row in set (0.00 sec)
SELECT IS_IPV4('300.0.0.1');
+----------------------+ | IS_IPV4('300.0.0.1') | +----------------------+ | 0 | +----------------------+ 1 row in set (0.00 sec)

IS_IPV4_COMPAT()

IS_IPV4_COMPAT()関数は、指定された引数が IPv4 互換アドレスであるかどうかをテストします。

SELECT IS_IPV4_COMPAT(INET6_ATON('::127.0.0.1'));
+-------------------------------------------+ | IS_IPV4_COMPAT(INET6_ATON('::127.0.0.1')) | +-------------------------------------------+ | 1 | +-------------------------------------------+ 1 row in set (0.00 sec)

IS_IPV4_MAPPE()

IS_IPV4_MAPPED()関数は、指定された引数が IPv4 マップド アドレスであるかどうかをテストします。

SELECT IS_IPV4_MAPPED(INET6_ATON('::ffff:127.0.0.1'));
+------------------------------------------------+ | IS_IPV4_MAPPED(INET6_ATON('::ffff:127.0.0.1')) | +------------------------------------------------+ | 1 | +------------------------------------------------+ 1 row in set (0.00 sec)

IS_IPV6()

IS_IPV6()関数は、指定された引数が IPv6 アドレスであるかどうかをテストします。

SELECT IS_IPV6('::1');
+----------------+ | IS_IPV6('::1') | +----------------+ | 1 | +----------------+ 1 row in set (0.00 sec)

IS_UUID()

IS_UUID()関数は、指定された引数がUUIDであるかどうかをテストします。

SELECT IS_UUID('eb48c08c-eb71-11ee-bacf-5405db7aad56');
+-------------------------------------------------+ | IS_UUID('eb48c08c-eb71-11ee-bacf-5405db7aad56') | +-------------------------------------------------+ | 1 | +-------------------------------------------------+ 1 row in set (0.00 sec)

NAME_CONST()

NAME_CONST()関数は列に名前を付けるために使用されます。代わりに列エイリアスを使用することをお勧めします。

SELECT NAME_CONST('column name', 'value') UNION ALL SELECT 'another value';
+---------------+ | column name | +---------------+ | another value | | value | +---------------+ 2 rows in set (0.00 sec)

前述のステートメントではNAME_CONST()を使用していますが、次のステートメントでは列のエイリアス付けに推奨される方法を使用しています。

SELECT 'value' AS 'column name' UNION ALL SELECT 'another value';
+---------------+ | column name | +---------------+ | value | | another value | +---------------+ 2 rows in set (0.00 sec)

寝る()

SLEEP()関数は、クエリの実行を指定された秒数だけ一時停止するために使用されます。

SELECT SLEEP(1.5);
+------------+ | SLEEP(1.5) | +------------+ | 0 | +------------+ 1 row in set (1.50 sec)

UUID()

UUID()関数は、 RFC 4122で定義されているユニバーサル一意識別子 (UUID) バージョン 1 を返します。

SELECT UUID();
+--------------------------------------+ | UUID() | +--------------------------------------+ | cb4d5ae6-eb6b-11ee-bacf-5405db7aad56 | +--------------------------------------+ 1 row in set (0.00 sec)

UUIDのベストプラクティスも参照してください。

UUIDからビンへ

BIN_TO_UUID()を参照してください。

値()

VALUES(col_name)関数は、 INSERTステートメントのON DUPLICATE KEY UPDATE句で特定の列の値を参照するために使用されます。

CREATE TABLE t1 (id INT PRIMARY KEY, c1 INT); Query OK, 0 rows affected (0.17 sec) INSERT INTO t1 VALUES (1,51),(2,52),(3,53),(4,54),(5,55); Query OK, 5 rows affected (0.01 sec) Records: 5 Duplicates: 0 Warnings: 0 INSERT INTO t1 VALUES(2,22),(4,44) ON DUPLICATE KEY UPDATE c1=VALUES(id)+100; Query OK, 4 rows affected (0.01 sec) Records: 2 Duplicates: 2 Warnings: 0 TABLE t1; +----+------+ | id | c1 | +----+------+ | 1 | 51 | | 2 | 102 | | 3 | 53 | | 4 | 104 | | 5 | 55 | +----+------+ 5 rows in set (0.00 sec)

サポートされていない関数

名前説明
UUID_SHORT()TiDBには存在しない特定の前提条件に基づいて一意のUUIDを提供しますTiDB #4620

このページは役に立ちましたか?