当前位置:首页 » 编程语言 » sql怎么取数字前4位数
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

sql怎么取数字前4位数

发布时间: 2023-03-25 03:51:07

A. 在sql语句中如何用正则取出一个字符串的前几位数字

  1. SQL 取字符串的前几位数字,SQL 关键字 substring

  2. substring 使用方法,参考下列SQL:

  3. declare @T nvarchar(10)

  4. set @T='12345abcde'

  5. select substring(@T,1,5)

  6. 结果如下:12345

  7. 如果是SQL 写正则表达式判断,只能通过存储过程或函数来处理

  8. SQL 如下:

  9. CREATE FUNCTION dbo.find_regular_expression
    (
    @source varchar(5000), --需要匹配的源字符串
    @regexp varchar(1000),--正则表达式
    @ignorecase bit = 0--是否区分大小写,默认为false
    )
    RETURNS bit--返回结果0-false,1-true
    AS
    BEGIN
    --0(成功)或非零数字(失败),是由 OLE 自动化对象返回的 HRESULT 的整数值。
    DECLARE @hr integer
    --用于保存返回的对象令牌,以便之后对该对象进行操作
    DECLARE @objRegExp integer DECLARE @objMatches integer
    --保存结果
    DECLARE @results bit

    /*
    创建 OLE 对象实例,只有 sysadmin 固定服务器角色的成员才能执行 sp_OACreate,

    并确定机器中有VBScript.RegExp类库
    */
    EXEC @hr = sp_OACreate 'VBScript.RegExp', @objRegExp OUTPUT
    IF @hr <> 0 BEGIN
    SET @results = 0
    RETURN @results
    END
    /*
    以下三个分别是设置新建对象的三个属性。下面是'VBScript.RegExp'中常用的属性举例:
    Dim regEx,Match,Matches '建立变量。
    Set regEx = New RegExp '建立一般表达式。
    regEx.Pattern= patrn '设置模式。
    regEx.IgnoreCase = True '设置是否区分大小写。
    regEx.Global=True '设置全局可用性。
    set Matches=regEx.Execute(string) '重复匹配集合
    RegExpTest = regEx.Execute(strng) '执行搜索。
    for each match in matches '重复匹配集合
    RetStr=RetStr &"Match found at position "
    RetStr=RetStr&Match.FirstIndex&".Match Value is '"
    RetStr=RetStr&Match.Value&"'."&vbCRLF Next
    RegExpTest=RetStr
    */
    EXEC @hr = sp_OASetProperty @objRegExp, 'Pattern', @regexp
    IF @hr <> 0 BEGIN
    SET @results = 0
    RETURN @results
    END
    EXEC @hr = sp_OASetProperty @objRegExp, 'Global', false
    IF @hr <> 0 BEGIN
    SET @results = 0
    RETURN @results
    END
    EXEC @hr = sp_OASetProperty @objRegExp, 'IgnoreCase', @ignorecase
    IF @hr <> 0 BEGIN
    SET @results = 0
    RETURN @results
    END
    --调用对象方法
    EXEC @hr = sp_OAMethod @objRegExp, 'Test', @results OUTPUT, @source
    IF @hr <> 0 BEGIN
    SET @results = 0
    RETURN @results
    END
    --释放已创建的 OLE 对象
    EXEC @hr = sp_OADestroy @objRegExp
    IF @hr <> 0 BEGIN
    SET @results = 0
    RETURN @results
    END
    RETURN @results
    END

B. sql取特定字符的前面几位字符

MSSQL的就用这个吧,直接可以查询出来
SELECT LEFT(MB002,PATINDEX('%-%',STUFF(MB002,PATINDEX('%-%',MB002),1,'*'))-1) FROM 表名

C. sql2005 查询表中某个字段的的前4位

Num列是什么类型的呢?如果是bigint类型,效率最高的方法是用between来确定数值范围
SELECT * FROM tableA WHERE Num BETWEEN 230100000000 AND 2301999999999
也可以通过其它方法,但是如果Num列上有索引,进行算数运算的话就不能使用索引快速检索数据了。

D. SQL 有没一种方法 可以把 6位数 后两位 去掉 只取前4 位

SQL里面不叫方法,叫做函数。可以用substring函数,它的作用是在一个字符串中,从指定位置开始截取多少位,。你要娶前面4位,可以这样:select substring(bbc,1,4) from abc

E. sql如何截取字符串中前面的数字

如果提取字符串中的数字,需要自定义函数,以下函数包含截取字符串中的数字、字母、汉字等。

createfunctionfn_myget
(@strasvarchar(max),
@categoryasvarchar(10)='Chinese',
@startasint=1,
@endasint=100000)
returnsvarchar(max)
as
begin
declare@iint=@start
declare@lenstrint=len(@str)
declare@str1varchar(max)
declare@strrevarchar(max)=''
while@i<=@lenstrand@i<=@end
begin
set@str1=substring(@str,@i,1);
--提取汉字
if(@Category='Chinese')
begin
if(len(@str1)!=datalength(@str1))
set@strre=@strre+@str1
end
--提取字母
elseif(@Category='Letters')
begin
if((ascii(@str1)>=65andascii(@str1)<=90orascii(@str1)>=97andascii(@str1)<=122))
set@strre=@strre+@str1
end
--提取数字
elseif(@Category='Digital')
begin
if(ascii(@str1)>=48andascii(@str1)<=57)
set@strre=@strre+@str1
end
else
set@strre='输入错误'
set@i=@i+1
end
return(@strre)
end

测试:

1、截取字符串dsajf23423423中的数字

selectdbo.fn_myget('dsajf23423423','Digital',1,1000)

结果:

自定义函数说明:

函数共需要4个参数:

第一个参数是要截取的字符串;

第二个参数根据要截取的内容不同,分别有“Digital”(截取数字)、“Letters”(截取字母)、“Chinese”(截取中文);

第三个参数代表截取的起始位;

第四个参数代表截取的截取的结束位。

F. sql 怎么取 字符串的前几位

sql中,使用LEFT函数即可取到字符串的前几位。

LEFT(c, number_of_char)用于返回某个被请求的文本域的左侧部分,其中c代表被请求的文本域,number_of_cha代表需要取出的字符串位数。如“LEFT("..com", 6)”即可取得字符串""。

(6)sql怎么取数字前4位数扩展阅读:

sql中,常用函数介绍:

1、AVG():返回平均值

2、COUNT():返回行数

3、FIRST():返回第一个记录的值

4、LAST():返回最后一个记录的值

5、MAX():返回最大值

6、MIN():返回最小值

7、SUM():返回总和

8、UCASE():将某个字段转换为大写

9、LCASE():将某个字段转换为小写

10、MID():从某个文本字段提取字符

11、LEN():返回某个文本字段的长度

12、ROUND():对某个数值字段进行指定小数位数的四舍五入

13、NOW():返回当前的系统日期和时间

14、FORMAT():格式化某个字段的显示方式

15、INSTR():返回在某个文本域中指定字符的数值位置

16、LEFT():返回某个被请求的文本域的左侧部分

17、RIGHT():返回某个被请求的文本域的右侧部分

G. 如何用sql获取一串数字中的第4位到第八位

这个使用substring ,就可以实现吧!

declare@avarchar(20)
selectsubstring(@a,4,4);--从第四位开始,共截取四位

H. sql怎么取字符串的前几位

sql语句截取字符串前几位语句:
select
substr(cont_no,1,9)
from
for_contract
SUBSTRING
(
expression
,
start
,
length
)
expression:是字符串、二进制字符串、text、image、列或包含列的表达式。不要使用包含聚合函数的表达式。
start:是一个整数,指定子串的开始位置。
length:是一个整数,指定子串的长度(要返回的字符数或字节数)。
eg:select
id
from
users
id的值是001.002$
select
substring(ID,charindex('.',ID)+1,(charindex('$',ID)-charindex('.',ID)-1))
as
idx

I. SQL查询提问:取前四位,并将后面的数据相加~

select substr(b.h_n_subject,0,4) as h_n_subject,
sum(g.h_count) as h_count,
sum(g.h_eval) as h_eval,
sum(g.h_ai) as h_ai
from table
group by h_n_subject

另外,这种取字段前四位并进行判断的设计,在海量数据的时候执行效率会非常低。这是数据库设计不规范导致。为什么你们不把前四位单独作为一个字段 然后后两位作为一个字段,然后两个字段再绑定在一起?

J. sql中对某字段截取前4位后计数

select
d / 100 as 截取前4位后,
count(*) as 各有多少
from

group by
d / 100

如果结果中 d / 100 返回了小数, 例如 1234.56
那么你需要使用一个函数来做 取整的 处理

如果你数据库是 Oracle 或者 DB2, 那么
用 TRUNC ( d / 100 ) 替换掉 d / 100

如果你数据库是 SQL Server
用 ROUND( d / 100 , 0, 1 ) 替换掉 d / 100