SET DATEFORMAT对日期处理的影响

--1. /*--说明
    SET DATEFORMAT设置对使用CONVERT把字符型日期转换为日期的处理也具有影响
    但不影响明确指定了style的CONVERT处理。
--
*/

--示例 ,在下面的示例中,第一个CONVERT转换未指定style,转换的结果受SET DATAFORMAT的影响,第二个CONVERT转换指定了style,转换结果受style的影响。
--
设置输入日期顺序为 日/月/年
SET DATEFORMAT DMY

--不指定Style参数的CONVERT转换将受到SET DATEFORMAT的影响
SELECT CONVERT(datetime,'2-1-2005')
--结果: 2005-01-02 00:00:00.000

--指定Style参数的CONVERT转换不受SET DATEFORMAT的影响
SELECT CONVERT(datetime,'2-1-2005',101)
--结果: 2005-02-01 00:00:00.000
GO

--2.
/*
--说明

    如果输入的日期包含了世纪部分,则对日期进行解释处理时
    年份的解释不受SET DATEFORMAT设置的影响。
--
*/

--示例,在下面的代码中,同样的SET DATEFORMAT设置,输入日期的世纪部分与不输入日期的世纪部分,解释的日期结果不同。
DECLARE @dt datetime

--设置SET DATEFORMAT为:月日年
SET DATEFORMAT MDY

--输入的日期中指定世纪部分
SET @dt='01-2002-03'
SELECT @dt
--结果: 2002-01-03 00:00:00.000

--输入的日期中不指定世纪部分
SET @dt='01-02-03'
SELECT @dt
--结果: 2003-01-02 00:00:00.000
GO

--3.
/*
--说明

    如果输入的日期不包含日期分隔符,那么SQL Server在对日期进行解释时
    将忽略SET DATEFORMAT的设置。
--
*/

--示例,在下面的代码中,不包含日期分隔符的字符日期,在不同的SET DATEFORMAT设置下,其解释的结果是一样的。
DECLARE @dt datetime

--设置SET DATEFORMAT为:月日年
SET DATEFORMAT MDY
SET @dt='010203'
SELECT @dt
--结果: 2001-02-03 00:00:00.000

--设置SET DATEFORMAT为:日月年
SET DATEFORMAT DMY
SET @dt='010203'
SELECT @dt
--结果: 2001-02-03 00:00:00.000

--输入的日期中包含日期分隔符
SET @dt='01-02-03'
SELECT @dt
--结果: 2003-02-01 00:00:00.000

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
import java.sql.Timestamp; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; import java.util.GregorianCalendar; import org.apache.commons.lang.StringUtils; /** * 日付に関するユーティリティクラス * */ public class DateUtil { /** * 年月日時のフォーマット(年月日) */ public static final String YYYYMMDD = "yyyyMMdd"; /** * 年月日時のスラッシュ入りフォーマット(年/月/日) */ public static final String YYYYMMDD_SLASH = "yyyy/MM/dd"; /** * 年月のスラッシュ入りフォーマット(年/月) */ public static final String YYYYMM_SLASH = "yyyy/MM"; /** * 年月日時の中間線入りフォーマット(年-月-日) */ public static final String YYYYMMDD_MID_LINE = "yyyy-MM-dd"; /** * 年月のスラッシュ入りフォーマット(年-月) */ public static final String YYYYMM_MID_LINE = "yyyy-MM"; /** * 年月日時分秒ミリ秒のフォーマット(年月日時分秒ミリ秒) */ public static final String YYYYMMDDHHMMSSSSS = "yyyyMMddHHmmssSSS"; /** * 年月日時分秒ミリ秒のフォーマット(年-月-日 時:分:秒) */ public static final String YYYYMMDDHHMMSS_MID_LINE = "yyyy-MM-dd HH:mm:ss"; /** * 年月日時分秒ミリ秒のフォーマット(年/月/日 時:分:秒) */ public static final String YYYYMMDDHHMMSS_SLASH = "yyyy/MM/dd HH:mm:ss"; /** * コンストラクタ */ private DateUtil() { // 何もしない } /** * システム日時を取得する * * @return システム日時 */ public static Date getSystemDate() { return new Date(); } /** * システム日時をTimestampオブジェクトで返却する * * @return Timestampオブジェクト */ public static Timestamp getTimestamp() { return toTimestamp(getSystemDate()); } /** * 指定するフォーマットのシステム日時を取得する * (2008年3月22日15時30分 → 2008-03-22 (format = "yyyy-MM-dd")) * @param format * 指定するフォーマット * @return システム日時 */ public static String getCurrentTime(String format) { return formatDateToStr(getSystemDate(), format); } /** * 現在の月を取得する * * @return 現在の月 */ public static String getCurentMonth() { SimpleDateFormat format = new SimpleDateFormat("MM"); return format.format(getSystemDate()); } /** * Nヶ月後の当月の最初の日を取得する * * @param n * Nヶ月後 * @return Nヶ月後の当月の最初の日 */ public static Calendar getMonthFirstDay(int n) { Calendar cal = Calendar.getInstance(); cal.set(Calendar.DAY_OF_MONTH, 1); cal.add(Calendar.MONTH, n); cal.set(Calendar.HOUR_OF_DAY, 0); cal.set(Calendar.MINUTE, 0); cal.set(Calendar.SECOND, 0); return cal; } /** * Nヶ月後の当月の最後の日を取得する * * @param n * Nヶ月後 * @return Nヶ月後の当月の最後の日 */ public static Calendar getMonthlastDay(int n) { Calendar cal = Calendar.getInstance(); cal.set(Calendar.DAY_OF_MONTH, 1); cal.add(Calendar.MONTH, n + 1); cal.add(Calendar.DATE, -1); cal.set(Calendar.HOUR_OF_DAY, 23); cal.set(Calendar.MINUTE, 59); cal.set(Calendar.SECOND, 59); return cal; } /** * 获得与某日期相隔几天的日期 * * @param date * 指定する日付 * @param addCount * 離れた日数 * @return 処理後の日付 */ public static Date addDay(Date date, int addCount) { if (date == null) { return null; } Calendar calendar = Calendar.getInstance(); calendar.setTime(date); calendar.add(Calendar.DATE, addCount); return calendar.getTime(); } /** * 获得与某日期相隔几天的日期 * * @param date * 指定する日付 * @param addCount * 離れた月数 * @return 処理後の日付 */ public static Date addMonth(Date date, int addCount) { if (date == null) { return null; } Calendar calendar = Calendar.getInstance(); calendar.setTime(date); calendar.add(Calendar.MONTH, addCount); return calendar.getTime(); } /** * DateオブジェクトをTimestampオブジェクトに変換する。 * * @param date * Dateオブジェクト * @return Timestamp オブジェクト */ public static Timestamp toTimestamp(Date date) { if (date == null) { return null; } return new Timestamp(date.getTime()); } /** * Dateオブジェクトを指定の形式でフォーマットする。 * 例:'yyyy年M月d日 h時m分' * @param date * Dateオブジェクト * @param dateFormat * Dateフォーマット * @return フォーマットされた文字列 */ public static String formatDateToStr(Date date, String dateFormat) { if (date == null) { return ""; } return getFormatter(dateFormat).format(date); } /** * 将某个日期格式字符串转换成另一指定格式日期字符串 例:传入"2009/1/15 16:58:00","yyyy/MM/dd * hh:mm:ss","yyyy年M月d日 a h时m分s秒" 则返回 “2009年1月15日 下午 4时58分0秒” * * @param dateStr * 指定する日付 * @param inDateFormat * 传入日期字符串的日期格式 * @param outDateFormat * 传出日期字符串的日期格式 * @return 返回指定格式的日期字符串 */ public static String formatDateToStr(String dateStr, String inDateFormat, String outDateFormat) { SimpleDateFormat simpleDateFormat = null; String str = ""; Date date = null; try { simpleDateFormat = getFormatter(inDateFormat); date = simpleDateFormat.parse(dateStr); simpleDateFormat.applyPattern(outDateFormat); return simpleDateFormat.format(date); } catch (Exception e) { return str; } } /** * 将字符串转化为格式为formmat 的日期格式返回 * * @param date * 待转换的日期 * @param formmat * 转换的format * @return 转换后的日期 */ public static Date stringToFormatDate(String date, String formmat) { try{ return getFormatter(formmat).parse(date); }catch(Exception e){ return null; } } /** * 日付の正確性チェック * * @param * dateStr 日期パラメータ * @param * format 日期フォーマット * @return 正しい:true 違い:false */ public static boolean isValidDate (String dateStr, String format) { try { getFormatter(format).parse(dateStr); return true; } catch (Exception e) { return false; } } /** * タイムの有効性チェック * * @param dateStr * タイム * @return 有効:true 無効:false */ public static boolean isValidTime (String dateStr) { boolean reval = false; if (!StringUtils.isBlank(dateStr)) { if (dateStr.length() == 4) { try { Integer.parseInt(dateStr); int hour = Integer.parseInt(dateStr.substring(0, 2)); int min = Integer.parseInt(dateStr.substring(2, 4)); if (hour <= 23 && hour >= 0 && min <= 59 && min >= 0) { return true; } } catch (Exception e) { } } } return reval; } /** * 根据输入的日期计算年龄 * * @param birthday 出生日期 格式:yyyy-MM-dd * @return String 年龄(周岁年龄) * */ public static String getAge(String birthday){ if (StringUtils.isBlank(birthday)) { return "0"; } Calendar birthdays = Calendar.getInstance(); try { birthdays.setTime(getFormatter(YYYYMMDD_MID_LINE).parse(birthday)); } catch (ParseException e) { return "0"; } Calendar today = new GregorianCalendar(); int age = today.get(Calendar.YEAR) - birthdays.get(Calendar.YEAR); birthdays.add(Calendar.YEAR, age); if (today.before(birthdays)) { age--; } return String.valueOf(age); } /** * 二つの日付の差を計算する *@param date1 計算日付1 *@param date2 計算日付2 * @return int 日付の差 */ public static int getDateDiffDays(Date date1 ,Date date2) { int retValue = 0; if (date1 != null && date2 != null) { long dateDiff = date1.getTime() - date2.getTime(); retValue = (int)(dateDiff/(24 * 60 * 60 * 1000)); } return retValue; } /** * 得到具体某个月的天数 * @throws ParseException */ public static int getDaysOfMonth(String year, String month) throws ParseException{ String datestr = year + "/" + month; Calendar cal = Calendar.getInstance(); SimpleDateFormat dateFormat = getFormatter(YYYYMM_SLASH); cal.setTime(dateFormat.parse(datestr)); int daysOfMonth = cal.getActualMaximum(Calendar.DAY_OF_MONTH); return daysOfMonth; } /** * 获取一个简单的日期格式化对象 * @param format * @return */ private static SimpleDateFormat getFormatter(String format) { return new SimpleDateFormat(format); } }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值