При использовании библиотеки Nodejs mysql2 я пытаюсь понять различия между connection.execute и connection.query.
Как я понимаю, запрос готовит оператор локально, а затем делает один вызов в базу данных. Выполнить отправляет запрос без параметров в подготовленную базу данных, а затем отправляет параметры отдельно для выполнения с подготовленным оператором. Оператор кэшируется при использовании connection.execute . Имеет ли вызов connection.execute два раза в строке с одним и тем же запросом? улучшение производительности.
Однако в функции B2 < /code>, оператор повторно используется, или в базе данных делается четыре отдельных сетевых вызова? В случае повторного использования оператора в B2 , будет ли B3 самым быстрым вариантом? >async function B1(connection) {
const statement = await connection.prepare("SELECT 1 + ? + ?");
const result1 = await statement.execute([1, 2]);
const result2 = await statement.execute([3, 4]);
await statement.close();
return [result1, result2];
}
async function B2(connection) {
const result1 = await connection.execute("SELECT 1 + ? + ?", [1, 2]);
const result2 = await connection.execute("SELECT 1 + ? + ?", [3, 4]);
return [result1, result2];
}
async function B3(connection) {
const result1 = await connection.query("SELECT 1 + ? + ?", [1, 2]);
const result2 = await connection.query("SELECT 1 + ? + ?", [3, 4]);
return [result1, result2];
}
Подробнее здесь: https://stackoverflow.com/questions/794 ... -in-mysql2
В чем польза для использования выполнения по запросу в MySQL2? ⇐ MySql
Форум по Mysql
-
Anonymous
1740541768
Anonymous
При использовании библиотеки Nodejs mysql2 я пытаюсь понять различия между connection.execute и connection.query.
Как я понимаю, запрос готовит оператор локально, а затем делает один вызов в базу данных. Выполнить отправляет запрос без параметров в подготовленную базу данных, а затем отправляет параметры отдельно для выполнения с подготовленным оператором. Оператор кэшируется при использовании connection.execute . Имеет ли вызов connection.execute два раза в строке с одним и тем же запросом? улучшение производительности.
Однако в функции B2 < /code>, оператор повторно используется, или в базе данных делается четыре отдельных сетевых вызова? В случае повторного использования оператора в B2 , будет ли B3 самым быстрым вариантом? >async function B1(connection) {
const statement = await connection.prepare("SELECT 1 + ? + ?");
const result1 = await statement.execute([1, 2]);
const result2 = await statement.execute([3, 4]);
await statement.close();
return [result1, result2];
}
async function B2(connection) {
const result1 = await connection.execute("SELECT 1 + ? + ?", [1, 2]);
const result2 = await connection.execute("SELECT 1 + ? + ?", [3, 4]);
return [result1, result2];
}
async function B3(connection) {
const result1 = await connection.query("SELECT 1 + ? + ?", [1, 2]);
const result2 = await connection.query("SELECT 1 + ? + ?", [3, 4]);
return [result1, result2];
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79468427/whats-the-benefit-to-using-execute-over-query-in-mysql2[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия