判断两个日期的时间部分之差


 

Select * from ConfigTB where DateDiff(s,Cast(Convert(Varchar(20),setendhour,108)   As   DateTime),Cast(Convert(Varchar(20),getdate(),108)   As   DateTime))<0

 

posted @ 2009-04-15 10:47 低调の华丽 阅读(27) 评论(0) 编辑

 浅析ASP.NET中页面传值的几种方法

第一种方法:

使用QueryString

使用QuerySting在页面间传递值已经是一种很老的机制了,这种方法的主要优点是实现起来非常简单,然而它的缺点是传递的值是会显示在浏览器 的地址栏上的(不安全),同时又不能传递对象,但是在传递的值少而安全性要求不高的情况下,这个方法还是一个不错的方案。使用这种方法的步骤如下:
1,使用控件创建web表单(form)
2,创建可以返回表单的按钮和链接按钮
3,在按钮或链接按钮的单击事件里创建一个保存URL的字符变量
4,在保存的URL里添加QueryString参数
5,使用Response.Redirect重定向到上面保存的URL

下面的代码片断演示了如何实现这个方法:

源页面代码:

 

 

private void Button1_Click (object sender, System.EventArgs e)
{
string url;
url
=”anotherwebform.aspx?name=” + TextBox1.Text + “&email=” +                   TextBox2.Text;
Response.Redirect(url);
}

目标页面代码:

private void Page_Load (object sender, System.EventArgs e)
{
Label1.Text
=Request.QueryString[”name”];
Label2.Text
=Request.QueryString[”email”];
}

第二种方法:

通过post方式。

以下为引用的内容:

send.aspx
receive.aspxstring
username 
= Ruquest.Form[”receive”];

 

第三种方法:

使用Session变量

使用Session变量是可以在页面间传递值的的另一种方式,在本例中我们把控件中的值存在Session变量中,然后在另一个页面中使用它,以不 同页面间实现值传递的目的。但是,需要注意的是在Session变量存储过多的数据会消耗比较多的服务器资源,在使用session时应该慎重,当然了, 我们也应该使用一些清理动作来去除一些不需要的session来降低资源的无谓消耗。使用Session变量传递值的一般步骤如下:
1,在页面里添加必要的控件
2,创建可以返回表单的按钮和链接按钮
3,在按钮或链接按钮的单击事件里,把控件的值添加到session变量里
4,使用Response.Redirect方法重定向到另一个页面
5,在另一个页面提取session的值,在确定不需要使用该session时,要显式清除它

下面的代码片断演示了如何实现这个方法:

源页面代码:

 

private void Button1_Click (object sender, System.EventArgs e)
{
file:
//textbox1 and textbox2 are webform
file://controls
Session[”name”]=TextBox1.Text;
Session[”email”]
=TextBox2.Text;
}

 

目标页面代码:

private void Page_Load (object sender, System.EventArgs e)
{
Label1.Text
=Session[”name”].ToString();
Label2.Text
=Session[”email”].ToString();
Session.Remove(”name”);
Session.Remove(”email”);
}

第四种方法:

通过Application

 

send.aspx:
protected void Button1_Click (object sender, EventArgs e)
{
Application[”username”] 
= “honge”;
Request.Redirect(”Default2.aspx”);
}
receive.aspx:
string username = Application[”username”];

 

这样可以得到参数值。

第五种方法:

使用Server.Transfer

这个方法相比上面介绍的方法稍微复杂一点,但在页面间值传递中却是特别有用的,使用该方法你可以在另一个页面以对象属性的方式来存取显露的值,当然 了,使用这种方法,你需要额外写一些代码以创建一些属性以便可以在另一个页面访问它,但是,这个方式带来的好处也是显而易见的。总体来说,使用这种方法是 简洁的同时又是面向对象的。使用这种方法的整个过程如下:
1,在页面里添加必要的控件
2,创建返回值的Get属性过程
3,创建可以返回表单的按钮和链接按钮
4,在按钮单击事件处理程序中调用Server.Transfer方法转移到指定的页面
5,在第二个页面中,我们就可以使用Context.Handler属性来获得前一个页面实例对象的引用,通过它,就可以使用存取前一个页面的控件的值了

以下代码综合实现上述步骤过程的代码:

源页面代码:


 

public string Name
{
get
{
return TextBox1.Text;

}
}
public string EMail
{
get
{
return TextBox2.Text;
}
}

然后调用Server.Transfer方法

 

private void Button1_Click (object sender, System.EventArgs e)
{
Server.Transfer(”anotherwebform.aspx”);
}

 

目标页面代码:

private void Page_Load (object sender, System.EventArgs e)
{
file:
//create instance of source web form
WebForm1 wf1;
file:
//get reference to current handler instance
wf1=(WebForm1)Context.Handler;
Label1.Text
=wf1.Name;
Label2.Text
=wf1.EMail;
}

 

如果在asp.net 2.0中还可以这样用:通过PreviousPage

 

PreviousPage d = Context.Handler as PreviousPage ;
if (d != null)
{
Response.Write(d.Name);这样可以得到参数值。
}

 

也可以这样用:


 

send.aspx:
receive.aspx:
string name = PreviousPage.Name;

这样可以得到参数值。

如果你的页面中用到了MasterPage的话 Server.Transfer 传递的 PreviousPage就无效了,不知道这是什么原因.所以在用到MasterPage的话,最好用Session或是 Context.Items[”username”]来实现。

总结

本文讲述了使用不同的方法实现了ASP.NET页面间值传递,这三种方法是:QueryString,Session和Server.Transfer,我们应该反覆体会几种方法的异同。我希望本文能给你有用的助益,直到在你的代码中运用自如!

posted @ 2009-04-03 14:23 低调の华丽 阅读(195) 评论(0) 编辑
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
</head>
<script type="text/javascript">
function returnWin(){
window.returnValue
=document.Form2.TextBox1.value;
window.close();
}
</script>


<body>
<form name="Form2" id="Form2">

<input name="TextBox1" id="TextBox1" value="123" type="text" />
<input name="button" value="返回" type="button" onclick="returnWin();" />
</form>
</body>
</html>
1.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
</head>
<script> 
function OpenWin(){
    
var str=window.showModalDialog('2.html',document.Form1.TextBox1.value,'help:no');
    
if(str!=null)  {
        document.Form1.TextBox1.value
=str;
    }
}
</script>

<body>
<form name="Form1">
<input name="TextBox1" id="TextBox1" value="1" />
<input type="button" name="Button1" value="打开窗口" onclick="OpenWin();" id="Button1" style="width:96px;" />
</form>
</html>

 

2.html

 

posted @ 2009-03-26 10:37 低调の华丽 阅读(746) 评论(0) 编辑

1. Asp.net基本控件

Label

标签

Textbox

文本框

Checkbox

多选框

Radio button

单选框

Image

图片框

Button

按钮

Link button

带链接的按钮

Image button

带图片的按钮


Listbox

通用列表框

Drop down list

下拉列表框

Check button list

复选列表框

Radio button list

单选列表框

Convert.toint32()  字符串转数值型

().ToString() 转字符串型

验证控件

requiredfieldvalidator

必须输入检查

regularexpressionvalidator

正则表达式检查

comparevalidator

比较检查

customvalidator

自定义检查

 

2. Asp.net2.0新控件

 

AdRotator 广告控件

<asp:AdRotator ID="AdRotator1" runat="server" AdvertisementFile="ad.xml" />


ad.xml

 

Code


 

posted @ 2009-03-08 20:42 低调の华丽 阅读(106) 评论(0) 编辑