执行 SQL 查询后将参数传递到 URL 中

本文关键字:URL 参数传递 SQL 查询 执行 | 更新日期: 2023-09-27 18:31:21

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

我的最后一个问题

我在 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 中显示多个值?(因为结果将是多行和值)

提前谢谢你

执行 SQL 查询后将参数传递到 URL 中

您现在的代码将仅读取数据库中的第一行。要读取所有行,您必须循环调用 Reader.Read(),如下所示:

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

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

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