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

Привет парни, я не профи, могли бы подсказать кто работал

с ClickHouse?
Необходимо производить INSERT датасета из 10-20тыс записей - за 1 запрос.
Использую асинхронную либу aiochclient.

По оф доке не совсем понятно как передать датасет из НЕСКОЛЬКИХ строк а не 1 за раз (

Пример INSERT-тa, из доки aiochclient:

`await client.execute(
"INSERT INTO t VALUES",
(1, (dt.date(2018, 9, 7), None)),
(2, (dt.date(2018, 9, 8), 3.14)),
)`

Тут то все ясно, но как вставвить строки не руками через запятую как аргументы, а нормально, например просто целым списком?

Если делаю так, например:

`data = ((1, (dt.date(2018, 9, 7), None)), (2, (dt.date(2018, 9, 8), 3.14)))`

`await client.execute(
"INSERT INTO t VALUES",
data,
)`

Получаю:
aiochclient.exceptions.ChClientError: Code: 53. DB::Exception: Type mismatch in IN or VALUES section. Expected: String. Got: Tuple: While executing ValuesBlockInputFormat. (TYPE_MISMATCH) (version 21.10.2.15 (official build))


Спасибо если кто поможет))

2 ответов

28 просмотров

Вместо ручками можно звездочку использовать print(*data_list) Как пример. Правда хз что будет если так с 300к строками сделать )

🇰 🇦 🇿 🇦 🇭- Автор вопроса

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

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

Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
А чем вам питонисты не угодили?😂
.
79
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
Всем привет. Поделитесь, пожалуйста, опытом. Есть форма, на которой имеется dbgrid и кнопки: добавить, редактировать, удалить. Если нет записей в dbgrid, то кнопки редактирова...
Евгений
5
type TExtensions<GExtender>=class function GetExtension<GEntityExtenderType>:GEntityExtenderType; end; function TExtensions<GExtender>.GetExtension<GEntityExtenderType...
zamtmn
8
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Всем привет, препод задал вопрос, подскажите пожалуйста, какой адрес инкапсулирует указатель?
Свинка Пеппа
8
Почему никто ещё не написал квантовую виртуальную машину на Windows?
КТ315
7
Вот смотрите у меня есть два стрима сейчас fs, cs: TStream; fs := TFileStream.Create('filename'); cs := TCompressionStream.Create(compression_level, fs); Я хочу сделать так: ...
notme
5
Карта сайта