Как я могу использовать ExecuteScalar в этом сценарии? - PullRequest
0 голосов
/ 06 декабря 2010

У меня есть этот оператор SQL Select, чтобы выбрать идентификатор корзины, где идентификатор пользователя равен определенному идентификатору.

Я хочу сохранить результат запроса в переменной, поэтому я подумал, что мог бы сделать:

BasketPage.SelectCommand="SELECT BasketID FROM tblBasket WHERE (UserID = '9f96bd94-91b9-4328-8214-4eac179c3a26')"

var BasketID = BasketPage.ExecuteScalar().ToString();

Но, очевидно, мне нужно создать новый экземпляр команды SQL, чтобы он работал, как я могу сделать это для команды выбора BasketPage?

Ответы [ 2 ]

2 голосов
/ 06 декабря 2010

Я не знаю о вашем 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();
        }
    }
1 голос
/ 06 декабря 2010

Предполагая, что вы используете SQL Server, вы пробовали что-то вроде

BasketPage.SelectCommand = 
         new SqlCommand("SELECT BasketID FROM tblBasket WHERE (UserID = '9f96bd94-91b9-4328-8214-4eac179c3a26')",
                      "yourconnectionstring");
...