CREATE FUNCTION f_SplitAddress(@地点 nvarchar(4000),@type int) RETURNS nvarchar(4000) AS BEGIN DECLARE @TestInfo varchar(50),@Province varchar(50),@result nvarchar(255), @City varchar(50),@district varchar(50),@AAddress varchar(255) --更新事件地址(A:获取省(直辖市)) SELECT @TestInfo = dbo.Get_StrArrayStrOfIndex(@地点,'省',1) IF @TestInfo <> @地点 --表示为省份 BEGIN SET @Province = @TestInfo --给省赋值 --获取省级下的市(也可能是州) SELECT @TestInfo = dbo.Get_StrArrayStrOfIndex(@地点,'市',1) IF @TestInfo <> @地点 --市 BEGIN --给省级下的市赋值 SELECT @City = dbo.Get_StrArrayStrOfIndex(@TestInfo,2) SELECT @TestInfo = dbo.Get_StrArrayStrOfIndex(@地点,@City,2) IF(SELECT dbo.Get_StrArrayStrOfIndex(@TestInfo,'镇',1)) <> @TestInfo --镇 BEGIN --给镇赋值 SELECT @district = dbo.Get_StrArrayStrOfIndex(@TestInfo,1) --给村赋值 SELECT @AAddress = dbo.Get_StrArrayStrOfIndex(@TestInfo,@district,2) END ELSE IF(SELECT dbo.Get_StrArrayStrOfIndex(@TestInfo,'县',1)) <> @TestInfo --县 BEGIN --给县赋值 SELECT @district = dbo.Get_StrArrayStrOfIndex(@TestInfo,1) --给村赋值 SELECT @AAddress = dbo.Get_StrArrayStrOfIndex(@TestInfo,2) END ELSE IF(SELECT dbo.Get_StrArrayStrOfIndex(@TestInfo,'州',1)) <> @TestInfo --州 BEGIN --给州赋值 SELECT @district = dbo.Get_StrArrayStrOfIndex(@TestInfo,'区',1)) <> @TestInfo --区 BEGIN --给区赋值 SELECT @district = dbo.Get_StrArrayStrOfIndex(@TestInfo,2) END ELSE IF(SELECT dbo.Get_StrArrayStrOfIndex(@TestInfo,1)) <> @TestInfo --市 BEGIN --给区赋值 SELECT @district = dbo.Get_StrArrayStrOfIndex(@TestInfo,2) END END ELSE --州 BEGIN SELECT @TestInfo = dbo.Get_StrArrayStrOfIndex(@地点,1) --给省级下的州赋值 SELECT @City = dbo.Get_StrArrayStrOfIndex(@TestInfo,2) END END END ELSE IF(SELECT dbo.Get_StrArrayStrOfIndex(@地点,1)) <> @地点 BEGIN --表示为直辖市 SELECT @TestInfo = dbo.Get_StrArrayStrOfIndex(@地点,1) SET @Province = @TestInfo --给直辖市赋值 SET @City = @Province SELECT @TestInfo = dbo.Get_StrArrayStrOfIndex(@地点,2) IF(SELECT dbo.Get_StrArrayStrOfIndex(@TestInfo,1)) <> @TestInfo --镇 BEGIN --给镇赋值 SELECT @district = dbo.Get_StrArrayStrOfIndex(@TestInfo,1) --给村赋值 SELECT @AAddress = dbo.Get_StrArrayStrOfIndex(@TestInfo,2) END ELSE IF(SELECT dbo.Get_StrArrayStrOfIndex(@TestInfo,1)) <> @TestInfo --县 BEGIN --给县赋值 SELECT @district = dbo.Get_StrArrayStrOfIndex(@TestInfo,1) --给村赋值 SELECT @AAddress = dbo.Get_StrArrayStrOfIndex(@TestInfo,2) END ELSE IF(SELECT dbo.Get_StrArrayStrOfIndex(@TestInfo,1)) <> @TestInfo --州 BEGIN --给州赋值 SELECT @district = dbo.Get_StrArrayStrOfIndex(@TestInfo,1)) <> @TestInfo --区 BEGIN --给区赋值 SELECT @district = dbo.Get_StrArrayStrOfIndex(@TestInfo,2) END ELSE IF(SELECT dbo.Get_StrArrayStrOfIndex(@TestInfo,1)) <> @TestInfo --市 BEGIN --给市赋值 SELECT @district = dbo.Get_StrArrayStrOfIndex(@TestInfo,2) END END --返回值(@type:0返回全部信息,1返回省,2返回市,3返回县,4返回村) IF @type = 0 BEGIN SET @result = @Province+@City+@district+@AAddress END ELSE IF @type = 1 BEGIN SET @result = @Province END ELSE IF @type = 2 BEGIN SET @result = @City END ELSE IF @type = 3 BEGIN SET @result = @district END ELSE IF @type = 4 BEGIN SET @result = @AAddress END ELSE BEGIN SET @result = @Province+@City+@district+@AAddress END IF @result = '' OR @result = NUll BEGIN SET @result = '很遗憾,分割失败!' END RETURN @result END --调用 SELECT dbo.f_SplitAddress('湖北省赤壁市车埠镇车埠村十一组50号',0) --返回所有:湖北省赤壁市车埠镇车埠村十一组50号 --此函数不可缺少(要先写) CREATE function [dbo].[Get_StrArrayStrOfIndex] ( @str varchar(1024),--要分割的字符串 @split varchar(10),--分隔符号 @index int --取第几个元素 ) returns varchar(1024) as begin declare @location int declare @start int declare @next int declare @seed int set @str=ltrim(rtrim(@str)) set @start=1 set @next=1 set @seed=len(@split) set @location=charindex(@split,@str) while @location<>0 and @index>@next begin set @start=@location+@seed set @location=charindex(@split,@str,@start) set @next=@next+1 end if @location =0 select @location =len(@str)+1 --这儿存在两种情况:1、字符串不存在分隔符号 2、字符串中存在分隔符号,跳出while循环后,@location为0,那默认为字符串后边有一个分隔符号。 return substring(@str,@start,@location-@start+1) end
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。