从字符串中提取特定文本

时间:2019-02-10 22:14:35

标签: mysql sql

我有一个Varchar字段,其中包含信息。作为信息的一部分,有一个国家(在所有情况下均列为字符串的第一项)。我想做的是运行一个脚本,该脚本将从字段中提取字符串的第一个字母,直到并包括字符串中第一个空格之前的最后一个字母。然后将其提取出来,将其放在同一行的单独字段中

3 个答案:

答案 0 :(得分:0)

如果您使用的是MySQl 8,则可以使用REGEXP_SUBSTR

select REGEXP_SUBSTR('Canada Test JohnDoe', '^[A-Za-z]+') o from dual

对于MySQL 5.5 +

with cte as
(
   select 'Canada Test JohnDoe' x from dual
)
select SUBSTR(x, 1, LOCATE(' ', x)) o from cte

答案 1 :(得分:0)

您可以使用substring_index()

select substring_index(col, ' ', 1) as country

如果字符串中没有空格,您将获得完整的字符串。所以这似乎是“安全的”。

注意:这不适用于所有国家/地区。许多有多个名称。从“美利坚合众国”和“联合王国”到最新的名称“北马其顿”

答案 2 :(得分:0)

我认为SUBSTRING_INDEX可以胜任。

SELECT SUBSTRING_INDEX(`name`, ' ', 1) AS countryName
FROM tableName;

//SUBSTRING_INDEX(str,delimiter,count)

您可以找到有关此功能here

的更多信息