函数PARSENAME使用和截取字符串

MS SQL server有一个函数PARSENAME ( 'object_name' , object_piece )html

函数有2个参数:数据库

Object_name
检索的对象名称。便是:服务器名.数据库名.全部者.对象名
Object_piece
是检索的对象类型。其值为1~4。
 
好比,为存储过程或自定义函数传入表名: TABLE_CATALOG.TABLE_SCHEMA. TABLE_NAME.COLUMN_NAME动态操做数据表时。
 
举个列:
 
 
DECLARE @str  NVARCHAR(MAX) = N'testdb.dbo.table_part.qty'

SELECT 
PARSENAME(@str,4) AS [TABLE_CATALOG],
PARSENAME(@str,3) AS [TABLE_SCHEMA],
PARSENAME(@str,2) AS [TABLE_NAME],
PARSENAME(@str,1) AS [COLUMN_NAME]
GO
Source Code

 

 另一个演示,定义一个表变量,随机添加存储一些IP地址:
 
 
 而后SELECT表,并使用ORDER BY进行排序:
 
 
这种排序结果,并不是是咱们想要的,它只是按每一段首数字大小进行排序。
这是为何,由于这些IP地址,并不是是标准IP地址。
把IP地址,转换为标准IP,参考这篇《 转换为标准IPv4格式http://www.javashuo.com/article/p-dbjboodc-er.html
以上的这个函数,也有使用 PARSENAME函数时行处理。
 
 
 
;WITH cte_ips AS
(
    SELECT [IPv4],[dbo].[svf_ConvertToStandardIPv4]([IPv4]) AS [std_ip] FROM @ips
)
SELECT [IPv4],[std_ip] FROM cte_ips
ORDER BY PARSENAME([std_ip],4),
         PARSENAME([std_ip],3),
         PARSENAME([std_ip],2),
         PARSENAME([std_ip],1)
Source Code
相关文章
相关标签/搜索