if exists (select * from dbo.sysobjects where
id = object_id(n[dbo].[people]) and objectproperty(id, nisusertable) = 1)
drop table [dbo].[people]
go
create table [dbo].[people] (
[pkid] [int] identity (1, 1) not null ,
[firstname] [char] (100) collate chinese_prc_ci_as null ,
[lastname] [char] (100) collate chinese_prc_ci_as null
) on [primary]
go
editdatagridcs.aspx
<%@ page language="c#" debug="true"%>
<%@ import namespace="system.data"%>
<%@ import namespace="system.data.sqlclient" %>
<script runat="server">
//make first sql
string sql = "";
string strcnn = "data source=.;initial catalog=aa;user id=sa;password=;";
//create a datasource function
public icollection createdatasource () {
sqlconnection conn = new sqlconnection(strcnn);
sqldataadapter db_sqladaptor = new sqldataadapter(sql,conn);
dataset ds = new dataset();
db_sqladaptor.fill(ds,"mydataresult");
dataview myview = ds.tables["mydataresult"].defaultview;
return myview;
}
//do page load
public void page_load(object sender, eventargs e) {
strcnn = "data source=.;initial catalog=aa;user id=sa;password=;";
if (!ispostback)
{
sql = "select * from people";
people.datasource = createdatasource();
people.databind();
}
}
public void page_grid(object sender, datagridpagechangedeventargs e)
{
sql = "select * from people";
// set currentpageindex to the page the user clicked.
people.currentpageindex = e.newpageindex;
// rebind the data.
people.datasource = createdatasource();
people.databind();
}
public void people_edit(object sender, datagridcommandeventargs e)
{
sql = "select * from people";
people.edititemindex = e.item.itemindex;
people.datasource = createdatasource();
people.databind();
}
public void people_cancel(object sender, datagridcommandeventargs e)
{
sql = "select * from people";
people.edititemindex = -1;
people.datasource = createdatasource();
people.databind();
}
public void people_update(object sender, datagridcommandeventargs e)
{
string firstname = ((textbox)e.item.cells[1].controls[1]).text;
string lastname = ((textbox)e.item.cells[2].controls[1]).text;
sqlconnection connupdate = new sqlconnection(strcnn);
connupdate.open();
string sql_edit = "update people " +
"set firstname = " + firstname.replace("","")+ "," +
"lastname = " + lastname.replace("","")+ "" +
" where pkid = " + e.item.cells[0].text;
sqlcommand sqlcommandupdate = new sqlcommand(sql_edit,connupdate);
sqlcommandupdate.executenonquery();
connupdate.close();
sql = "select * from people";
people.edititemindex = -1;
people.datasource = createdatasource();
people.databind();
}
public void people_delete(object sender, datagridcommandeventargs e) {
sqlconnection conndel = new sqlconnection(strcnn);
conndel.open();
string sql_del = "delete from people " +
" where pkid = " + e.item.cells[0].text;
sqlcommand sqlcommanddel = new sqlcommand(sql_del,conndel);
sqlcommanddel.executenonquery();
conndel.close();
sql = "select * from people";
people.edititemindex = -1;
people.datasource = createdatasource();
people.databind();
}
</script>
<font face="arial" size="3">
<b>edit people</b>
</font>
<br>
<form runat="server">
<asp:datagrid id="people" runat="server"
bordercolor="green"
width="640"
pagesize="5"
allowpaging="true"
onpageindexchanged="page_grid"
borderwidth="1"
cellpadding="3"
autogeneratecolumns="false"
showheader="true"
visible="true"
oneditcommand="people_edit"
oncancelcommand="people_cancel"
onupdatecommand="people_update"
ondeletecommand="people_delete">
<headerstyle bordercolor="white" backcolor="black"
forecolor="white"
font-bold="true"
font-name="arial"
font-size="9" horizontalalign="center"/>
<itemstyle bordercolor=""
backcolor="#fffff0"
forecolor="black"
font-name="arial"
font-size="8"
font-bold="false" horizontalalign="center"/>
<edititemstyle bordercolor=""
backcolor="#fffff0"
forecolor="black"
font-name="arial"
font-size="7"
font-bold="false" horizontalalign="center"/>
<pagerstyle mode="numericpages" font-size="8"/>
<columns>
<asp:boundcolumn headertext="id" readonly="true" datafield="pkid"/>
<asp:templatecolumn>
<headertemplate>
<b> first name </b>
</headertemplate>
<itemtemplate>
<asp:label
text=<%# databinder.eval(container.dataitem, "firstname").tostring().trim() %>
runat="server"/>
</itemtemplate>
<edititemtemplate>
<asp:textbox id="firstname" text=
<%# databinder.eval(container.dataitem, "firstname").tostring().trim() %>
runat="server" width="100%"/>
</edititemtemplate>
</asp:templatecolumn>
<asp:templatecolumn>
<headertemplate>
<b> last name </b>
</headertemplate>
<itemtemplate>
<asp:label
width="200"
text=<%# databinder.eval(container.dataitem, "lastname").tostring().trim() %>
runat="server"/>
</itemtemplate>
<edititemtemplate>
<asp:textbox id="lastname" text=<br>
<%# databinder.eval(container.dataitem, "lastname").tostring().trim() %>
runat="server" width="100%"/>
</edititemtemplate>
</asp:templatecolumn>
<asp:editcommandcolumn
buttontype="linkbutton"
canceltext="cancel"
edittext="edit"
updatetext="update" />
<asp:buttoncolumn text= "delete" commandname="delete"></asp:buttoncolumn>
</columns>
</asp:datagrid>
</form>
本文评论(comments):为了保护您的电子邮件不被骚扰,地址中的个别符号转换成了全角字符!
评论人:凌风雁 电子邮件:yblin@163.com 评论日期:2004年06月12日 03:51:07
我这个没有办法实现删除功能!不知道为什么!!!可不可以帮助解决一下!!
dim rcount,pcount,currentpage as integer
sub page_load(sender as object, e as eventargs) 首次载入
if not page.ispostback then
dim mana as string
mana = request.querystring("mname")
if mana ="" then
response.redirect("/manage/admin.aspx")
exit sub
end if
session("managename") = mana
dim cn as oledbconnection
dim cmd as oledbdataadapter
dim ds as dataset
dim sql as string = "select * from news order by id desc"
dim dsn as string = application("dsn")
cn = new oledbconnection(dsn)
cmd = new oledbdataadapter
cmd.tablemappings.add("table","news")
cmd.selectcommand = new oledbcommand(sql,cn)
ds = new dataset("news")
cmd.fill(ds,"news")
rcount = ds.tables("news").defaultview.count
currentpage = 1
if (rcount mod mylist.pagesize) = 0 then
pcount = rcount/mylist.pagesize
lblrecordcount.text = rcount.tostring()
lblpagecount.text = pcount.tostring()
lblcurrentpage.text= "1"
else
pcount =cint( rcount/mylist.pagesize + 0.5)
lblrecordcount.text = rcount.tostring()
lblpagecount.text = pcount.tostring()
lblcurrentpage.text = "1"
end if
listsize()
mylist.datasource = ds.tables("news").defaultview
mylist.databind()
end if
end sub
sub change_page(sender as object, e as datagridpagechangedeventargs) 换页
mylist.currentpageindex = e.newpageindex
databind()
end sub
sub page_onclick(sender as object,e as commandeventargs) 响应按钮
currentpage = cint(lblcurrentpage.text)
pcount = cint(lblpagecount.text)
dim cmd1 as string
cmd1 = e.commandname
if cmd1 = "next" then
if (currentpage < (pcount)) then
currentpage = currentpage + 1
end if
end if
if cmd1 = "prev" then
if (currentpage > 0) then
currentpage = currentpage – 1
end if
end if
if cmd1 = "first" then
currentpage = 1
end if
if cmd1 = "last" then
currentpage = (pcount)
end if
lblcurrentpage.text = currentpage
listsize()
mylist.currentpageindex = currentpage – 1
databind()
end sub
sub mylist_delete(sender as object, e as datagridcommandeventargs)
dim mycn as oledbconnection
dim mycmd as oledbcommand
dim mysql as string = "delete from news where id = @id"
dim mydsn as string = application("dsn")
mycn = new oledbconnection(mydsn)
mycmd = new oledbcommand(mysql,mycn)
mycmd.parameters.add(new oledbparameter("@id",oledbtype.integer,4))
mycmd.parameters("@id").value =mylist.datakeys(cint(e.item.itemindex).tostring())
mycmd.connection.open()
mycmd.executenonquery()
mycmd.connection.close()
databind()
end sub
function databind()
dim cn as oledbconnection
dim cmd as oledbdataadapter
dim ds as dataset
dim sql as string = "select * from news order by id desc"
dim dsn as string = application("dsn")
cn = new oledbconnection(dsn)
cmd = new oledbdataadapter
cmd.tablemappings.add("table","news")
cmd.selectcommand = new oledbcommand(sql,cn)
ds = new dataset("news")
cmd.fill(ds,"news")
mylist.datasource = ds.tables("news").defaultview
mylist.databind()
end function
function listsize() 判断按钮可用与否
lbnnextpage.enabled = true
lbnprevpage.enabled = true
lbnlastpage.enabled = true
lbnfirstpage.enabled = true
if currentpage = pcount then
lbnnextpage.enabled = false
lbnlastpage.enabled = false
end if
if currentpage = 1 then
lbnprevpage.enabled = false
lbnfirstpage.enabled = false
end if
if currentpage = 1 and pcount = 1 then
lbnnextpage.enabled = false
lbnprevpage.enabled = false
lbnlastpage.enabled = false
lbnfirstpage.enabled = false
end if
end function
function formatstring(str as string) as string 格式化输出字符
str=str.replace(" "," ")
str=str.replace("<","<")
str=str.replace(">",">")
str=str.replace(vbcrlf,"
")
formatstring = str
end function
function getchar(str_biaoti as string) as string 截取字符
if (str_biaoti.length>20)
return str_biaoti.substring(0,20)+"……"
else
return str_biaoti
end if
end function
function newwin(url)
{
var popup;
url=url;
popup=window.open(url,null,"top=5,left=5,width=600,resizable=no,height=500,menubar=no,toolbar=no,scrollbars=yes,status=no");
popup.focus();
}