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