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

lbsoftware 2003-11-11 09:40:05
但825不一定从第四个开始,不过一定是在两个-之间。上面的字符串是一个字断的值,但我想要其中的825。谢谢大家!
...全文
93 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的执行速度之快可想而知.
基于永磁同步电机矢量控制simulink仿真内容概要:本文档围绕永磁同步电机(PMSM)矢量控制的Simulink仿真展开,详细介绍了基于Simulink平台构建永磁同步电机矢量控制系统的方法,涵盖电机数学模型、坐标变换、PI调节器设计、SVPWM调制、电流环与速度环控制策略等核心内容。通过仿真模型实现对电机的高性能控制,帮助理解矢量控制原理及其工程实现方式,并可用于教学、科研及实际项目开发中的算法验证与优化。此外,文档还提及多种相关仿真案例,如同步电机无传感器控制、扩展状态观测器应用等,进一步丰富了研究维度。; 适合人群:具备一定电机控制理论基础和Simulink使用经验的电气工程、自动化及相关专业的研究生、科研人员及从事电机驱动系统开发的工程师。; 使用场景及目标:①掌握永磁同步电机矢量控制的基本原理与仿真建模方法;②用于高校课程设计、毕业设计或科研项目的仿真验证;③为企业研发提供可参考的技术方案与实现路径;④深入理解FOC(磁场定向控制)在实际系统中的应用细节。; 阅读建议:建议结合Simulink软件动手搭建仿真模型,逐步调试各模块参数,重点关注电流环与速度环的动态响应特性,同时可拓展学习无传感器控制、MPC预测控制等进阶内容以提升综合设计能力。

34,874

社区成员

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

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