C# 在这种情况下如何使用ExecuteScalar?

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命令

我使用这个SQLSELECT语句来选择用户id等于特定id的篮子id

我想将查询结果存储在一个变量中,因此我认为我可以这样做:

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时”好吧,那个么为什么还要麻烦使用
语句呢