Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
1 / 1 / 0
Регистрация: 17.11.2010
Сообщений: 40
MS SQL

Sql-запрос возвращает ошибку

03.10.2018, 10:44. Показов 752. Ответов 3

Студворк — интернет-сервис помощи студентам
Доброго времени суток!
Продублирую тему из JS, но теперь в разрезе SQL-PHP

Делаю запрос к БД MS SQL через ajax.
Кликните здесь для просмотра всего текста
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
function getActiveDevice(tec_id, device_id) {
      $.ajax({
          url: "php/sqlQuery.php",
          type: "GET",
          dataType: "json",
          data: {
            tec_id:tec_id,
            device_id:device_id
          },
          success:function(result){
              console.log("Success: ", result);
            },
          error:function(jqXHR, textStatus, errorThrown) {
            console.log('textStatus: '+ textStatus);
            console.log('error: ' + errorThrown);
          }
      });
}

в sqlQuery.php делается выборка и формируется массив
Кликните здесь для просмотра всего текста
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
<?php
 
$id_tec = $_GET['tec_id'];
$id_device = $_GET['device_id'];
 
// подключение к БД
include_once '../php/DBconnect.php';
 
if ($id_tec == 0) {
  echo json_encode(array("c" => "all"));
  exit();
} else {
    // выборка из объединенных таблиц gftec и Device по полю gftec.tabl=device.id
 
// !!вопрос в этом запросе!!
    $db_query = "SELECT gftec.[Id]
                        ,gftec.[ID_TEC]
                        ,gftec.[dattime]
                        ,gftec.[p]
                        ,gftec.[t]
                        ,gftec.[q]
                        ,gftec.[tabl]
                          ,Device.[ID] as 'id_dev'
                          ,Device.[Name]
                          ,Device.[OrderNum]
                          ,Device.[IdDataType]
              FROM (
                SELECT * FROM gftec WHERE [ID_TEC]=".$id_tec.") AS gftec JOIN (
                SELECT * FROM Device WHERE [Id_tec]=".$id_tec.") AS device ON gftec.[tabl]=device.[ID]
                WHERE gftec.[Id] IN (select max(Id) FROM gftec WHERE gftec.[ID_TEC]=".$id_tec." GROUP BY gftec.[tabl])
                ORDER BY device.[OrderNum]";
}
// формирование массива значений
 
    $odbc_result = odbc_exec($db_connect,$db_query);
    $device_cont = odbc_num_rows($odbc_result);
 
    if ($odbc_result) {
        for ($i=0; $i <$device_cont ; $i++) {
          $res_d_name[$i] = odbc_result($odbc_result,"Name");
          $res_p[$i] = odbc_result($odbc_result,"p");
          $res_t[$i] = odbc_result($odbc_result,"t");
          $res_q[$i] = odbc_result($odbc_result,"q");
          $res_dattime[$i] = date("d:m:Y h:i:s", strtoTime(odbc_result($odbc_result,"dattime")));
          odbc_fetch_row($odbc_result);
      }
       echo json_encode(array('c' => $device_cont, 'd_name' => $res_d_name, 'p' => $res_p, 't' => $res_t, 'q' => $res_q, 'dattime' => $res_dattime));
      } else {  
       echo "\n - table isn't readed"; }
?>

в средствах разработчика браузера результат всего этого:
- в логах error: SyntaxError: Синтаксическая ошибка
- в сети
ИмяПротоколМетодРезультатТип содержимогоПолученоВремяИнициатор
http://saradm-hpf-test.ad.ies-... e_id=99999HTTPGET200text/html0 B4,86 сXMLHttpRequest

Проблема в том, что данный SELECT был отлажен в MS SQL Server Manadement Studio. И там он отлично работает. Но при копировании запроса в php, результатом становится "синтаксическая ошибка" (результат не меняется, если вместо переменных вставляю явные значения). Как я понимаю, для php чего-то в этом запросе не хватает. Синтаксис php проверялся неоднократно - вместо переменных вставлял обычные значения, все двойные/одинарные кавычки, скобки, точки с запятой - все, вроде бы, на месте, но...

p.s. Не знаю поможет ли эта история, но вот работающий запрос (собственно его и переделываю):
Кликните здесь для просмотра всего текста
PHP
1
2
3
4
5
6
7
8
9
10
11
    $db_query = "SELECT [Id]
                     ,[ID_TEC]
                     ,[dattime]
                     ,[p]
                     ,[t]
                     ,[q]
                     ,[tabl]
                  FROM [GF].[dbo].[gftec]
                  where [ID_tec]=".$id_tec." and [Id] in (select max(id) from [GF].[dbo].[gftec]
                                                                  where [ID_TEC]=".$id_tec."
                                                                  group by [tabl])";

так вот изначально он был без where в 10 строке и все в той же менеджмент студии работал отлично, но при вставке в php работать отказывался. Я уже не помню, как додумался до добавления этой 10-й строки, однако смысла ее добавления ни тогда, ни сейчас так и не понял и воспринимал, как бубен. Но вот второй запрос со схожими симптомами вызывает подозрения...
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
03.10.2018, 10:44
Ответы с готовыми решениями:

Sql-запрос возвращает ошибку в ajax
Доброго времени суток! Делаю SQL-запрос к БД через ajax и проваливаюсь в ошибку. Сам запрос обкатан в MS SQL Management Studio -...

GET запрос возвращает ошибку 404
При запросе URL http://shtok.ru/search?searchword=*** из браузера все открывается нормально. Но если я пытаюсь выдернуть ее GET...

HTTP запрос возвращает ошибку 406
Всем доброго времени суток. Пишу программу, которая бы получала полный html-код страницы. Но почти все запросы возвращают ошибки. Можете...

3
 Аватар для otto-fukin
14 / 60 / 21
Регистрация: 15.06.2017
Сообщений: 572
09.10.2018, 20:02
Цитата Сообщение от leech Посмотреть сообщение
но вот работающий запрос
Цитата Сообщение от leech Посмотреть сообщение
но при вставке в php работать отказывался.
это не запрос, а какой-то макет на каком-то псевдоязыке. free porno
0
1 / 1 / 0
Регистрация: 17.11.2010
Сообщений: 40
10.10.2018, 09:02  [ТС]
Цитата Сообщение от otto-fukin Посмотреть сообщение
это не запрос, а какой-то макет на каком-то псевдоязыке. free porno
спасибо за максимально содержательный ответ. Сразу все вопросы решились (режим самоутверждения: ON я так понимаю?)
0
 Аватар для otto-fukin
14 / 60 / 21
Регистрация: 15.06.2017
Сообщений: 572
10.10.2018, 19:13
Да не. Захожу на этот форум чиста поржать. 90е годы прошлого века вспомнить.Движок - то не обновлялся лет 20. Соответственно и над контингентом
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.10.2018, 19:13
Помогаю со студенческими работами здесь

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

Не выполняется сложный SQL-запрос (возвращает пустую таблицу)
Всем доброго времени суток. Возникла проблема со сложным запросом (вложенный Select). Суть в том, что в Accesse он выполняется и...

Почему SQL запрос с TIBQuery у меня возвращает всё время 1?
Здравствуйте! Я хочу подсчитать сколько у меня записей в таблице с определённым значением, но ничего не выходит. Подскажите, что я...

Написать SQL запрос, который возвращает информацию о пяти ближайших днях рождения пользователей
Есть таблица пользователей CREATE TABLE `users` ( `user_id` int(11) NOT NULL AUTO_INCREMENT, `birthday` date NOT NULL default...

Запрос из базы возвращает в reader значение поля типа date как datetime +MS SQL Server 2008
В таблице есть поле типа Date, в таблицу добавлены записи, в это поле добавлена запись только с датой. Есть перекрёстный запрос на вывод...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru