我有一些数据,我想基于可能存在或不存在的分隔符进行拆分。基于分隔符的T-SQL拆分字符串
示例数据:
John/Smith
Jane/Doe
Steve
Bob/Johnson
我使用下面的代码拆分此数据为第一和最后一个名字:
SELECT SUBSTRING(myColumn, 1, CHARINDEX('/', myColumn)-1) AS FirstName,
SUBSTRING(myColumn, CHARINDEX('/', myColumn) + 1, 1000) AS LastName
FROM MyTable
的结果,我想:
FirstName---LastName
John--------Smith
Jane--------Doe
Steve-------NULL
Bob---------Johnson
只要所有行都具有预期的分隔符,此代码就可以正常工作,但当行不行时会出错t:
"Invalid length parameter passed to the LEFT or SUBSTRING function."
如何重新编写此项以正常工作?
正是我一直在寻找,谢谢! – Whatevo
很棒!谢谢 – Mikel