这个问题我不知写什么标题好…反正是求帮忙…………!!

qq386707112 2012-05-14 02:27:31
Table2是一个数据库表……调试时他说“myDataList”的 DataSourceID 必须是 IDataSource 类型的控件的 ID。未能找到 ID 为“Table2”的控件。”,我不懂怎么解决……求帮忙!! (还有,如果发错论坛就提示下啊)
以下是C#代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data.SqlClient;

namespace DataList控件
{
public partial class _Default : System.Web.UI.Page
{
private void Repeater0()
{
string myConnectionString = "Data Source=li-pc\\sqlexpress;Initial Catalog=测试数据库2;Integrated Security=True";
SqlConnection myConnection = new SqlConnection(myConnectionString);
string cmdString = "select top 5 * from Table2";
SqlCommand myCommand = new SqlCommand(cmdString,myConnection);
myConnection.Open();
SqlDataReader myReader = myCommand.ExecuteReader();
myDataList.DataSource = myReader;
myDataList.DataBind();
myReader.Close();
myConnection.Close();
}
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
Repeater0();
}

protected void myDataList_ItemCommand(object source,DataListCommandEventArgs e)
{
if (e.CommandName.ToLower() == "Show")
{
Label name = (Label)e.Item.FindControl("name");
Label city = (Label)e.Item.FindControl("city");
Label address = (Label)e.Item.FindControl("address");
if (name != null && city != null && address != null)
{
myLabel1.Text = name.Text + "" + city.Text + "" + address.Text + "";
}
}
}
}
}
以下是HTML代码:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="DataList控件._Default" %>

<!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 runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
<h1>DataList控件演示</h1>
<asp:DataList ID="myDataList" runat="server" BackColor="Black"
BorderWidth="1px" OnItemCommand="myDataList_ItemCommand"
DataSourceID="Table2" >



<HeaderTemplate>
<table border="1" cellpadding="0" cellspacing="0">
<tr><td>客户名称</td><td>所在城市</td><td>联系地址</td></tr>
</HeaderTemplate>
<ItemTemplate>
<tr>
<td><asp:Label ID="name" runat="server" Text='<%# DataBinder.Eval(Container.DataItem,"name") %>'></asp:Label></td>
<td><asp:Label ID="city" runat="server" Text='<%# DataBinder.Eval(Container.DataItem,"city") %>'></asp:Label></td>
<td><asp:Label ID="address" runat="server" Text='<%# DataBinder.Eval(Container.DataItem,"address") %>'></asp:Label></td>
<td><asp:Button ID="ShowInfo" runat="server" CommandName="Show" Text="选择用户" /></td>
</tr>
</ItemTemplate>
<FooterTemplate>
</table>
</FooterTemplate>
</asp:DataList>
你选择的用户是:<asp:Label ID="myLabel1" runat="server" Text="myLabel" Width="308px"></asp:Label>
</div>
</form>
</body>
</html>
...全文
66 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
bdmh 2012-05-14
  • 打赏
  • 举报
回复
table2是一个组件的id,你应该有一个
<asp:sqldatasource id="CustomersSource"的组件,看DataSourceID 的帮助代码
Shawn0691302 2012-05-14
  • 打赏
  • 举报
回复
DataSourceID="Table2" 这个是干什么的?问题在这里。。。
bdmh 2012-05-14
  • 打赏
  • 举报
回复
DataSourceID="Table2",没有Table2,当然识别不了了,你sql中的"Table2",与这个无关

62,268

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧