我想你的意思应该是要获取2个值,一个开始时间一个结束时间,然后再传值到数据库查询位于这个时间段内的记录吧
前台代码:
<asp:RadioButtonList ID="RadioButtonList1" runat="server">
<asp:ListItem>本日</asp:ListItem>
<asp:ListItem>本周</asp:ListItem>
<asp:ListItem>本月</asp:ListItem>
</asp:RadioButtonList>
<asp:Button ID="Button1" runat="server" onclick="Button1_Click" Text="Button" />
后台代码:
protected void Button1_Click(object sender, EventArgs e)
{
string beginTime="",endTime="";
switch (RadioButtonList1SelectedValue)
{
//本日时间是从当天00:00:00到23:59:59;
case "本日": beginTime = DateTimeNowToString("d") + " 00:00:00"; endTime = DateTimeNowToString("d")+" 23:59:59"; break;
//获取本周时间段,嵌套一个switch语句块,得到本周星期一0点到星期天23点的时间段;
case "本周": switch (DateTimeNowDayOfWeek) //
{
/星期一/case DayOfWeekMonday: beginTime = DateTimeNowToString("d") + " 00:00:00"; endTime = DateTimeNowAddDays(6)ToString("d") + " 23:59:59"; break;
/星期二/case DayOfWeekTuesday: beginTime = DateTimeNowAddDays(-1)ToString("d") + " 00:00:00"; endTime = DateTimeNowAddDays(5)ToString("d") + " 23:59:59"; break;
/星期三/case DayOfWeekWednesday: beginTime = DateTimeNowAddDays(-2)ToString("d") + " 00:00:00"; endTime = DateTimeNowAddDays(4)ToString("d") + " 23:59:59"; break;
//后面周4到周日根据上面计算即可
} break;
//获取本月时间段,开始时间是本月1号,而下个月1号减去1天就是本月最后一天;
case "本月": beginTime = DateTimeNowToString("yyyy-MM") + "-01 00:00:00"; endTime = DateTimeParse(DateTimeNowAddMonths(1)ToString("yyyy-MM") + "-01 00:00:00")AddDays(-1)ToString("d")+" 23:59:59"; break;
}
ResponseWrite("选择的时间段是:" + beginTime + "至" + endTime);//此时beginTime和endTime还是string类型,转换成DateTime类型传值到数据库即可;
}
复制代码
代码如下:
echo
date("Ymd",strtotime("now")),
"\n";
echo
date("Ymd",strtotime("-1
week
Monday")),
"\n";
echo
date("Ymd",strtotime("-1
week
Sunday")),
"\n";
echo
date("Ymd",strtotime("+0
week
Monday")),
"\n";
echo
date("Ymd",strtotime("+0
week
Sunday")),
"\n";
//date('n')
第几个月
//date("w")
本周周几
//date("t")
本月天数
echo
'<br>上周:<br>';
echo
date("Y-m-d
H:i:s",mktime(0,
0
,
0,date("m"),date("d")-date("w")+1-7,date("Y"))),"\n";
echo
date("Y-m-d
H:i:s",mktime(23,59,59,date("m"),date("d")-date("w")+7-7,date("Y"))),"\n";
echo
'<br>本周:<br>';
echo
date("Y-m-d
H:i:s",mktime(0,
0
,
0,date("m"),date("d")-date("w")+1,date("Y"))),"\n";
echo
date("Y-m-d
H:i:s",mktime(23,59,59,date("m"),date("d")-date("w")+7,date("Y"))),"\n";
echo
'<br>上月:<br>';
echo
date("Y-m-d
H:i:s",mktime(0,
0
,
0,date("m")-1,1,date("Y"))),"\n";
echo
date("Y-m-d
H:i:s",mktime(23,59,59,date("m")
,0,date("Y"))),"\n";
echo
'<br>本月:<br>';
echo
date("Y-m-d
H:i:s",mktime(0,
0
,
0,date("m"),1,date("Y"))),"\n";
echo
date("Y-m-d
H:i:s",mktime(23,59,59,date("m"),date("t"),date("Y"))),"\n";
$getMonthDays
=
date("t",mktime(0,
0
,
0,date('n')+(date('n')-1)%3,1,date("Y")));//本季度未最后一月天数
echo
'<br>本季度:<br>';
echo
date('Y-m-d
H:i:s',
mktime(0,
0,
0,date('n')-(date('n')-1)%3,1,date('Y'))),"\n";
echo
date('Y-m-d
H:i:s',
mktime(23,59,59,date('n')+(date('n')-1)%3,$getMonthDays,date('Y'))),"\n";
提倡了一下中文写,
static public void main(String 参数[]){
SimpleDateFormat 格式=new SimpleDateFormat("y年M月d日 E H时m分s秒",LocaleCHINA);
Calendar 日历=CalendargetInstance(LocaleCHINA);
//当前时间,貌似多余,其实是为了所有可能的系统一致
日历setTimeInMillis(SystemcurrentTimeMillis());
Systemoutprintln("当前时间:"+格式format(日历getTime()));
日历set(CalendarDAY_OF_WEEK, CalendarMONDAY);
Systemoutprintln("周一时间:"+格式format(日历getTime()));
}
===========
改到后天测了一下
输出
当前时间:2011年8月31日 星期三 12时32分40秒
周一时间:2011年8月29日 星期一 12时32分40秒
获取本周一
public static Date getNowWeekMonday(Date date) {Calendar cal = CalendargetInstance();
calsetTime(date);
caladd(CalendarDAY_OF_MONTH, -1); //解决周日会出现 并到下一周的情况
calset(CalendarDAY_OF_WEEK, CalendarMONDAY);
303 return calgetTime();
}
获取上周一
public static Date getLastWeekMonday(Date date) {Date a = DateUtilsaddDays(date, -1);
Calendar cal = CalendargetInstance();
calsetTime(a);
caladd(CalendarWEEK_OF_YEAR, -1);// 一周
calset(CalendarDAY_OF_WEEK, CalendarMONDAY);
return calgetTime();
}
获取上周日
public static Date getLastWeekSunday(Date date) {
Date a = DateUtilsaddDays(date, -1);
Calendar cal = CalendargetInstance();
calsetTime(a);
calset(CalendarDAY_OF_WEEK, 1);
return calgetTime();
}
代码里面有用到 lapachecommon-ang包 你需要下载下 就可以使用
这个可以用dwr框架来做,你可以google一下dwr框架,是前台页面通过js直接调用后台方法的轻量级框架。
至于时间算法
1显示本周,那得算出当前周的周一到周7(国外是周日到周六为一周)是几号到几号。 方法是:
private static HashMap<String, String> getWeekByDate() {
HashMap<String, String> dayMap = new HashMap<String, String>();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); // 设置时间格式
Calendar cal = CalendargetInstance();
calsetTime(new Date());
// 判断要计算的日期是否是周日,如果是则减一天计算周六的,否则会出问题,计算到下一周去了
int dayWeek = calget(CalendarDAY_OF_WEEK);// 获得当前日期是一个星期的第几天
if (1 == dayWeek) {
caladd(CalendarDAY_OF_MONTH, -1);
}
Systemoutprintln("要计算日期为:" + sdfformat(calgetTime())); // 输出要计算日期
calsetFirstDayOfWeek(CalendarMONDAY);// 设置一个星期的第一天,按中国的习惯一个星期的第一天是星期一
int day = calget(CalendarDAY_OF_WEEK);// 获得当前日期是一个星期的第几天
caladd(CalendarDATE, calgetFirstDayOfWeek() - day);// 根据日历的规则,给当前日期减去星期几与一个星期第一天的差值
String imptimeBegin = sdfformat(calgetTime());
Systemoutprintln("所在周星期一的日期:" + imptimeBegin);
dayMapput("Monday", imptimeBegin);
caladd(CalendarDATE, 6);
String imptimeEnd = sdfformat(calgetTime());
Systemoutprintln("所在周星期日的日期:" + imptimeEnd);
dayMapput("SunDay", imptimeEnd);
return dayMap;
}
得到了周一和周日具体是那天,直接去数据库查就OK了,怎么查可以去看下SQL里的between关键字
还有一些写不下,追问一下
<php
//这个月的 周日-周六的日期
$year = date("Y");
$month = date("m");
$days = date("t");
for ($i=0; $i < $days; $i++) {
$day = $year'-'$month'-'$i;
$w = date('w',strtotime($day));
if ($w == 6 || $w ==0) {
echo $day' 是周末<br />';
}
}
><php
//这个周的 周日-周六的日期
$year = date("Y");
$month = date("m");
$days = date("t");
$hao = date('j');
for ($i=$hao; $i < ($hao+7); $i++) {
$day = $year'-'$month'-'$i;
$w = date('w',strtotime($day));
if ($w == 6 || $w ==0) {
echo $day' 是周末<br />';
}
}
>
望采纳 Thx
以上就是关于.net中取到本日,本周,本月,是怎么取得全部的内容,包括:.net中取到本日,本周,本月,是怎么取得、用php获取本周,上周,本月,上月,本季度日期的代码、java 获取当前日期时间和本周的星期一的日期时间等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)