diff --git a/src/types.js b/src/types.js index aff1e373..d935e21d 100644 --- a/src/types.js +++ b/src/types.js @@ -213,6 +213,17 @@ export const escapeIdentifier = function escape(str) { return '"' + str.replace(/"/g, '""').replace(/\./g, '"."') + '"' } +const defaultArrayTypes = { + "boolean": 1000, + "number": 1021, + "string": 1009, + "bigint": 1016, +}; + +export const inferArrayType = function inferArrayType(x) { + return defaultArrayTypes[typeof x[0]] || inferType(x[0]); +} + export const inferType = function inferType(x) { return ( x instanceof Parameter ? x.type : @@ -220,7 +231,7 @@ export const inferType = function inferType(x) { x instanceof Uint8Array ? 17 : (x === true || x === false) ? 16 : typeof x === 'bigint' ? 20 : - Array.isArray(x) ? inferType(x[0]) : + Array.isArray(x) ? inferArrayType(x) : 0 ) } diff --git a/tests/index.js b/tests/index.js index 576cb7d4..88efa8f6 100644 --- a/tests/index.js +++ b/tests/index.js @@ -92,6 +92,22 @@ t('Boolean false', async() => [false, (await sql`select ${ false } as x`)[0].x] ) +t('Boolean[] [true, false]', async() => + ["[true,false]", JSON.stringify((await sql`select ${ [true, false] }::bool[] as x`)[0].x)] +) + +t('Number[] [1, 2]', async() => + ["[1,2]", JSON.stringify((await sql`select ${ [1, 2] }::int4[] as x`)[0].x)] +) + +t('String[] ["a", "b"]', async() => + ['["a","b"]', JSON.stringify((await sql`select ${ ["a", "b"] }::text[] as x`)[0].x)] +) + +t('BigInt[] [BigInt(1), BigInt(2)]', async() => + ['[1,2]', JSON.stringify((await sql`select ${ [BigInt(1), BigInt(2)] }::float4[] as x`)[0].x)] +) + t('Boolean true', async() => [true, (await sql`select ${ true } as x`)[0].x] ) @@ -125,7 +141,7 @@ t('String array', async() => ) t('Array of Integer', async() => - ['3', (await sql`select ${ sql.array([1, 2, 3]) } as x`)[0].x[2]] + [3, (await sql`select ${ sql.array([1, 2, 3]) } as x`)[0].x[2]] ) t('Array of String', async() => @@ -138,11 +154,11 @@ t('Array of Date', async() => { }) t('Nested array n2', async() => - ['4', (await sql`select ${ sql.array([[1, 2], [3, 4]]) } as x`)[0].x[1][1]] + [4, (await sql`select ${ sql.array([[1, 2], [3, 4]]) } as x`)[0].x[1][1]] ) t('Nested array n3', async() => - ['6', (await sql`select ${ sql.array([[[1, 2]], [[3, 4]], [[5, 6]]]) } as x`)[0].x[2][0][1]] + [6, (await sql`select ${ sql.array([[[1, 2]], [[3, 4]], [[5, 6]]]) } as x`)[0].x[2][0][1]] ) t('Escape in arrays', async() =>