MySQL - UUID

こんにちは、未来のデータベースの魔法使いさんたち!今日は、MySQLにおけるUUIDの魔法の世界に飛び込みます。新しいことを学ぶのが初めてでも、このレッスンが終わるまでに、プロのようにUUIDを呼び出せるようになるでしょう!

MySQL - UUID

MySQLのUUID関数

まずは基本から始めましょう。UUIDはUniversally Unique Identifierの略で、すべての砂に唯一の名前を与えるようなものです。すごいですね、-right?

MySQLには、私たちにこれらのユニークな識別子を生成してくれる便利な関数UUID()があります。まるで、あなたが愿えばいつでも唯一の愿いを叶えてくれる精霊のようです!

使い方を以下に示します:

SELECT UUID();

これを実行すると、以下のようなものが表示されます:

'123e4567-e89b-12d3-a456-426614174000'

UUID()を呼び出すたびに、異なる結果が得られます。まるで、側面が何兆もあるサイコロを振るようなものです!

UUIDを使う理由

「こんな長くて複雑な文字列に手間をかける必要があるの?」と思っているかもしれません。では、巨大なオンラインストアを運営していると仮定しましょう。すべての注文に唯一の番号を割り当てる必要があります。哪怕是在同一ミリ秒に2人の顧客が注文をした場合でも。UUIDはこの問題を素晴らしく解決します!

UUIDのフォーマット

では、UUIDの構造を分解してみましょう。ランダムな文字列の寄せ集めではなく、法則性があります!

UUIDは128ビットの数値で表され、32桁の16進数として5つのグループにハイフンで区切られて表示されます。以下のようになります:

xxxxxxxx-xxxx-Mxxx-Nxxx-xxxxxxxxxxxx

ここで:

  • xは16進数の数字(0-9またはa-f)
  • MはUUIDのバージョン(1-5)
  • Nは変種(8、9、a、またはb)

MySQLでは通常、バージョン1または4のUUIDを使用します。

データベーステーブル内のUUID

新たに得たUUIDの知識を実際のデータベーステーブルで使ってみましょう!

図書館の書籍を管理するためのテーブルを作成すると仮定しましょう。UUIDを主キーとして使用します:

CREATE TABLE books (
book_id CHAR(36) PRIMARY KEY,
title VARCHAR(100),
author VARCHAR(100),
publication_year INT
);

そして、図書館に本を追加します:

INSERT INTO books (book_id, title, author, publication_year)
VALUES (UUID(), 'The MySQL Magician', 'Query Queen', 2023);

このINSERT文を実行するたびに、新しい唯一のIDを持つ新しい本が追加されます。重複キーの心配はもうありません!

UUIDを使った書籍の選択

魔法のMySQL本を取得するために、以下を使用します:

SELECT * FROM books WHERE title = 'The MySQL Magician';

これで以下のような結果が得られます:

book_id                               | title               | author      | publication_year
--------------------------------------+---------------------+-------------+------------------
f47ac10b-58cc-4372-a567-0e02b2c3d479  | The MySQL Magician  | Query Queen | 2023

UUIDの修正

「生成されたUUIDを変更することはできるのか?」と思っているかもしれません。短い答えは:できますが、するべきではありません!

UUIDはユニークで永続的なものとして設計されています。変更することはその目的を台無います。しかし、絶対に変更する必要がある場合(たとえば、テストデータをクリーンアップする場合)、以下のようにすることができます:

UPDATE books
SET book_id = UUID()
WHERE title = 'The MySQL Magician';

これにより、本に新しいUUIDが割り当てられます。しかし、実際のシナリオでは、他のシステムの一部が古いUUIDを参照している場合、問題が発生する可能性があります!

UUID関数とメソッド

MySQLはUUIDを操作するためのいくつかの関数を提供しています。以下に便利な表を示します:

関数 説明
UUID() 新しいUUIDを生成
UUID_TO_BIN(uuid) UUIDを文字列形式からバイナリ形式に変換
BIN_TO_UUID(uuid_bin) UUIDをバイナリ形式から文字列形式に変換
IS_UUID(string) 文字列が有効なUUIDかどうかを確認

以下にこれらの使い方の例を示します:

SELECT UUID() AS new_uuid,
UUID_TO_BIN(UUID()) AS binary_uuid,
BIN_TO_UUID(UUID_TO_BIN(UUID())) AS back_to_string,
IS_UUID(UUID()) AS is_valid_uuid;

これで新しいUUID、そのバイナリ表現、バイナリから文字列に戻されたもの、そしてそれが有効なUUIDかどうかの確認が得られます。

結論

そして、ここまでが、私の亲爱的な学生たちとのUUIDの旅です。我们从它们的生成到在数据库中的使用,甚至是高级函数までをのぞいてきました。

UUIDは雪の结晶のように、(ほぼ)2つが同じことはありません。分散システム間でのユニーク性を確保するのに最適で、MySQLのツールキットにおける強力なツールです。

MySQLの冒険を続ける中で、UUIDのさらに多くの使い道を見つけるでしょう。特に、中央管理机构が識別子を割り当てることなくユニークなIDが必要な状況では非常に便利です。

練習を続け、好奇心を持ち続けてください。そうすれば、間もなく、あなたは開発チームのUUIDの魔法使いになるでしょう!次回まで、お楽しみに!ハッピーキューイング!

Credits: Image by storyset