Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
 Аватар для Laroux
172 / 167 / 75
Регистрация: 21.11.2014
Сообщений: 1,490

Количество затронутых обработкой строк

29.02.2016, 16:09. Показов 3050. Ответов 24
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Что-то не могу сообразить вот что: произвожу в коде какую-нить операцию с MySQL (например, UPDATE или DELETE) c условием WHERE
Ну допустим
SQL
1
UPDATE `My_table` SET `field1`='some_text', `field2`=0 WHERE `id` IN (2,4,5,12,32,40,55,982,1023);
Если я такой код выполню в phpMyAdmin (или, допустим, какой-нить Adminer), то я увижу некое сообщение типа "Запрос завершён, изменено 4 записи"

А как мне получить количество затронутых запросом строк в PHP? А в идеале еще бы и ключи затронутых строк получить...

P.S. Не.. я могу, конечно, перед выполнением скрипта сделать SELECT с таким же условием и понять, сколько и чего у меня поменяется. Но это лишние запросы к БД.. плюс (не уверен, но запросто), что если с системой работает несколько пользователей, то между SELECT-ом и UPDATE-ом может произойти изменение БД, и данные SELECT-а станут неактуальными.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.02.2016, 16:09
Ответы с готовыми решениями:

Как быть с подготовленными запросами в PDO? execute() не возвращает количество затронутых строк
Метод exec() возвращает количество затронутых строк, но его нельзя использовать в подготовленных запросах. Для этого существует метод...

SQLite. Получить кол-во строк, затронутых UPDATE
"SELECT changes()" не проверяет, изменились ли записи в БД или просто были перезаписаны. Значит, единственный способ узнать, были ли...

помогите с обработкой строк
Ввести с клавиатуры строку символов. Признак окончания ввода строки – нажатие клавиши "Ввод". Программа должна определить длину...

24
 Аватар для Пифагор
2172 / 1655 / 840
Регистрация: 10.01.2015
Сообщений: 5,207
29.02.2016, 19:23
Студворк — интернет-сервис помощи студентам
Hikari, мы уже об этом говорили выше. Там как-то хитро все.
Мне бы больше хотелось посмотреть на реализацию этого чуда через данные команды.
Laroux, можно код???
0
 Аватар для Laroux
172 / 167 / 75
Регистрация: 21.11.2014
Сообщений: 1,490
29.02.2016, 22:10  [ТС]
список есть.. однако я не знаю, есть ли в таблице все id из перечня
ну и кроме того вот вариант я описал https://www.cyberforum.ru/post8817818.html
0
 Аватар для Пифагор
2172 / 1655 / 840
Регистрация: 10.01.2015
Сообщений: 5,207
29.02.2016, 22:14
Что-то непонятно там. Ну да ладно. Сам попробую.
Т. е., не получилось, что требовалось?
0
 Аватар для Laroux
172 / 167 / 75
Регистрация: 21.11.2014
Сообщений: 1,490
29.02.2016, 22:24  [ТС]
а чего код-то?
Вот смотрите, без кода - простыми словами.

Есть таблица счетов клиентов. Туда счета могут добавлять добрый десяток человек. И удалять несколько человек.
Я делаю апдейт таблицы (помечаю, к примеру, обработанными - не заморачивайтесь, это внутриконторские терки).

когда я делаю апдейт, я в лог помещаю список всех счетов, которые были обновлены. Список счетов, которые надо обновить, зависит от нескольких параметров.
При реализации через последовательные select и потом update имеется вероятность, что между этими операциями кто-то, к примеру, удалит счет. А значит лог обновления будет некорректным

Я думаю, что вариант с LOCK само оно.. Лучше вряд ли что придумаешь.
0
12 / 18 / 2
Регистрация: 02.11.2015
Сообщений: 222
20.04.2017, 23:57
Извиняюсь, что не совсем по теме, хотя кто знает.. Просто не гуглится.. Пришёл на эту страницу через поиск.. Существует ли какой-нибудь SQL-запрос (чисто SQL), который вернёт количество затронутых строк последним запросом?
По идеи должен быть..
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.04.2017, 23:57
Помогаю со студенческими работами здесь

Проблемы с обработкой длинных строк на кириллице
Всем привет! Не могу нигде найти ответ на вопрос почему обрезаются строки. есть процедура Код (PHP): Sub Click(Source As Button)...

Реализация консольного калькулятора с обработкой строк
Реализация консольного калькулятора с обработкой строк. Помогите чем кто может, заранее спасибо:)

Подсчитать количество пучтых строк и количество строк,которые начинаются и оканчиваются на одну и ту же букву.
Дан текстовый файл.Подсчитать количество пучтых строк и количество строк,которые начинаются и оканчиваются на одну и ту же...

Поменять местами две средних строки, если количество строк четное, и первую со средней строкой, если количество строк нечетное
поменять местами двесредних строки, если количество строк четное, и первую со средней строкой, если количество строк нечетное

Массив из строк. 1) Подсчитать количество одинаковых строк. 2) Реверс строк
Необходимо 1) Определить число одинаковых слов. 2) Сформировать второй массив, в котором порядок букв в словах изменен на...


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

Или воспользуйтесь поиском по форуму:
25
Ответ Создать тему
Новые блоги и статьи
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов. import "math" func angleClock(hour int, minutes int) float64 { . . .
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html и его же старой инструкции по установке Lazarus с gtk2. . .
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер. Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
попытка написать игровой сервер на C++
pyirrlicht 29.04.2026
попытка написать игровой сервер на плюсах с открытым бесконечным миром. возможно получится прикрутить интерпретатор питон для кастомизации игровой логики. что есть на текущий момент:. . .
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2. Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru