最近在工作中,需要从数据库存储的邮箱中提取出用户所在国家代码。
经研究发现,国家代码最长为3位,而且一般是跟在@字符后面,所以可以用以下sql函数提取。
创建Sql函数
--mail格式为 xxx@{countrycode}.abc.com CREATE FUNCTION fn_GetCountryCodeFromMail ( @mail NVARCHAR(200) ) RETURNS VARCHAR(3) BEGIN RETURN UPPER(REPLACE(SUBSTRING(@mail, CHARINDEX('@', @mail) + 1, 3), '.', '')); END
执行测试
SELECT dbo.fn_GetCountryCodeFromMail('a@cn.abc.com') UNION SELECT dbo.fn_GetCountryCodeFromMail('b@ind.abc.com')