我有1000条记录要显示在网格视图中,所以我使用ObjectDataSource来绑定网格视图。
<asp:ObjectDataSource ID="odsProducts" runat="server" SelectMethod="GetProducts"
TypeName="ProductsList" EnablePaging="True" MaximumRowsParameterName="PageSize"
SelectCountMethod="GetRowsCount" StartRowIndexParameterName="StartRow"></asp:ObjectDataSource>
<asp:GridView ID="UserTable" runat="server" AllowPaging="True" DataSourceID="odsProducts"
SelectedIndex="0" DataKeyNames="UserID" ShowHeaderWhenEmpty="True" BorderStyle="Groove"
OnRowDataBound="UserTable_RowDataBound" AutoGenerateColumns="false">
在数据访问层中,我有一个类[Dataserver]
来执行打开和关闭连接,我有一个名为executeNonQuery方法的方法,用于从数据库中检索数据。
public int ExecuteNonQuery(CommandType commandType, string sql, MySqlParameter[] commandParameters)
{
...
return rowsAffected;
}
所以在我的OjectdataSource的Getdata方法
中 private DataView GetData(int StartRow, int PageSize)
{
DataServer server = new DataServer();
DataTable dt = new DataTable();
int newOrgID = 60;
string userQuery = "Select tbl_User.UserID, tbl_User.FirstName, tbl_User.LastName, tbl_User.Email, tbl_User.PhoneNumber, tbl_User.CreatedBy, tbl_Organisation.OrganisationName from tbl_user WHERE Organisationid=@OrganisationID order by tbl_user.LastName asc";
MySqlParameter[] para = new MySqlParameter[1];
para[0] = new MySqlParameter("@OrganisationID", MySqlDbType.Int32);
para[0].Value = newOrgID ;
dt = server.ExecuteQuery(CommandType.Text, userQuery, para);
}
网络中的所有示例都带有存储过程,有些人可以帮助我这样做。我得到的错误是我无法绑定网格视图,无法将数据集转换为数据。那么我如何使用数据表来绑定到gridview
答案 0 :(得分:0)
只需更改SelectMethod
的签名
private DataView GetData(int StartRow, int PageSize)
到
public DataTable GetProducts(MyNewParameter,StartRow,PageSize)
并在方法结束时返回dt
。
很好的例子:http://www.codeproject.com/KB/aspnet/PagingWithODS.aspx
答案 1 :(得分:0)
如何使用数据表来绑定到gridview
此示例显示如何使用DataTable作为数据源绑定到GridView:
MySqlCommand sm = new MySqlCommand("SELECT * FROM table", database_connection);
MySqlDataAdapter sa = new MySqlDataAdapter(sm);
DataTable dt = new DataTable();
sa.Fill(dt); // store query results in dt
gv.DataSource = dt;
gv.DataBind();
这也说明了如何在不使用存储过程或ObjectDataSource的情况下执行选择查询。
如果您使用的是System.Data.SqlClient
而不是MySql.Data.MySqlClient
,请将这些课程重命名为SqlCommand
和SqlDataAdapter
。