ホームページ >データベース >mysql チュートリアル >MySQL の比較のために文字列から数値以外の文字を効率的に取り除くにはどうすればよいですか?

MySQL の比較のために文字列から数値以外の文字を効率的に取り除くにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-12-06 21:11:16470ブラウズ

How Can I Efficiently Strip Non-Numeric Characters from Strings for MySQL Comparisons?

MySQL 文字列比較での数字以外の文字の削除

MySQL で文字列を比較する場合、多くの場合、数値以外の文字を削除する必要があります。試合の邪魔をする。この操作を実行するには、MySQL クエリ内の preg_replace などの PHP 関数に直接依存することはできません。

代わりに、指定された文字列から数字以外の文字を削除するカスタム MySQL 関数を作成できます。以下に関数の例を示します。

DROP FUNCTION IF EXISTS STRIP_NON_DIGIT;
DELIMITER $$
CREATE FUNCTION STRIP_NON_DIGIT(input VARCHAR(255))
   RETURNS VARCHAR(255)
BEGIN
   DECLARE output   VARCHAR(255) DEFAULT '';
   DECLARE iterator INT          DEFAULT 1;
   WHILE iterator < (LENGTH(input) + 1) DO
      IF SUBSTRING(input, iterator, 1) IN ( '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' ) THEN
         SET output = CONCAT(output, SUBSTRING(input, iterator, 1));
      END IF;
      SET iterator = iterator + 1;
   END WHILE;
   RETURN output;
END
$$

この関数は VARCHAR 入力を受け取り、各文字を反復処理して、それが数字であるかどうかを確認します。存在する場合、その文字は出力変数に追加されます。

この関数を使用すると、次のように文字列から数値以外の文字を取り除き、それを MySQL クエリの数値と比較するために使用できます。 :

SELECT * FROM foo WHERE STRIP_NON_DIGIT(bar) = '12345'

以上がMySQL の比較のために文字列から数値以外の文字を効率的に取り除くにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。