SQL案例学习笔记(一)reverser() substring(str,start,length)
--oracle
select rtrim('where aa=0 and b=1 and','and')
--要求获得
where aa=0 and b=1
在sql中没有类似于oracle的rtrim(,)的方法
故用以下方法
--SQL
declare @s nvarchar(50)
declare @dd nvarchar(50)
declare @sp_name nvarchar(50)
set @sp_name='where aa=0 and b=1 and bb=3 and'
select @sp_name
set @dd=reverse(@sp_name)
set @s=substring(@dd,charindex('a',@dd,0)+1,charindex('w',@dd,0))
select reverse(@s)
其中
reverse() 为反转函数
substring(str,start,length)截取指定长度的字符串
肖工写的函数
CREATE FUNCTION dbo.Rtrimstring
(@string NVARCHAR(4000),@trimStr NVARCHAR(50))
RETURNS NVARCHAR(4000)
AS
BEGIN
set @string =rtrim(isnull(@string ,''))
WHILE (Len (@string) > 0)
BEGIN
IF RIGHT(@string,Len(@trimStr)) = @trimStr
BEGIN
--与去掉前导字符串函数正好相反,截取的时候是从左侧截取,从而忽略尾部的匹配字符串
SET @string = LEFT(@string,Len(@string) - Len(@trimStr))
END
ELSE
BREAK
END
RETURN @string
END
DECLARE @string NVARCHAR(4000),@trimStr NVARCHAR(50);
SET @string='where aa=0 and b=1 and';
SET @trimStr='and';
select @string=dbo.Rtrimstring(@string,@trimStr);
select @string;
资料来源:http://www.51itr.com/index.php?doc-view-82.html
大家还有更好的办法么
作者:唐小熊
出处:http://www.cnblogs.com/IT-Bear/
关于作者:一头写代码的熊
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接
如有问题,可以通过kumat@foxmail.com 联系我,非常感谢。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构