メインコンテンツまでスキップ
バージョン: 26.x

STARTS_WITH

説明

STARTS_WITH関数は、文字列が指定された接頭辞で始まるかどうかを確認します。これは真偽値を返す関数で、完全な接頭辞マッチングを実行し、大文字と小文字を区別します。

構文

STARTS_WITH(<str>, <prefix>)

パラメータ

Parameterデスクリプション
<str>チェック対象のメイン文字列。型: VARCHAR
<prefix>マッチさせる接頭辞文字列。型: VARCHAR

戻り値

BOOLEAN型を返します(Dorisでは TINYINT として表示され、true の場合は 1、false の場合は 0)。

マッチングルール:

  • 完全前方一致、大文字小文字を区別
  • 空の接頭辞は任意の文字列にマッチ(true を返す)
  • UTF-8 マルチバイト文字の正確なマッチングをサポート
  • 接頭辞の長さはメイン文字列の長さを超えることはできない(接頭辞が空でない限り)

特殊ケース:

  • いずれかの引数が NULL の場合は NULL を返す
  • 接頭辞が空文字列の場合は true を返す(任意の文字列は空文字列で始まる)
  • メイン文字列が空で接頭辞が空でない場合は false を返す
  • 両方が空文字列の場合は true を返す

  1. 基本的な接頭辞マッチング
SELECT STARTS_WITH('hello world', 'hello'), STARTS_WITH('hello world', 'world');
+-------------------------------------+-------------------------------------+
| STARTS_WITH('hello world', 'hello') | STARTS_WITH('hello world', 'world') |
+-------------------------------------+-------------------------------------+
| 1 | 0 |
+-------------------------------------+-------------------------------------+
  1. 大文字と小文字の区別
SELECT STARTS_WITH('Hello World', 'hello'), STARTS_WITH('Hello World', 'Hello');
+-------------------------------------+-------------------------------------+
| STARTS_WITH('Hello World', 'hello') | STARTS_WITH('Hello World', 'Hello') |
+-------------------------------------+-------------------------------------+
| 0 | 1 |
+-------------------------------------+-------------------------------------+
  1. NULL値の処理
SELECT STARTS_WITH(NULL, 'test'), STARTS_WITH('test', NULL);
+----------------------------+----------------------------+
| STARTS_WITH(NULL, 'test') | STARTS_WITH('test', NULL) |
+----------------------------+----------------------------+
| NULL | NULL |
+----------------------------+----------------------------+
  1. 空文字列の処理
SELECT STARTS_WITH('hello', ''), STARTS_WITH('', 'world');
+---------------------------+----------------------------+
| STARTS_WITH('hello', '') | STARTS_WITH('', 'world') |
+---------------------------+----------------------------+
| 1 | 0 |
+---------------------------+----------------------------+
  1. 完全文字列マッチ
SELECT STARTS_WITH('test', 'test'), STARTS_WITH('test', 'testing');
+-----------------------------+--------------------------------+
| STARTS_WITH('test', 'test') | STARTS_WITH('test', 'testing') |
+-----------------------------+--------------------------------+
| 1 | 0 |
+-----------------------------+--------------------------------+
  1. ファイルパスチェック
SELECT STARTS_WITH('/home/user/file.txt', '/home'), STARTS_WITH('C:\\Windows\\file.txt', 'C:\\');
+--------------------------------------------+------------------------------------------------+
| STARTS_WITH('/home/user/file.txt', '/home') | STARTS_WITH('C:\\Windows\\file.txt', 'C:\\') |
+--------------------------------------------+------------------------------------------------+
| 1 | 1 |
+--------------------------------------------+------------------------------------------------+
  1. UTF-8マルチバイト文字
SELECT STARTS_WITH('ṭṛì ḍḍumai hello', 'ṭṛì'), STARTS_WITH('ṭṛì ḍḍumai hello', 'ḍḍumai');
+------------------------------------------+---------------------------------------------+
| STARTS_WITH('ṭṛì ḍḍumai hello', 'ṭṛì') | STARTS_WITH('ṭṛì ḍḍumai hello', 'ḍḍumai') |
+------------------------------------------+---------------------------------------------+
| 1 | 0 |
+------------------------------------------+---------------------------------------------+
  1. URLとプロトコルの確認
SELECT STARTS_WITH('https://example.com', 'https://'), STARTS_WITH('ftp://server.com', 'http://');
+----------------------------------------------+---------------------------------------------+
| STARTS_WITH('https://example.com', 'https://') | STARTS_WITH('ftp://server.com', 'http://') |
+----------------------------------------------+---------------------------------------------+
| 1 | 0 |
+----------------------------------------------+---------------------------------------------+
  1. 数値文字列プレフィックス
SELECT STARTS_WITH('123456789', '123'), STARTS_WITH('987654321', '123');
+----------------------------------+----------------------------------+
| STARTS_WITH('123456789', '123') | STARTS_WITH('987654321', '123') |
+----------------------------------+----------------------------------+
| 1 | 0 |
+----------------------------------+----------------------------------+
  1. 特殊文字と記号
SELECT STARTS_WITH('@username', '@'), STARTS_WITH('#hashtag', '#');
+-------------------------------+--------------------------------+
| STARTS_WITH('@username', '@') | STARTS_WITH('#hashtag', '#') |
+-------------------------------+--------------------------------+
| 1 | 1 |
+-------------------------------+--------------------------------+

Keywords

STARTS_WITH