ホームページ >データベース >mysql チュートリアル >MySQL の比較のために文字列から数値以外の文字を効率的に取り除くにはどうすればよいですか?
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 サイトの他の関連記事を参照してください。