sql2005只取字段中的 数字 有函数可以用吗????????

wym840713 2009-05-25 05:51:06
部门-1011
部门-1022


要求结果
1011
1022
...全文
187 14 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
wym840713 2009-05-26
  • 打赏
  • 举报
回复
谢谢12楼
htl258_Tony 2009-05-25
  • 打赏
  • 举报
回复
[Quote=引用 12 楼 wym840713 的回复:]
3楼的处理:
部门-1011-财务科

结果是: 1011-财务科
[/Quote]
11楼的试了吗?
wym840713 2009-05-25
  • 打赏
  • 举报
回复
3楼的处理:
部门-1011-财务科

结果是: 1011-财务科
htl258_Tony 2009-05-25
  • 打赏
  • 举报
回复
if object_id('[tb]') is not null drop table [tb] 
go
create table [tb](col varchar(20))
insert [tb] select '部门-1011-财务科'
insert [tb] select '部门-1022'

select left(substring(col,patindex('%[0-9]%',col),len(col+'-')-patindex('%[0-9]%',col)),charindex('-',substring(col,patindex('%[0-9]%',col),len(col+'-')-patindex('%[0-9]%',col))+'-')-1) as col from tb
/*
col
--------------------
1011
1022

(2 行受影响)
*/
you_tube 2009-05-25
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 wym840713 的回复:]
刚才没有清楚 ,可能数字后面也会有汉字的

部门-1011-财务科
[/Quote]
这个就行
[Quote=引用 3 楼 jinjazz 的回复:]
SQL codeselect姓名=left(str,patindex('%[0-9]%',str+'0')-1)
,证件号=stuff(str,1,patindex('%[0-9]%',str+'0')-1,'')from(--这后面是直接写测试数据,你可以直接写表名selectstr=N'张三612345678901234'unionallselectstr=N'张三三612345678901234'unionallselectstr=N'李四612345678901234567'unionallselectstr=N'李四四612345678901234567'unionallselectstr=N'王五(护照号)12345678'unionallselectstr=N'王五五(护照号…
[/Quote]
Jamin_Liu 2009-05-25
  • 打赏
  • 举报
回复
declare @source table
(
context varchar(20)
)

insert into @source
values('部门-001'),
('部门-002');

select right(context,PATINDEX('%[0-9]%',context)-1)
from @source
wym840713 2009-05-25
  • 打赏
  • 举报
回复
刚才没有清楚 ,可能数字后面也会有汉字的

部门-1011-财务科
csdyyr 2009-05-25
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 csdyyr 的回复:]
SQL codeselectright(col,5)fromtb
[/Quote]

DECLARE @TB TABLE([col] NVARCHAR(7))
INSERT @TB
SELECT N'部门-1011' UNION ALL
SELECT N'部门-1022'

SELECT RIGHT(col,4) as col
FROM @TB
/*
col
----
1011
1022
*/

SQL77 2009-05-25
  • 打赏
  • 举报
回复
SELECT RIGHT(RTRIM(@STR),4) FROM TB
htl258_Tony 2009-05-25
  • 打赏
  • 举报
回复
if object_id('[tb]') is not null drop table [tb] 
go
create table [tb](col varchar(20))
insert [tb] select '部门-1011'
insert [tb] select '部门-1022'

select right(col,len(col)-charindex('-',col)) as col from tb
/*
col
--------------------
1011
1022

(2 行受影响)
*/
Zoezs 2009-05-25
  • 打赏
  • 举报
回复

declare @STR varchar(50)
set @STR=N'部门-1011'
select right(@STR,charindex('-',@STR)+1)
jinjazz 2009-05-25
  • 打赏
  • 举报
回复
select 姓名=left(str,patindex('%[0-9]%',str+'0')-1)
,证件号=stuff(str,1,patindex('%[0-9]%',str+'0')-1,'')
from( -- 这后面是直接写测试数据,你可以直接写表名
select str=N'张三612345678901234' union all
select str=N'张三三612345678901234' union all
select str=N'李四612345678901234567' union all
select str=N'李四四612345678901234567' union all
select str=N'王五(护照号)12345678' union all
select str=N'王五五(护照号)12345678'
)a
/*
张三 612345678901234
张三三 612345678901234
李四 612345678901234567
李四四 612345678901234567
王五(护照号) 12345678
王五五(护照号) 12345678
*/
htl258_Tony 2009-05-25
  • 打赏
  • 举报
回复
select right(col,len(col)-charindex('-',col)) as col from tb
csdyyr 2009-05-25
  • 打赏
  • 举报
回复
select right(col,5) from tb
访问真八字排盘系统介绍: 1、八字排盘 八字排盘是将年月日时按照天干地支的形式进行排列,一个时间单位代表了一个柱。八字由年柱、月柱、日柱和时柱共四个柱组成,也被称为四柱八字。八字学基于国阴阳五行、天干地支与刑冲克害、以及民间盲派的神煞论等方式,进一步预测爱情顺遂、工作高低、姻缘好坏、财富高低、学业成就、身体健康等事的学问。 八字排盘由以下元素组合:年月日时四柱、大运干支、胎元 、流年干支、十神、地势、神煞等。生辰八字不只是把干支历计算出来,而还要遵守月令、节令的强弱,时辰的阴阳变化进行校正。排盘分析,就是根据出生者的性别、天干地支的阴阳五行关系、进一步推算出来的一套方法论,给预测者做人生吉凶的参考数据,在未来事业、财运、婚姻、家庭等问题时,能做出风险较低的决策。 八字排盘怎么看 八字排盘由年、月、日、时四柱组成,每柱包含一个天干和一个地支,共八个字。年柱代表出生的年份,月柱代表出生的月份,日柱代表出生的日期,时柱则代表出生的时辰。每个柱的干支组合都会对个人的命运产生影响。天干地支旁边标注的正财、偏财、偏印、正印、比肩、劫财、食神、伤官、正官、七杀等,称为十神。 2、八字排盘软件介绍 我们是腾讯云市场金牌合作伙伴,广州正规软件开发公司,开发的八字排盘系统数据最全面精准,我们八字排盘采用最精确的排盘程序,而且运用“真太阳时”,进行更精确的时间划分。大家都知道我们使用的北京时间,是统一规定的标准时间。而八字排盘需要相对于太阳方位的天文时间,即平太阳时。我们国家地大物博,北京时间19时,哈尔滨已经夜幕降临,而新疆却还是太阳高挂,这时哈尔滨的天文时间可能在20:00以后,而新疆的天文时间可能在16时以前。北京时间是东经120度经线的平太阳时,如果您出生地的经度与北京时间所处的经度差异较大,或者处于单数时间点的前后,比如6点差一刻,8点,10点15分等

27,582

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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