C# 在这种情况下如何使用ExecuteScalar?
我使用这个SQLSELECT语句来选择用户id等于特定id的篮子id 我想将查询结果存储在一个变量中,因此我认为我可以这样做:C# 在这种情况下如何使用ExecuteScalar?,c#,asp.net,sql,executescalar,C#,Asp.net,Sql,Executescalar,我使用这个SQLSELECT语句来选择用户id等于特定id的篮子id 我想将查询结果存储在一个变量中,因此我认为我可以这样做: BasketPage.SelectCommand="SELECT BasketID FROM tblBasket WHERE (UserID = '9f96bd94-91b9-4328-8214-4eac179c3a26')" var BasketID = BasketPage.ExecuteScalar().ToString(); 但显然,我需要创建一个SQL命令
BasketPage.SelectCommand="SELECT BasketID FROM tblBasket WHERE (UserID = '9f96bd94-91b9-4328-8214-4eac179c3a26')"
var BasketID = BasketPage.ExecuteScalar().ToString();
但显然,我需要创建一个SQL命令的新实例才能使其工作,我如何才能为BasketPage Select命令执行此操作?假设您使用的是SQL Server,您是否尝试过类似的操作
BasketPage.SelectCommand =
new SqlCommand("SELECT BasketID FROM tblBasket WHERE (UserID = '9f96bd94-91b9-4328-8214-4eac179c3a26')",
"yourconnectionstring");
假设您使用的是SQL Server,您是否尝试过类似的方法
BasketPage.SelectCommand =
new SqlCommand("SELECT BasketID FROM tblBasket WHERE (UserID = '9f96bd94-91b9-4328-8214-4eac179c3a26')",
"yourconnectionstring");
我不知道您的
BasketPage
,但您无法使用ExecuteScalar
方法对基础数据库执行此查询。假设SQL Server:
using (var connection = new SqlConnection(connString))
using (var command = connection.CreateCommand()) {
command.CommandText = "select BasketId from tblBasket where UserId = N'9f96bd94-91b9-4328-8214-4eac179c3a26'";
command.CommandType = CommandType.Text;
try {
var basketId = (string)command.ExecuteScalar(); // Assuming BasketId is a string, since you called ToString() in your question.
} finally {
command.Dispose();
connection.Dispose();
}
}
我不知道您的
BasketPage
,但您无法使用ExecuteScalar
方法对基础数据库执行此查询。假设SQL Server:
using (var connection = new SqlConnection(connString))
using (var command = connection.CreateCommand()) {
command.CommandText = "select BasketId from tblBasket where UserId = N'9f96bd94-91b9-4328-8214-4eac179c3a26'";
command.CommandType = CommandType.Text;
try {
var basketId = (string)command.ExecuteScalar(); // Assuming BasketId is a string, since you called ToString() in your question.
} finally {
command.Dispose();
connection.Dispose();
}
}
为什么你认为你需要创建一个SQL命令的新实例?因为除非我创建了一个新实例,否则该方法不会出现或让我使用它。你的代码是什么
BasketPage
class?它实际上是否有SelectCommand
属性?我不了解这种方法,您的BasketPage
类的代码示例以及您在其中使用ADO.NET的方式可能会有所帮助。=)为什么你认为你需要创建一个SQL命令的新实例?因为除非我创建了一个新实例,否则该方法不会出现或让我使用它。你的代码是什么BasketPage
class?它实际上是否有SelectCommand
属性?我不了解这种方法,您的BasketPage
类的代码示例以及您在其中使用ADO.NET的方式可能会有所帮助。=)为什么同时使用finally和using?这是由于异常处理,它最好让未处理的异常冒泡出来,否则你会遇到问题,编写try…finally
比try…catch
更好,如果你只想再次抛出异常,或者抛出一个新的异常,也就是说,因为堆栈跟踪的事情。无论如何,在编写finally
子句时,我不会让它为空,而是编写dispose行,同时我知道这些对象无论如何都会被处理。因此,当有一天我不使用IDisposable
s时,我应该考虑以某种方式释放资源。如果我理解正确,您会喜欢finally,因为它让您“…考虑以某种方式释放资源。”“…当有一天我不使用'IDisposable's时”好的,那么为什么要费心使用语句,然后为什么同时使用finally和using呢?这是由于异常处理,最好让未处理的异常冒泡出来,否则与此有关,编写try…finally
比try…catch
更好,如果你只想再次抛出异常,或者抛出一个新的异常,那是因为堆栈跟踪的原因。无论如何,在编写finally
子句时,我不会让它为空,而是编写dispose行,同时我知道这些对象无论如何都会被处理。因此,当有一天我不使用IDisposable
s时,我应该考虑以某种方式释放资源。如果我理解正确,您会喜欢finally,因为它让您“…考虑以某种方式释放资源。”“…当有一天我不使用'IDisposable's时”好吧,那个么为什么还要麻烦使用语句呢