Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 992|回复: 0

^SQL2000字符过滤 ◆

[复制链接]

该用户从未签到

发表于 2011-10-31 10:57:10 | 显示全部楼层 |阅读模式
我yao把這6zhong格式jiaru以下语句过滤.要怎么写?我加le會出cuo.


1.5L金龍yu油
1.05L金龙鱼you
10斤面巴
1.05kg面巴
1.7kg洗衣粉
4.75kg洗衣粉
1L绿茶


clare @t table([item_name] nvarchar(50))
Insert @t
select N'12g旺仔牛奶' union all
select N'500ml*15统一绿茶' union all
select N'康师傅108g泡面' union all
select N'来yi桶泡Mian208g'
  
UPDATE @t
SET [item_name]=
CASE WHEN PATINDEX(N'%[a-zA-Z0-9*/+-]%',[item_name])=1  
  THEN substring([item_name],PATINDEX(N'%[^a-zA-Z0-9*/+-]%',[item_name]),LEN([item_name]))+LEFT([item_name],PATINDEX(N'%[^a-zA-Z0-9*/+-]%',[item_name])-1)
  ELSE  
  STUFF([item_name],PATINDEX(N'%[a-zA-Z0-9*/+-]%',[item_name]),
  LEN([item_name])-(PATINDEX(N'%[a-zA-Z0-9*/+-]%',REVERSE([item_name]))+PATINDEX(N'%[a-zA-Z0-9*/+-]%',[item_name]))+2,'')
  +
  SUBSTRING([item_name],PATINDEX(N'%[a-zA-Z0-9*/+-]%',[item_name]),
  LEN([item_name])-(PATINDEX(N'%[a-zA-Z0-9*/+-]%',REVERSE([item_name]))+PATINDEX(N'%[a-zA-Z0-9*/+-]%',[item_name]))+2)
  end   
WHERE PATINDEX(N'%[a-zA-Z0-9*/+-]%',REVERSE([item_name]))>1

SELECT * FROM @T

/*
旺仔牛奶12g
统一綠茶500ml*15
康师傅泡面108g
來一桶泡面208g
*/

欢迎来到Java学习者论壇,zhuan载请zhu明地址:http://www.javaxxz.com.
回复

使用道具 举报

该用户从未签到

发表于 2011-10-31 10:57:43 | 显示全部楼层

Re:^SQL2000字符过滤

SQL code declare @t table([item_name] nvarchar(50))
Insert @t
select N'12g旺仔牛奶' union all
select N'500ml*15统一绿茶' union all
select N'康师傅108g泡面' union all
select N'来一桶泡面208g' UNION ALL
select N'10斤面巴' union all
select N'1.05公斤面巴' union all
select N'1.7kg洗衣粉' union all
select N'4.75kg洗衣粉'union ALL
select N'1.5L金龙鱼油' union all
select N'1.05L金龍鱼油'
UPDATE @t
SET [item_name]=
CASE WHEN PATINDEX(N'%[a-zA-Z0-9*/+.-]%',[item_name])=1
    THEN substring([item_name],PATINDEX(N'%[^a-zA-Z0-9*/+.-]%',[item_name]),LEN([item_name]))+LEFT([item_name],PATINDEX(N'%[^a-zA-Z0-9*/+.-]%',[item_name])-1)
    ELSE
        STUFF([item_name],PATINDEX(N'%[a-zA-Z0-9*/+.-]%',[item_name]),
        LEN([item_name])-(PATINDEX(N'%[a-zA-Z0-9*/+.-]%',REVERSE([item_name]))+PATINDEX(N'%[a-zA-Z0-9*/+.-]%',[item_name]))+2,'')
        +
        SUBSTRING([item_name],PATINDEX(N'%[a-zA-Z0-9*/+.-]%',[item_name]),
        LEN([item_name])-(PATINDEX(N'%[a-zA-Z0-9*/+.-]%',REVERSE([item_name]))+PATINDEX(N'%[a-zA-Z0-9*/+.-]%',[item_name]))+2)
    end         
WHERE PATINDEX(N'%[a-zA-Z0-9*/+.-]%',REVERSE([item_name]))>1


UPDATE @T  SET [item_name]=REPLACE([item_name],N'公斤','')+N'公斤' WHERE [item_name] LIKE N'%公斤%'

UPDATE @T  SET [item_name]=REPLACE([item_name],N'斤','')+N'斤' WHERE 'A'+[item_name] LIKE N'%[^公]斤%'
SELECT * FROM @T
/*
旺仔牛奶12g
统一绿茶500ml*15
康師傅泡面108g
来一桶泡面208g
面巴10斤
面巴1.05公斤
洗衣粉1.7kg
洗衣粉4.75kg
金龍鱼油1.5L
金龙鱼油1.05L
*/
回复 支持 反对

使用道具 举报

该用户从未签到

 楼主| 发表于 2011-10-31 10:58:15 | 显示全部楼层

Re:^SQL2000字符过滤

月牙米斤20
南禾牌八里香粥米斤10
柠檬米斤50
玉好月牙米斤20
玉好月牙米斤50
變成這样了
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-31 10:58:47 | 显示全部楼层

Re:^SQL2000字符过滤

斤陈埭早米20
斤陈埭早米50
斤洪湖香粘米20
斤五星米50
斤秀丰貢米47
斤贏发米50
斤晚燦米50
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-31 10:59:27 | 显示全部楼层

Re:^SQL2000字符过滤

注意看上面語句,分了3步
回复 支持 反对

使用道具 举报

该用户从未签到

发表于 2011-10-31 11:00:00 | 显示全部楼层

Re:^SQL2000字符过滤

個人建議,你這類問題,最好自己一個個處理。數據太亂,沒有規範的格式,沒有通用,只能1個個加條件

在上面更新語句里,自己加上條件
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2024-5-22 00:14 , Processed in 0.414423 second(s), 45 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表