當前位置:首頁 » 編程語言 » 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類型的,長度都是固定的,畢竟補全空格比較麻煩,所以數據類型要謹慎使用