在 SQL Server 2019 中修剪 nvarchar 参数
我有一个存储过程,它将字符串发送到我的参数之一
@deliveryName [nvarchar](255)
有时交付名称可以是“交付示例 1”,有时可以是“交付方法 - 交付示例 1”,也可能是“其他内容 - 交付示例 1” “
在它到达存储过程之前无法对其进行编辑,有没有一种安全的方法可以纯粹在sql server MSSQL中修剪第一个“-”之前的所有内容?我说如果送货名称中有多个“-”,有没有安全的办法。例如“交付方法 - 交付示例 - 2”我只想让它输出“交付示例 - 2”
到目前为止我所看到的所有地方都说
CASE
WHEN str LIKE ',%,' THEN SUBSTRING(str, 2, LEN(str)-2)
WHEN str LIKE ',%' THEN RIGHT(str, LEN(str)-1)
WHEN str LIKE '%,' THEN LEFT(str, LEN(str)-1)
ELSE str
END
对每种可能性使用一个案例(类似这样的),但总是有新的方法每天,所以这很难跟上。
I have a stored procedure that sends a string to one of my parameters
@deliveryName [nvarchar](255)
Sometimes the delivery name can be "Delivery example 1" and sometimes it can be "Delivery method - Delivery example 1", it could also be "something else - Delivery example 1"
This cant be edited before it hits the stored procedure, is there a safe way to trim everything before the first "-" purely in sql server MSSQL? I say is there a safe way in the case that there are multiple "-" in the delivery name. for example "Delivery method - Delivery example - 2" i would just want it to output "Delivery example - 2"
Everywhere ive looked so far is saying to use a case when (something like this)
CASE
WHEN str LIKE ',%,' THEN SUBSTRING(str, 2, LEN(str)-2)
WHEN str LIKE ',%' THEN RIGHT(str, LEN(str)-1)
WHEN str LIKE '%,' THEN LEFT(str, LEN(str)-1)
ELSE str
END
for every eventuality but there are always new methods daily so this would be hard to keep up with.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
看起来它只需要一个带有
CHARINDEX
或PATINDEX
的SUBSTRING
来获取第一个破折号的位置。测试片段
db<>fiddle 上的演示 此处< /em>
Looks like it just needs a
SUBSTRING
with aCHARINDEX
orPATINDEX
to get the position of the first dash.Test snippet
Demo on db<>fiddle here
对于没有“-”的名称,您可以将“-”附加到
DeliveryName
变量中,获取第一次出现“-”的索引,并获取该索引右侧的字符串You could append a '-' to your
DeliveryName
variable for names that don't have a '-', get the index of first occurence of '-' and get the string to right of that index