0

这是我的代码:

  Protected Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs) Handles Me.Load

    ltRooms.Text = CInt(Session("numOfRooms"))


    'Calculate total cost
    Dim intPrice As Integer
    Dim intTotal As Integer

    intPrice = AccessDataSource1.SelectCommand = "SELECT [Price] FROM [Rooms] WHERE ([RoomType] = 'RoomType')"


    intTotal = intPrice * intRooms
    ltPrice.Text = intTotal.ToString

    End Sub

和我的数据源

           <asp:AccessDataSource ID="AccessDataSource1" runat="server" 
        DataFile="Hostel.accdb" 
        SelectCommand="SELECT * FROM [Bookings]"></asp:AccessDataSource>

我正在尝试存储选择查询中的值,然后使用它来计算总价,然后将其存储在文字中。到目前为止,我只得到 0。没有编译错误。

有谁知道为什么这不起作用?

4

1 回答 1

1

为了清楚起见,我将各种评论合并为一个答案,并停止页面抱怨扩展讨论。这完全不在我的脑海中,因此代码中可能存在一些错误。不过,它应该足以查明问题。

首先,现在我今天再看一遍,我认为您的代码只是设置了数据源的SelectCommand属性,并没有真正查询数据库。我认为您需要使用DataSource.Select方法。

您的代码最终可能看起来像这样:

AccessDataSource1.SelectCommand = "SELECT [Price] FROM [Rooms] WHERE ([RoomType] = '" & RoomType & "')"

Dim intPrices As List(Of Integer) = AccessDataSource1.Select(DataSourceSelectArguments.Empty)

' Now do stuff with your price data.

如果以上没有帮助,那么我会检查intPriceSelect 调用返回的值。您还应该检查 RoomType 是否设置正确。

如果从数据库返回错误的数据,那么您应该能够修复 SQL 查询以检索正确的数据。如果您需要进一步的帮助,请发布 SQL 查询和表结构。

如果返回正确的数据,则检查intRooms定义的位置。如果它为零,那么无论 的值如何,您的总数都将计算为零intPrice

于 2013-05-29T09:39:02.177 回答