Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
 Аватар для ilta
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 9

Запрос возвращает не все данные из таблицы

12.04.2017, 16:35. Показов 2307. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Занимаюсь веб-интерфейсом для базы данных на MS SQL SERVER. Серверная часть на php. Проблема в том, что при запросе к некоторым таблицам возвращает не все данные, например записей в таблице 40, выводит 10, при этом в запросе никаких условий нет. Подскажите, может кто сталкивался, в какую сторону хоть копать? Это проблема на сервере, что-то с драйвером? Или что-то с кодом? Обратила внимание, что в двух случаях выводит записи до той, в которой текстовое поле длиннее, чем предыдущие. При том, что в одном из этих случае ВСЕ записи короче, чем в другом.
База данных рабочая, с java работает нормально. На нее не думаю. Но если вы считаете иначе, то не молчите.))

Вот пример кода. Первый запрос выводит все записи, а второй - 18 из 46.
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
$month = $_POST[monthLF];
$year = $_POST[yearLF];
 
echo '            <table border=0>
                      <tr>
                          <td align=left width="200"> Расчёт произведён за год:</td>
                          <td align=left><b>'.$year.'</b></td>
                      </tr>
                      <tr>
                          <td align=left width="200"> Расчёт произведён за месяц:</td>
                          <td align=left><b>'.$month.'</b></td>
                      </tr>
                  </table>
';
 
include 'connectLF.php';
 
//Establishes the connection
$conn = sqlsrv_connect($serverName, $connectionOptions);
if ($conn)
{
    $sql = 'Select Kategor from Lgotnik_Federal where InfoYear = '.$year.' and InfoMonth = '.$month;
    echo $sql;
    $res = sqlsrv_query ( $conn, $sql);
    $arr = array();
    $kh = 0;
    while( $row = sqlsrv_fetch_array( $res, SQLSRV_FETCH_ASSOC) )
    {
        $kh=$kh+1;
        $Kategors = explode(",", $row['Kategor']);
        $count = count($Kategors);
        for ($i=0; $i<$count; $i++)
        {
            $k = 0 + $Kategors[$i];
            if (array_key_exists($k, $arr))
            {
                $c = $arr[$k];
                $arr[$k] = $arr[$k] + 1;
            }
            else
            {
                $arr += [$k=>'1'];
            }
        }
    }
    sqlsrv_free_stmt( $res);
    //print_r($arr);
 
    echo '<h1>Расчёт количества льготных категорий в базе данных, предоставленной ПФР </h1>';
    $sql = 'select KodLgota,NameLgota from SprLgota_Federal order by KodLgota';
    echo $sql;
    $res = sqlsrv_query ( $conn, $sql);
    echo '<table border>';
    echo '<tr><td><b>Код категории</b></td><td><b>Наименование категории </b></td><td><b>Количество</b></td></tr>';
    while( $row = sqlsrv_fetch_array( $res, SQLSRV_FETCH_ASSOC) )
    {
        $k = $row['KodLgota'];
        $n = $row['NameLgota'];
        if (array_key_exists($k, $arr))
        {
            echo '<tr><td>'.$k.'</td><td>'.$n.'</td><td>'.$arr[$k].'</td></tr>';
        }
        else
        {
            echo '<tr><td>'.$k.'</td><td>'.$n.'</td><td>0</td></tr>';
        }
    }
    echo '<tr><td rowspan = 2><b>Итого</b></td><td><b>Количество человек</b></td><td><b>'.$kh.'</b></td></tr>';
    echo '<tr><td><b>Количество льготных оснований</b></td><td><b>'.array_sum($arr).'</b></td></tr>';
    echo '</table>';
    sqlsrv_free_stmt( $res);
 
}
else
{
echo "<br />".'Невозможно подключиться к базе данных'."<br />";
}
Заранее спасибо! Буду рада любому конструктивному совету.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.04.2017, 16:35
Ответы с готовыми решениями:

PHP запрос к БД access возвращает не все данные
Таблица ARH_Dialy: Дата (Дата/время) Температура_среднесут (Числовой) Давление_среднесут (Числовой) Расход_за_сутки (Числовой) ...

SQL запрос возвращает не все данные. Почему?
Странная ситуация с SQL запросом. Есть база данных, из которой SQL запросом вытаскиваю результаты продаж за один день в Excel-таблицу. ...

POST запрос не возвращает данные
POST запрос не возвращает данные. После передачи параметров должна возвратиться страница sinonimus.ru/index.php/index.php#final_text с...

4
 Аватар для Vas-e-na
420 / 417 / 79
Регистрация: 21.06.2010
Сообщений: 1,362
12.04.2017, 17:03
Дамп базы в студию
0
 Аватар для ilta
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 9
12.04.2017, 17:49  [ТС]
Без этого никак? Там персональные данные...
0
 Аватар для arava
340 / 135 / 70
Регистрация: 30.06.2014
Сообщений: 717
12.04.2017, 17:57
Лучший ответ Сообщение было отмечено ilta как решение

Решение

ilta, Не работаю с Вашей СУБД но укажу куда копать .

sqlsrv_fetch_array — Returns a row as an array ( возвращает строку как массив, именно строку! )

Вам нужно использовать функцию которая возвращает все значения,предполагаю что это sqlsrv_fetch , перепроверьте .

Сейчас Ваш запрос к БД возвращает только одну строку
1
 Аватар для ilta
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 9
13.04.2017, 10:10  [ТС]
arava, большое вам спасибо, использование sqlsrv_fetch решило проблему!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.04.2017, 10:10
Помогаю со студенческими работами здесь

Запрос на выборку полей из таблицы создания заказа (возвращает пустые поля)
Доброй ночи! помогите, пожалуйста.. написала запрос на выборку полей из таблицы создания заказа, обязательно последнего, запрос строится,...

hql запрос возвращает не все поля с записями
public Collection&lt;Products&gt; getProducts() { //return sessionFactory.getCurrentSession().createSQLQuery(&quot;select priceProduct, id, name...

Запрос из конструктора - получить данные из таблицы
С новым годом Вас!! Мой вопрос в следующем: Есть БД: Firebird 2.5 Мое приложение сделанное в Microsoft Visual Studio 2013 (upd 3) ...

Запрос: вывести данные из таблицы для каждой n-ой детали
Здравствуйте! Подскажите, пожалуйста, как вывести данные из таблицы для каждой n-ой детали?

Из таблицы Exel выбирает все строки с нечетным номерами и вставляет эти данные в Word в четные строки таблицы
Написать код VBA при нажатии на кнопку, который из таблицы Exel выбирает все строки с нечетным номерами и вставляет эти данные в Word в...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка 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, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru