Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
clickhouse-query-in-body
Advanced tools
Client for ClickHouse. Forked from TimonKK/clickhouse. Put sql query in request body to support looooong query
Forked from TimonKK/clickhouse.
Send query in post data to support very long query.
const clickhouse = new ClickHouse();
or with all options:
```javascript
const clickhouse = new ClickHouse({
url: 'http://localhost',
port: 8123,
debug: false,
basicAuth: null,
isUseGzip: false,
format: "json", // "json" || "csv" || "tsv"
raw: false,
config: {
session_id : 'session_id if neeed',
session_timeout : 60,
output_format_json_quote_64bit_integers : 0,
enable_http_compression : 0,
database : 'my_database_name',
},
// This object merge with request params (see request lib docs)
reqParams: {
...
}
});
or change
basicAuth: null
to
basicAuth: {
username: 'default',
password: '',
},
Exec query:
const queries = [
'DROP TABLE IF EXISTS session_temp',
`CREATE TABLE session_temp (
date Date,
time DateTime,
mark String,
ips Array(UInt32),
queries Nested (
act String,
id UInt32
)
)
ENGINE=MergeTree(date, (mark, time), 8192)`,
'OPTIMIZE TABLE ukit.loadstat PARTITION 201807 FINAL',
];
for (const query of queries) {
const r = await clickhouse.query(query).toPromise();
console.log(query, r);
}
Exec by callback way:
clickhouse.query(query).exec(function (err, rows) {
...
});
Stream:
clickhouse.query(`SELECT number FROM system.numbers LIMIT 10`).stream()
.on('data', function() {
const stream = this;
stream.pause();
setTimeout(() => {
stream.resume();
}, 1000);
})
.on('error', err => {
...
})
.on('end', () => {
...
});
or async stream:
// async iteration
for await (const row of clickhouse.query(sql).stream()) {
console.log(row);
}
As promise:
const rows = await clickhouse.query(query).toPromise();
// use query with external data
const rows = await clickhouse
.query('SELECT * AS count FROM temp_table', {
external: [
{
name: 'temp_table',
data: e._.range(0, rowCount).map((i) => `str${i}`),
},
],
})
.toPromise();
Set session:
clickhouse.sessionId = '...';
const r = await clickhouse
.query(
`CREATE TEMPORARY TABLE test_table
(_id String, str String)
ENGINE=Memory`
)
.toPromise();
In case your application requires specific sessions to manage specific data then you can send session_id
with each query.
let mySessionId = 'some_randome_string';
const r = await clickhouse
.query(
`CREATE TEMPORARY TABLE test_table
(_id String, str String)
ENGINE=Memory`,
{},
{ sessionId: mySessionId }
)
.toPromise();
Insert stream:
const ws = clickhouse.insert('INSERT INTO session_temp').stream();
for (let i = 0; i <= 1000; i++) {
await ws.writeRow([
e._.range(0, 50)
.map((j) => `${i}:${i * 2}:${j}`)
.join('-'),
]);
}
//wait stream finish
const result = await ws.exec();
Pipe readable stream to writable stream (across transform):
const rs = clickhouse.query(query).stream();
const tf = new stream.Transform({
objectMode: true,
transform: function (chunk, enc, cb) {
cb(null, JSON.stringify(chunk) + '\n');
},
});
clickhouse.sessionId = Date.now();
const ws = clickhouse.insert('INSERT INTO session_temp2').stream();
const result = await rs.pipe(tf).pipe(ws).exec();
Run Tests:
npm install
npm run test
# or
# node_modules/.bin/mocha --timeout 60000 --slow 5000 -f "SPECIFIC TEST NAME"
Changelogs:
Links
FAQs
Client for ClickHouse. Forked from TimonKK/clickhouse. Put sql query in request body to support looooong query
The npm package clickhouse-query-in-body receives a total of 6 weekly downloads. As such, clickhouse-query-in-body popularity was classified as not popular.
We found that clickhouse-query-in-body demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.