如何用SQL语句得到第一个'-'和第二个'-'这间的值?如:100-825-4565-7878。我只想要825。谢大家。

lbsoftware 2003-11-11 09:40:05
但825不一定从第四个开始,不过一定是在两个-之间。上面的字符串是一个字断的值,但我想要其中的825。谢谢大家!
...全文
89 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
cloudchen 2003-11-11
  • 打赏
  • 举报
回复
declare @str varchar(100),@find varchar(100),@firstPosition int,@secondPosition int
set @str = '100-825123123123-4565-7878'
set @find = '-'
set @firstPosition = charindex(@find,@str)+1
set @secondPosition = charindex(@find,@str,@firstPosition)
select substring(@str,@firstPosition,@secondPosition-@firstPosition)
wenhao676 2003-11-11
  • 打赏
  • 举报
回复
create function f_split(@SourceSql varchar(8000),@StrSeprate varchar(10))
returns @temp table(a varchar(100))
--实现split功能 的函数
--date :2003-10-14
as
begin
declare @i int
set @SourceSql=rtrim(ltrim(@SourceSql))
set @i=charindex(@StrSeprate,@SourceSql)
while @i>=1
begin
insert @temp values(left(@SourceSql,@i-1))
set @SourceSql=substring(@SourceSql,@i+1,len(@SourceSql)-@i)
set @i=charindex(@StrSeprate,@SourceSql)
end
if @SourceSql<>''
insert @temp values(@SourceSql)
return
end

用这个函数,随便你取那个
carolbaby 2003-11-11
  • 打赏
  • 举报
回复
declare @index1 int;

select @index1 = charindex('-','100-825-4565-7878')+1

select substring('100-825-4565-7878',@index1,charindex('-','100-825-4565-7878',@index1) - @index1)

不过不够简洁
lbsoftware 2003-11-11
  • 打赏
  • 举报
回复
那个825不一定长为3,也可能是56456456
pengdali 2003-11-11
  • 打赏
  • 举报
回复
select substring('100-825-4565-7878',charindex('-','100-825-4565-7878')+1,3)
day_dayup 2003-11-11
  • 打赏
  • 举报
回复
declare @number varchar(50)
declare @number2 varchar(50)
declare @lenth int
set @number='12156765-15545-54515'
set @lenth=charindex('-',@number)-1
set @number2=substring(@number,@lenth+2,len(@number))
select substring(@number2,1,(charindex('-',@number2)-1))
erickleung 2003-11-11
  • 打赏
  • 举报
回复
为何不在输入数据之时, 先按组别输入到不同的字段, 又假如字段为电话编号, 又容许用户使用不同格式输入, 一些有3个'-'一此有空白符, 一此只有一个'-'. 这样的sql的执行速度之快可想而知.
【微电网】【创新点】基于非支配排序的蜣螂优化算法NSDBO求解微电网多目标优化调度研究(Matlab代码实现)内容概要:本文研究了基于非支配排序的蜣螂优化算法(NSDBO)在微电网多目标优化调度中的应用,并提供了Matlab代码实现。该方法结合智能优化算法与电力系统调度需求,针对微电网运行中的多重目标(如经济性、环保性、稳定性等)进行协同优化,有效提升了调度方案的综合性能。文中详细阐述了NSDBO算法的设计原理、非支配排序机制及其在求解多目标问题上的优势,并通过仿真实验验证了其相较于传统算法在收敛性和多样性方面的优越表现。; 适合人群:具备一定电力系统基础知识和Matlab编程能力的研究生、科研人员及从事微电网优化、智能优化算法研究的相关工程技术人员。; 使用场景及目标:①用于解决微电网中多目标、多约束的优化调度问题,如成本最小化与碳排放最低的平衡;②为智能优化算法在能源系统中的应用提供可复现的技术路径和代码参考,支持学术研究与实际项目开发; 阅读建议:建议读者结合Matlab代码深入理解算法实现细节,重点关注非支配排序与蜣螂行为模拟的融合机制,同时可尝试将其迁移至其他多目标优化问题中进行拓展研究。

34,874

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧