Sql从邮件中提取国家代码

最近在工作中,需要从数据库存储的邮箱中提取出用户所在国家代码。

经研究发现,国家代码最长为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')

 

转载于:https://www.cnblogs.com/lizhanglong/p/7505483.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值