Home > Database > Mysql Tutorial > How Can I Extract Digits from Strings in MySQL?

How Can I Extract Digits from Strings in MySQL?

DDD
Release: 2025-01-09 16:57:46
Original
550 people have browsed it

How Can I Extract Digits from Strings in MySQL?

Extract numbers from string in MySQL

When dealing with alphanumeric strings, numbers need to be separated for various data processing needs. MySQL provides several ways to achieve this goal.

For strings starting with a numeric character followed by a non-numeric character, you can use CAST() or implicit conversion:

<code class="language-sql">SELECT CAST('1234abc' AS UNSIGNED); -- 1234
SELECT '1234abc'+0; -- 1234</code>
Copy after login

To extract numbers from an arbitrarily structured string, you can define a custom function like ExtractNumber:

<code class="language-sql">DELIMITER $$

CREATE FUNCTION `ExtractNumber`(in_string VARCHAR(50))
RETURNS INT
NO SQL
BEGIN
    DECLARE ctrNumber VARCHAR(50);
    DECLARE finNumber VARCHAR(50) DEFAULT '';
    DECLARE sChar VARCHAR(1);
    DECLARE inti INTEGER DEFAULT 1;

    IF LENGTH(in_string) > 0 THEN
        WHILE(inti <= LENGTH(in_string)) DO
            SET sChar = SUBSTRING(in_string, inti, 1);
            IF sChar BETWEEN '0' AND '9' THEN
                SET finNumber = CONCAT(finNumber, sChar);
            END IF;
            SET inti = inti + 1;
        END WHILE;
        RETURN CAST(finNumber AS UNSIGNED);
    ELSE
        RETURN 0;
    END IF;
END$$

DELIMITER ;</code>
Copy after login

After defining the custom function ExtractNumber, you can use it in queries:

<code class="language-sql">SELECT ExtractNumber("abc1234def") AS number; -- 1234</code>
Copy after login

The above is the detailed content of How Can I Extract Digits from Strings in MySQL?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template