Я использую библиотеку mssql, в которой есть это interface
:
export interface IRecordSet<T> extends Array<T> {
columns: IColumnMetadata;
toTable(name?: string): Table;
}
У меня есть функция, которая получает данные из базы данных и возвращает массив IRecordSet<T>
, так что это массив массивов, которые содержат универсальный тип <T>
. Это выглядит так:
[[{}, {}, ...], [{}, {}, ...], ...]
import { IRecordSet } from 'mssql'
type Data<T> = Array<IRecordSet<T>>
async function getData (sql: string): Promise<Data<any>> {
// connect to db, run sql
return []
}
Теперь мне нужна функция, которая вызывает getData()
, и я хотел бы ввести фактические возвращенные данные, указав общий тип в IRecordSet<T>
.
Я знаю, что это не работает, но это то, что у меня есть прямо сейчас:
interface BookData {
name: string
author: string
}
interface CarData {
make: string
model: string
}
type BooksAndCars = Data<[BookData, CarData]>
async function getBooksAndCars (): Promise<void> {
const myData: BooksAndCars = await getData(`
SELECT name, author FROM Books;
SELECT make, model FROM Cars;
`)
const firstBook: BookData = myData[0][0]
const cars: CarData[] = myData[1]
// ...
}
Машинописный текст говорит:
Type '[BookData, CarData]' is not assignable to type 'BookData'.
Type 'IRecordSet<[BookData, CarData]>' is not assignable to type 'CarData[]'.
Я понимаю эти ошибки, но я не знаю, как ввести myData
, firstBook
& cars
переменные, использующие определенные интерфейсы (BookData
& CarData
).
Что должно type BooksAndCars = Data<[BookData, CarData]>
быть...?