170 похожих чатов

Подскажите, хочу написать функцию для SQL-запросов. Пока какая-то порнография

выходит, вроде такого:

template <typename... ColumnType, class Func, typename... Args>
void sql_exec(string_view query, Func&& result_consumer, Args... query_args)
{
// do query...
while (true) {
std::tuple<Columns...> query_result;
// get next query row, break if no more results
result_consumer(query_result);
}
}

И соответственно вызываться будет как-то так:

sql_exec<int, long, std::string>("SELECT a, b, c FROM table...",
[](const auto& results) {
auto [column1_val, column2_val...] = results;
// process columnX_val data...
}),
query_param1, query_param2...);

Во-первых тип Func неплохо бы как-то проверить/ограничить, во-вторых в целом как-то плохо кажется. Можно ли прилично как-то сделать и как?

10 ответов

27 просмотров

Мне кажется, можно func<> юзать. Да, оверхед, но можно хоть типы извлечь. А в случае, если у тебя api для исполнения sql запросов, сомневаюсь, что оверхед будет заметен прям сильно

Не надо просто пытаться статично описать все наборы данных. DDD и всё.

Kirill-Frolov Автор вопроса
Ilya Zviagin
Не надо просто пытаться статично описать все набор...

Я не понимаю как DDD может быть в языке со статической типизацией. Это же не питон. Конечно идиому "всё есть строка" реализовать тривиально, но оно как-то не очень эффективно потом при работе с большими наборами чисел, даи ошибка в рантайме когда число неожиданно не число -- неудобно.

Alex Noname
Это как вообще

Задавай конкретные вопросы.

Kirill Frolov
Я не понимаю как DDD может быть в языке со статиче...

Что мешает сделать что-то, что умеет пересобираться в пользовательские структуры данных? Вон в userver у них возвращает PgAnswer, который через boost.pfr и маппинги в типы пересобирается в типы пользовательские

std::invocable<...> и уберите оттуда тупл

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Карта сайта