Ⅰ 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類型的,長度都是固定的,畢竟補全空格比較麻煩,所以數據類型要謹慎使用