0

完全にテストされたサイトをWebサーバーに移動しましたが、戻ってきます

ParameterName'Choices'のSqlParameterは、このSqlParameterCollectionに含まれていません。

VS 2010を使用すると、このエラーを再現できません。すべてが完全に機能し、すべてのテストに合格します。

サーバーはIIS6とnet3.5を実行しています。過去に使用したことがあり、問題はありません。このサイトは、vb.netを使用してasp.net3.5で構築されています。

コード:

<SelectParameters>
   <asp:Parameter Name="UserID" Type="Object" />
   <asp:ControlParameter ControlID="DropDownList1" Name="Active" 
                         PropertyName="SelectedValue" Type="Boolean" />
   <asp:Parameter Name="Choices" Type="String" />
</SelectParameters>

Protected Sub BoarListSQL_Selecting(sender As Object, e As System.Web.UI.WebControls.SqlDataSourceSelectingEventArgs) Handles BoarListSQL.Selecting
    e.Command.Parameters("@UserId").Value = userId
    e.Command.Parameters("@Active").Value = DropDownList1.SelectedValue.ToString()
    e.Command.Parameters("@Choices").Value = lb_breeds.SelectedValue.ToString() 'breedChoice
End Sub

SelectCommand="If @Choices = 'ALL' BEGIN SELECT BoarID,Registration,Breed,Tag1,DOB,Name,BoarStudID,EntryDate,RemovalDate,Reason,Active,Location,BreedingHerdDate,Notes FROM [Table] WHERE ([UserID] = @UserID) AND ([Active] = @Active) END ELSE SELECT BoarID,Registration,Breed,Tag1,DOB,Name,BoarStudID,EntryDate,RemovalDate,Reason,Active,Location,BreedingHerdDate,Notes FROM [Table] WHERE ([UserID] = @UserID) AND ([Active] = @Active) AND ([Breed] = @Choices)"

パラメータリストに選択肢があり、selectが実行されたときに値を追加しています。

どんな助けでも大歓迎です。ありがとう。

4

1 に答える 1

0

addWithValue を追加してみてください (正常に動作するはずです)。使用しないテキストをデータベースに入れるときに ' ' が必要になる場合があることに注意してください。

したがって、他の1つの解決策は次のとおりです。

e.Command.Parameters("@Choices").Value = "'" & lb_breeds.SelectedValue.ToString() & "'"  'breedChoice

使用方法の良い例が http://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqlparametercollection.addwithvalue(v=vs.90).aspxにあります。

お役に立てれば。

于 2012-05-11T14:45:30.127 に答える