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

char类型字段sql求差

发布时间: 2022-08-22 22:10:34

sql server2000,如何对时间是char类型的数据进行 加减

首先 201702 即使是char型也不是一个完整地可以转化成日期型的格式,至少需要年月日三段

--(1)把你的char补充成完整地日期格式char,我在后面补充01,这样20170201就是可转换--的格式
select'201702'+'01'
--(2)转换成日期型,用cast方法
selectcast('201702'+'01'assmalldatetime)
--这样就成时间类型了,然后你进行日期加减计算,用dateadd
selectdateadd(mm,1,cast('201702'+'01'assmalldatetime))
--dateadd这个函数第一个参数是单位,year年,mm月,day是日,mi分钟,ss秒
--第二个参数是数量,例子是1,就是加1个月
--第三个参数就是要变化的时间

Ⅱ SQL中字段类型为char值,如何进行大小比较

select top 1 * from 表名 order by 班级+0 desc

Ⅲ sqlchar和 char类型的 字符串怎么比较

unsigned char s[50]="abc\0";
试试看
另外你可以看看strcmp的返回是+1还是-1来判断两个字符的关系

Ⅳ sql server语句怎么实现两个字符型相减

相减只有数字类型或日期类型可以操作,如果两个字符型字段存储的是数字或者日期格式的内容,可对两个字段进行转换,然后再作相减操作;

如:两个字符型(数字)的字段

ID1 ID2

1 2

2 4

执行语句:

selectcast(ID2asint)-cast(ID1asint)fromtablename;

如:两个字符型(日期)的字段

DATE1 DATE2

2015-08-01 2015-09-01

2015-07-01 2015-10-01

执行语句:

selectcast(DATE2asdatetime)-cast(DATE1asdatetime)fromtablename;

Ⅳ SQL语言中CHAR的用法

char会自动填充空格,varchar不会。所以varchar比较节省空间,但是检索效率char高一点。用法不存在什么区别。
举个例子吧
字段a为char(5)类型
字段b为varchar(5)类型
向a,b中赋值'123'
a的结果是'123
'
(123+两个空格)
b的结果是'123'

Ⅵ ORACEL sql语句 两时间字段求差

两个Date类型字段:START_DATE,END_DATE,计算这两个日期的时间差(分别以天,小时,分钟,秒,毫秒):

天:

ROUND(TO_NUMBER(END_DATE - START_DATE))

小时:

ROUND(TO_NUMBER(END_DATE - START_DATE) * 24)

分钟:

ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60)

秒:

ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60)

毫秒:

ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60 * 1000)

Oracle计算时间差函数 2008-08-20 10:00 两个Date类型字段:START_DATE,END_DATE,计算这两个日期的时间差(分别以天,小时,分钟,秒,毫秒): 天: ROUND(TO_NUMBER(END_DATE - START_DATE)) 小时: ROUND(TO_NUMBER(END_DATE - START_DATE) * 24) 分钟: ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60) 秒: ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60) 毫秒: ROUND(TO_NUMBER(END_DATE - START_DATE) * 24 * 60 * 60 * 1000)

外加to_date与to_char函数:

ORACLE中:
select to_date('2007-06-28 19:51:20','yyyy-MM-dd HH24:mi:ss') from al;
一般SQL中:
select to_date('2007-06-28 19:51:20','yyyy-MM-dd HH:mm:ss') from al;
区别:
1、HH修改为HH24。
2、分钟的mm修改为mi。

24 小时的形式显示出来要用 HH24

select to_char(sysdate,'yyyy-MM-dd HH24:mi:ss') from al;

select to_date('2005-01-01 13:14:20','yyyy-MM-dd HH24:mi:ss') from al;

to_date() function

1. 日期格式参数 含义说明

D 一周中的星期几

DAY 天的名字,使用空格填充到 9 个字符

DD 月中的第几天

DDD 年中的第几天

DY 天的简写名

IW ISO 标准的年中的第几周

IYYY ISO 标准的四位年份

YYYY 四位年份

YYY,YY,Y 年份的最后三位,两位,一位

HH 小时,按 12 小时计

HH24 小时,按 24 小时计

MI 分

SS 秒

MM 月

Mon 月份的简写

Month 月份的全名

W 该月的第几个星期

WW 年中的第几个星期 1. 日期时间间隔操作

当前时间减去 7 分钟的时间

select sysdate,sysdate - interval '7' MINUTE from al

当前时间减去 7 小时的时间

select sysdate - interval '7' hour from al

当前时间减去 7 天的时间

select sysdate - interval '7' day from al

当前时间减去 7 月的时间

select sysdate,sysdate - interval '7' month from al

当前时间减去 7 年的时间

select sysdate,sysdate - interval '7' year from al

时间间隔乘以一个数字

select sysdate,sysdate - 8 *interval '2' hour from al

2. 日期到字符操作

select sysdate,to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from al

select sysdate,to_char(sysdate,'yyyy-mm-dd hh:mi:ss') from al

select sysdate,to_char(sysdate,'yyyy-ddd hh:mi:ss') from al

select sysdate,to_char(sysdate,'yyyy-mm iw-d hh:mi:ss') from al

参考 oracle 的相关关文档 (ORACLE901DOC/SERVER.901/A90125/SQL_ELEMENTS4.HTM#48515)

3. 字符到日期操作

select to_date('2003-10-17 21:15:37','yyyy-mm-dd hh24:mi:ss') from al

具体用法和上面的 to_char 差不多。

4.TO_NUMBER
使用TO_NUMBER函数将字符转换为数字
TO_NUMBER(char[, '格式'])

数字格式格式
9 代表一个数字
0 强制显示0
$ 放置一个$符
L 放置一个浮动本地货币符
. 显示小数点
, 显示千位指示符

oracle中的to_date参数含义

1.日期格式参数含义说明
D 一周中的星期几
DAY 天的名字,使用空格填充到9个字符
DD 月中的第几天
DDD 年中的第几天
DY 天的简写名
IW ISO标准的年中的第几周
IYYY ISO标准的四位年份
YYYY 四位年份
YYY,YY,Y 年份的最后三位,两位,一位
HH 小时,按12小时计
HH24 小时,按24小时计
MI 分
SS 秒
MM 月
Mon 月份的简写
Month 月份的全名
W 该月的第几个星期
WW 年中的第几个星期 1.日期时间间隔操作
当前时间减去7分钟的时间
select sysdate,sysdate - interval ’7’ MINUTE from al
当前时间减去7小时的时间
select sysdate - interval ’7’ hour from al
当前时间减去7天的时间
select sysdate - interval ’7’ day from al
当前时间减去7月的时间
select sysdate,sysdate - interval ’7’ month from al
当前时间减去7年的时间
select sysdate,sysdate - interval ’7’ year from al
时间间隔乘以一个数字
select sysdate,sysdate - 8 *interval ’2’ hour from al
2.日期到字符操作
select sysdate,to_char(sysdate,’yyyy-mm-dd hh24:mi:ss’) from al
select sysdate,to_char(sysdate,’yyyy-mm-dd hh:mi:ss’) from al
select sysdate,to_char(sysdate,’yyyy-ddd hh:mi:ss’) from al
select sysdate,to_char(sysdate,’yyyy-mm iw-d hh:mi:ss’) from al
参考oracle的相关关文档(ORACLE901DOC/SERVER.901/A90125/SQL_ELEMENTS4.HTM#48515)
3. 字符到日期操作
select to_date(’2003-10-17 21:15:37’,’yyyy-mm-dd hh24:mi:ss’) from al
具体用法和上面的to_char差不多。
4. trunk/ ROUND函数的使用
select trunc(sysdate ,’YEAR’) from al
select trunc(sysdate ) from al
select to_char(trunc(sysdate ,’YYYY’),’YYYY’) from al
5.oracle有毫秒级的数据类型
--返回当前时间 年月日小时分秒毫秒
select to_char(current_timestamp(5),’DD-MON-YYYY HH24:MI:SSxFF’) from al;
--返回当前时间的秒毫秒,可以指定秒后面的精度(最大=9)
select to_char(current_timestamp(9),’MI:SSxFF’) from al;
6.计算程序运行的时间(ms)
declare
type rc is ref cursor;
l_rc rc;
l_mmy all_objects.object_name%type;
l_start number default dbms_utility.get_time;
begin
for I in 1 .. 1000 loop
open l_rc for 'select object_name from all_objects '|| 'where object_id = ' || i;
fetch l_rc into l_mmy;
close l_rc;
end loop;
dbms_output.put_line ( round( (dbms_utility.get_time-l_start)/100, 2 ) ||' seconds ...' );
end;

Ⅶ sql中有两列,都是char(12),求时间差问题,精确到间隔多少分钟求大侠帮忙

转换时间可以用convert 或cast ,不过你目前的格式不能直接转换为datetime,所以要先将你的栏位值转换成有效的日期格式
转换时可以下如
CONVERT(datetime,LEFT(A,8) + ' ' + substring(A,9,2) + ':' +right(A,2))
CONVERT(datetime,LEFT(B,8) + ' ' + substring(B,9,2) + ':' +right(B,2))
计算两日期时间差可以使用datediff函数,可指定时,分,秒,月,日,年等
如datediff(mi,sdate,edate)
如果你要直接得出A,B的时候差,可用如下写法
select datediff(mi,CONVERT(datetime,LEFT(A,8) + ' ' + substring(A,9,2) + ':' +right(A,2)),CONVERT(datetime,LEFT(B,8) + ' ' + substring(B,9,2) + ':' +right(B,2))) as 差异分钟数 from demo where ....

Ⅷ SQL2005中字段值char类型的问题

一般对数据结构没有特殊要求的话,字符(包括特殊字符)都是用varchar(50),50表示最大长度,如果还是不够用就选varchar(max),用起来都是没有问题的。

Ⅸ SQL中计算两列之间相差的天数,注意:列数据类型为:CHAR非日期型

select to_date(日期1,'yyyy-mm-dd') - to_date(日期2,'yyyy-mm-dd') from al;

Ⅹ SQL数据库中字符串与char数据类型的比较

别听别人瞎说,这就是varchar和char的区别当定义了char的长度后如果长度不够则会自动用空字符补全,而varchar则没事如果是18位的你查询的时候用你的18位加一个空格就能查出来了,不过一般用char类型的,长度都是固定的,毕竟补全空格比较麻烦,所以数据类型要谨慎使用