能夠使用 ORACLE TRUNC()函數 來進行判斷 表 A 日期字段 datetime 部分數據帶時分秒,部分數據沒有時分秒 select * from A where datetime = TRUNC(datetime) --不包含時分秒 select * from A where datetime <> TRUNC(datetime) --包含時分秒 也能夠用 TRUNC() 函數來更新數據. TRUNC():相似截取函數,按指定的格式截取輸入的數據。 1.【trunc(for dates)】TRUNC()函數處理日期 語法格式:TRUNC(date[,fmt]) 其中:date 一個日期值;fmt 日期格式。 該日期將按指定的日期格式截取;忽略它則由最近的日期截取。 示例: select trunc(sysdate) from dual;--2017/2/13,返回當前時間 select trunc(sysdate,'yy') from dual;--2017/1/1,返回當年第一天 select trunc(sysdate,'mm') from dual;--2017/2/1,返回當月的第一天 select trunc(sysdate,'d') from dual;--2017/2/12,返回當前星期的第一天,即星期天 select trunc(sysdate,'dd') from dual;--2017/2/13,返回當前日期,今天是2017/2/13 select trunc(sysdate ,'HH24') from dual;--2017/2/13 15:00:00,返回本小時的開始時間 select trunc(sysdate ,'MI') from dual;--2017/2/13 15:13:00,返回本分鐘的開始時間 2.【TRUNC(for number)】TRUNC()函數處理number型數字 語法格式:TRUNC(number[,decimals]) 其中: number 待作截取處理的數值;decimals 指明需保留小數點後面的位數,可選項,忽略它則截去全部的小數部分。 注意:截取時並不對數據進行四捨五入。 示例: select trunc(123.567,2) from dual;--123.56,將小數點右邊指定位數後面的截去; select trunc(123.567,-2) from dual;--100,第二個參數能夠爲負數,表示將小數點左邊指定位數後面的部分截去,即均以0記; select trunc(123.567) from dual;--123,默認截去小數點後面的部分;