Support for array parameter in "WHERE IN" clause
Shogobg opened this issue · 1 comments
Shogobg commented
Hello.
I have the following code:
import { Client as LibsqlClient, createClient } from '@libsql/client/web';
...
const res = await client.execute({
sql: 'SELECT * FROM watched_videos WHERE videoId IN (:videos) LIMIT 10;',
args: { videos: ['--0zLNUmhRI', '--1AEHcLmuk'] },
});
Expected behavior:
Given the table has more than 2 records and the records with videoId '--0zLNUmhRI' and '--1AEHcLmuk' exist, the query should return two rows containing the corresponding videoId.
Actual result - no records are returned:
{
"columns": [
"videoId",
"status"
],
"columnTypes": [
"varchar(255)",
"INT",
],
"rows": [],
"rowsAffected": 0,
"lastInsertRowid": null
}
I've looked at the code libsql, and it seems that currently there is no support for an array of values as argument, like the above.
https://github.com/tursodatabase/libsql-client-ts/blob/main/packages/libsql-core/src/api.ts#L422