Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
 Аватар для Энтомолог
141 / 182 / 44
Регистрация: 25.04.2012
Сообщений: 2,623
Записей в блоге: 5

ADO.NET Возвращается неверный результат запроса

13.03.2015, 18:40. Показов 589. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
 using (var SqlCon = await Connection.GetConnection())
            {
                int count;                
                object o = null;
 
                using (var cmdIdsCount =
                    Command.InitializeCommandForInputIds
                        (@"GetPrivateMessagesAuthorsCount",
                            SqlCon, companionId,accountId))
                {//тут companionId=2,accountId=1
                    o = await cmdIdsCount.ExecuteScalarAsync();
                }
if (o == DBNull.Value || o == null)
                    count = 1;
                else
                    count = Convert.ToInt32(o);
}
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
internal static SqlCommand InitializeCommandForInputIds
           (string Function, SqlConnection SqlCon, int CompanionId, int AccountId)
        {
            SqlCommand cmd = new SqlCommand(Function, SqlCon);//тут CompanionId=2,AccountId=1 и ConnectionState=Open
            cmd.CommandType = CommandType.StoredProcedure;
            SqlParameter par = cmd.Parameters.Add(AccountIdParameter, SqlDbType.Int);
            par.Value = AccountId;
            SqlParameter par1 = cmd.Parameters.Add(CompanionIdParameter, SqlDbType.Int);
            par.Value = CompanionId;
            cmd.CommandTimeout = CmdTimeout;
            cmd.Prepare();
 
            return cmd;
        }
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
create table PrivateMessage
(
    Id INT IDENTITY(1,1) NOT NULL PRIMARY KEY,
    SenderAccountId INT NOT NULL DEFAULT 1,
    AcceptorAccountId int NOT NULL DEFAULT 1,
    PrivateText NVARCHAR(1000) NOT NULL DEFAULT N'Сообщение'   
);
insert into PrivateMessage values (1,2,N'Первое'),
(2,1,N'Второе'),
(1,2,N'Третье');
go
CREATE PROCEDURE GetPrivateMessagesAuthorsCount(@AccountId int=1, @CompanionId int=2)
AS 
BEGIN   
set nocount off;
    select count(Id)
    from PrivateMessage 
    where ((SenderAccountId=@AccountId and AcceptorAccountId=@CompanionId)
    or (SenderAccountId=@CompanionId and AcceptorAccountId=@AccountId));
    
end
go
Почему-то при запросе в базу из программы count всегда=0 (o=0)

T-SQL
1
exec GetPrivateMessagesAuthorsCount 2,1
выдаёт 3. В чём может быть проблема и как исправить?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
13.03.2015, 18:40
Ответы с готовыми решениями:

ADO.NET передача запроса на sql server
Сетевые пакеты запроса передаются на сервер БД по сети друг за другом или параллельно ?

Удаленный SQL-сервер Ado.Net + .Net remoting + Asp .Net
Всем привет! Нужно написать клиент-серверное приложение на основе Microsoft Sql Server 2005 Express Edition. Некое клиент-серверное...

Отличия ADO.NET'03 и ADO.NET'05
Друзья, есть ли отличия в технологии ADO.NET для 2003 и для 2005, и насколько они велики? Вопрос вот почему, имеет ли смысл, в случае...

1
1167 / 885 / 517
Регистрация: 09.04.2014
Сообщений: 2,098
13.03.2015, 20:00
Цитата Сообщение от Alex9 Посмотреть сообщение
SqlParameter par1 = cmd.Parameters.Add(CompanionIdParameter, SqlDbType.Int);
par.Value = CompanionId;
должно быть par1.Value

Добавлено через 2 минуты
это
C#
1
2
3
4
SqlParameter par = cmd.Parameters.Add(AccountIdParameter, SqlDbType.Int);
            par.Value = AccountId;
            SqlParameter par1 = cmd.Parameters.Add(CompanionIdParameter, SqlDbType.Int);
            par.Value = CompanionId;
можно заменить на
C#
1
2
cmd.Parameters.AddWithValue(AccountIdParameter, AccountId);
cmd.Parameters.AddWithValue(CompanionIdParameter, CompanionId);
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.03.2015, 20:00
Помогаю со студенческими работами здесь

При создании запроса в DataSet БД возвращается к первоначальному виду
Здравствуйте! Есть БД созданная при помощи встроенного в VS 2013 MS SQL. Проблема в том что при создании какого нибудь запроса в...

ChildWindowFromPoint даёт неверный результат
Есть WinForms приложение. В основном окне вызывается дочернее вот таким кодом:new RecordForm().ShowDialog(this);В этом дочернем окне...

результат запроса linq to sql содержит данные обеих таблиц, картографированных на классы. Я хочу результат присвоить в GridControl.DataSource
Здравствуйте! У меня есть две таблицы T1(id_t1(PK),name), T2(id_t2(PK), id_t1(FK), date) отображенных на классы при помощи linq to sql и...

Книги по ADO.NET
Может быть, пропустил такую тему и где-то уже было, но вот интересно знать ваше мнение - какая из всех книг по ADO.NET является лучшей ? ...

Книги по ADO .NET(C#)
Здравствуйте! Может кто подсказать хорошую книгу по ADO .NET на русском языке, желательно как можно новее. Какая версия ADO .NET на данный...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru