@morpheus93 said in Ожидание сразу нескольких элементов. Как?:
@Fox Is there also an OR / AND selector for element finding by MATCH? And any possibility to search for picture with or /and?
No, only using the @UserTrue module
@Bigma said in Как в SQL сделать сразу несколько запросов в одном действии:
@sergerdn индекс есть?
CREATE TABLE `wp_users` (
`ID` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
`user_login` varchar(60) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '',
`user_pass` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '',
`user_nicename` varchar(50) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '',
`user_email` varchar(100) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '',
`user_url` varchar(100) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '',
`user_registered` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
`user_activation_key` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '',
`user_status` int(11) NOT NULL DEFAULT 0,
`display_name` varchar(250) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '',
PRIMARY KEY (`ID`),
KEY `user_login_key` (`user_login`),
KEY `user_nicename` (`user_nicename`),
KEY `user_email` (`user_email`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci
@Bigma said in Как в SQL сделать сразу несколько запросов в одном действии:
@sergerdn Завтра гляну, с телефона сам понимаешь.
Не понимаю, так как мне неизвестно, чтобы UPDATE возвращал что-то сверх того, что я дал выше. Я понимаю, что я не DBA и легко могу не знать что-то и это прям нормально. Всего знать невозможно. Поэтому я и попросил пример запроса UPDATE , где он возвращает id обновленных записей.
Следующим запросом можно получить инфу, что обновилось, но это будет следующий запрос и мы опять наткнулись, что другой поток может между двумя запросами вмешаться и сделать свою работу. Тогда мы получим не то, что ожидаем.
Щас глянуть не могу, что он возвращает в ответ, но можно писать ведь не 1, а номер потока к примеру, или рендом. И по этому числу искать запись. Проверю завтра.
@Bigma said in Как в SQL сделать сразу несколько запросов в одном действии:
Щас глянуть не могу, что он возвращает в ответ, но можно писать ведь не 1 а номер потока к примеру, или рендом. И по этому числу искать запись. Проверю завтра.
Да многое можно, а потом посмотреть на свой код и понять, что ты сделал функционал SELECT FOR UPDATE.
P.S.
У меня была такая история.
@Bigma said in Как в SQL сделать сразу несколько запросов в одном действии:
@sergerdn Как ты уже написал, она лочит всю таблицу, имей это ввиду.
Я же сам это написал, конечно я имею в виду. И так же добавил, что эта информация может быть устаревшая и надо ее проверять. Может у современных реализаций INNODB немного не так. Может лочится только одна запись в таблице на чтение. Чтобы другой поток не захватил ее.
Под капотом БД многое что делается, другое дело, что ты не знаешь об этом и "спишь спокойно".
@Shogo, многострочный запрос и несколько запросов в одном, это не одно и тоже, модуль поддерживает многострочные запросы, но не поддерживает несколько запросов в одном, так как либо они не поддерживаются в конкретном диалекте или отключены по умолчанию. Например в MySQL и MariaDB, несколько запросов в одном отключены по умолчанию, а чтобы их включить нужно добавить multipleStatements: true в настройки диалекта.