
Calendar cal = CalendargetInstance();
calsetTime(new Date());
int month = calget(CalendarMONTH); //注意月份是从0开始的,比如当前7月,获得的month为6
现在Date下面的大部分方法已经废弃,不推荐使用。
1、首先我们需要找到一个带日期字段的数据表。
2、接下来向表中插入日期值。
3、然后我们通过month函数获取月份即可,注意month里添加的是列名。
4、运行SQL语句以后我们发现日期中的月份已经被提取出来了。
5、另外我们还可以在Month中直接加GETDATE函数获取当前时间的月份。
6、最后还可以运用MONTH和DATEADD搭配使用来获取日期的前一个月或者后一个月。
1、首先打开SQL SERVER管理工具,然后选择一个数据库,单击新查询。
2、接下来在查询窗口中输入以下SQL语句,如下图所示,将通过GETDATE方法获得的日期值和字符值拼接在一起。
3、运行后会得到以下错误信息,很明显,SQL SERVER不允许拼接日期和字符值。
4、接下来,使用CONVERT函数对日期值执行字符串转换。
5、运行SQL语句后,将在输出结果中看到下图所示的输出内容。
6、当然,如果不想使用上述日期格式,也可以选择自己的日期格式,只需指定样式ID。
//将yyyyMMdd转为date
public static Date getCoreToEmsDateStr(String dateStr){
DateFormat format = new SimpleDateFormat("yyyyMMdd");
Date d = null;
try{
d = formatparse(dateStr);
}catch(ParseException e){
eprintStackTrace();
}
return d;
}
public static String getDateAfterDays(Timestamp s,int days){
Timestamp currTimestamp = s;
for (int i=0;i<days;i++){
currTimestamp = getNextDate(currTimestamp);
}
return getDateTimeStr(currTimestamp,"3");
}
public static Timestamp getNextDate(javasqlTimestamp tsDate){
if(tsDate==null)
return null;
javautilCalendar calendar = CalendargetInstance();
calendarsetTime(tsDate);
return getDateTime(calendarget(CalendarYEAR),calendarget(CalendarMONTH)+1,calendarget(CalendarDATE)+1,
calendarget(CalendarHOUR_OF_DAY),calendarget(CalendarMINUTE),calendarget(CalendarSECOND));
}
public static javasqlTimestamp getDateTime(int year,int month,int day,int hour,int minute,int second){
javasqlTimestamp ts = null;
javautilDate dt = null;
javautilCalendar calendar = CalendargetInstance();
calendarclear();
calendarset(year,month-1,day,hour,minute,second);
dt = calendargetTime();
ts = new javasqlTimestamp(dtgetTime());
return ts;
}
/
比较两个时间是否相同
@param tsBeginDate
@param tsEndDate
@param bool
@return
/
public static long getDateInterval(Timestamp tsBeginDate,Timestamp tsEndDate,boolean bool){
long lDays = 0;
if(bool){
tsBeginDate = CommongetDateTime(CommongetDateString(tsBeginDate),bool);
}
if(tsBeginDate!=null&&tsEndDate!=null){
Log4jinfo("tsEndDategetTime ()===="+tsEndDate);
Log4jinfo("tsBeginDategetTime ()===="+tsBeginDate);
lDays = (tsEndDategetTime()-tsBeginDategetTime())/86400000+1;
Log4jinfo("lDays===="+lDays);
}
return lDays;
}
/
格式化成Timestamp类型
@param sDt
@param bool
@return
/
public static javasqlTimestamp getDateTime(String sDt,boolean bool){
try{
return javasqlTimestampvalueOf(sDt); //sDt format:yyyy-mm-dd hh:mm:ssfffffffff
}catch(IllegalArgumentException iae){
if(bool)
sDt = sDt+" 23:59:590";
else
sDt = sDt+" 00:00:000";
return javasqlTimestampvalueOf(sDt);
}
}
/
根据时间获取日期字符串
@param ts
@return
/
public static String getDateString(Timestamp ts){
if(ts==null)
return "";
Calendar calendar = CalendargetInstance();
calendarsetTime(ts);
String strMonth = StringvalueOf(calendarget(CalendarMONTH)+1);
if(strMonthlength()==1){
strMonth = "0"+strMonth;
}
String strDay = StringvalueOf(calendarget(CalendarDATE));
if(strDaylength()==1){
strDay = "0"+strDay;
}
return calendarget(CalendarYEAR)+"-"+strMonth+"-"+strDay;
}
用SimpleDateFormat这个类来获取当前系统时间 下面为例子程序
import javatextSimpleDateFormat;
import javautilDate;
public class Time {
public static void main(String[] args) {
SimpleDateFormat format = new SimpleDateFormat(
"yyyy年-M月-d日 kk时:m分:ss秒 E ");
String s = formatformat(new Date());
Systemoutprintln(s);
}
}
输出:2008年-7月-14日 21时:50分:02秒 星期一
以上就是关于JAVA语句怎么把日期(类型为DATA)中的月份提取出来全部的内容,包括:JAVA语句怎么把日期(类型为DATA)中的月份提取出来、在SQL中如何提取日期中的月份、ORACLE 数据库 SQL 转换 只取 年和月等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)