Ⅰ 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类型的,长度都是固定的,毕竟补全空格比较麻烦,所以数据类型要谨慎使用