-1

我最近问了一个关于如何写查询的问题,谢天谢地你们回答了我(谢谢)

我的最后一个问题

我在一个 WML 站点上工作,所以我需要从查询中传递值我找到了一种方法(如下代码所示),但它没有用。

    <%   
//this Query was provided earlier in the previous question.

        string queryString = "select st.firstname + ' ' + st.lastname,se.year, c.coursename,c.NumberOfCredits,ri.mark  from Students st inner join RegisteredIn ri on ri.StudentId=st.id inner join Semester se on se.id=ri.SemesterId inner join Courses c on c.id=se.id ";

我找到但没有工作的方式

         using (System.Data.SqlClient.SqlConnection connection = new System.Data.SqlClient.SqlConnection(connectionString))
         {

            System.Data.SqlClient.SqlCommand command = new System.Data.SqlClient.SqlCommand(queryString, connection);

            command.Parameters.AddWithValue("@StudentId",StudentId);

                connection.Open();
                System.Data.SqlClient.SqlDataReader reader = command.ExecuteReader();
                if (reader.HasRows)
                {
                    reader.Read();
                    string _firstname = reader[0].ToString();
                    string _lastname = reader[1].ToString();
                    string _coursename = reader[2].ToString();
                    string _credits = reader[3].ToString();
                    string _mark = reader[4].ToString();

                    string url = string.Format("~/StudentInfo.aspx?StudentId={0}&firstname={1}&lastname={2}&coursename={3}&credits={4}&mark={5}", StudentId, _firstname, _lastname, _coursename, _credits, _mark);
                    Response.Redirect(url);

    %>

接收参数的页面将类似于

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="StudentInfo.aspx.cs" Inherits="StudentInfo" %>

<wml>
    <card>



        <p><% Response.Write(Request.Params["StudentId"]);%></p>
        <p><b>firstname:</b> <% Response.Write(Request.Params["firstname"]);%></p>
        <p><b>lastname:</b> <% Response.Write(Request.Params["lastname"]);%></p>
        <p><b>coursename:</b> <% Response.Write(Request.Params["coursename"]);%></p>
       <p><b>credits:</b> <% Response.Write(Request.Params["credits"]);%></p>
        <p><b>Mark:</b> <% Response.Write(Request.Params["mark"]);%></p>

    </card>
</wml>

结果将类似于

First Semester  2010
Student : Arin Rizk

Course Name     No. of Credit      Mark
    AAA                3            65
    BBB                3            23
    CCC                3            65
    DDD                3            58
    EEE                3            70

Your GPA for this semster is 3.12

我的问题是: - 如何从查询中提取值并放入 URL 中?- 我将如何在 WML 或 ASP 中显示多个值?(因为结果将是多行和值)

先感谢您

4

1 回答 1

1

您现在的代码将只读取数据库中的第一行。要读取所有行,您必须调用 Reader。循环读取(),类似于:

while(reader.Read())
{
    string _firstname = reader[0].ToString();
    string _lastname = reader[1].ToString()
    ...
}

但恐怕在 URL 中将所有这些信息作为参数传递确实不是一个好主意。您必须以某种方式加入所有行的结果,并在另一页上将它们拆分回单个值,这在我看来是多余的。此外,URL 长度通常是有限的,因此如果您的查询返回的不仅仅是几行,它将不起作用。为什么要在 URL 中传输整个查询结果?在 URL 中仅传输学生的标识符(或您想要显示的任何内容)并在第二页上再次从数据库中读取数据更为常见(并且更容易做到)。

更新: 如果我理解正确,您的实际问题不是如何将查询字符串中的数据库查询结果传递到另一个页面,而是您想在页面上显示查询结果。第一步是在第二页的窗体上添加适当的控件(Label、DataGridView 等)。然后根据您使用的控件,您可以将控件绑定到数据源,或者在 StudentInfo.aspx 文件中的 Page_Load 等方法中手动添加数据到控件。但由于这与您首先提出的问题完全不同,我建议您再问一个问题。这个话题也在这里讨论过很多次,所以你可以先看看这些问题

于 2012-04-16T18:01:26.887 回答