程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> sql server取出內容中漢字,數字,字母

sql server取出內容中漢字,數字,字母

編輯:關於SqlServer

       --取出數字

      IF OBJECT_ID(’DBO.GET_NUMBER2’) IS NOT NULL

      DROP FUNCTION DBO.GET_NUMBER2

      GO

      CREATE FUNCTION DBO.GET_NUMBER2(@S VARCHAR(100))

      RETURNS VARCHAR(100)

      AS

      BEGIN

      WHILE PATINDEX(’%[^0-9]%’,@S) > 0

      BEGIN

      set @s=stuff(@s,patindex(’%[^0-9]%’,@s),1,’’)

      END

      RETURN @S

      END

      GO

      --測試

      PRINT DBO.GET_NUMBER(’呵呵ABC123ABC’)

      GO

      --123

      --------------------------------------------------------------------

      --取出英文

      IF OBJECT_ID(’DBO.GET_STR’) IS NOT NULL

      DROP FUNCTION DBO.GET_STR

      GO

      CREATE FUNCTION DBO.GET_STR(@S VARCHAR(100))

      RETURNS VARCHAR(100)

      AS

      BEGIN

      WHILE PATINDEX(’%[^a-z]%’,@S) > 0

      BEGIN

      set @s=stuff(@s,patindex(’%[^a-z]%’,@s),1,’’)

      END

      RETURN @S

      END

      GO

      --測試

      PRINT DBO.GET_STR(’呵呵ABC123ABC’)

      GO

      --------------------------------------------------------------------

      --取出中文

      IF OBJECT_ID(’DBO.CHINA_STR’) IS NOT NULL

      DROP FUNCTION DBO.CHINA_STR

      GO

      CREATE FUNCTION DBO.CHINA_STR(@S NVARCHAR(100))

      RETURNS VARCHAR(100)

      AS

      BEGIN

      WHILE PATINDEX(’%[^吖-座]%’,@S) > 0

      SET @S = STUFF(@S,PATINDEX(’%[^吖-座]%’,@S),1,N’’)

      RETURN @S

      END

      GO

      PRINT DBO.CHINA_STR(’呵呵ABC123ABC’)

      GO

      SELECT * FROM (select ’ASDKG論壇K聯通DL’ as col)TB WHERE COL LIKE N’%[吖-咗]%’

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved