Making progress on getting SQL Server working.

This commit is contained in:
Sam Rose 2024-03-12 12:25:30 +00:00
parent d1f876d67f
commit 477d17b53e
No known key found for this signature in database
3 changed files with 61 additions and 41 deletions

View File

@ -438,7 +438,7 @@ describe.each([
})
describe("view save", () => {
it.only("views have extra data trimmed", async () => {
it("views have extra data trimmed", async () => {
const table = await createTable({
type: "table",
name: "orders",
@ -1604,35 +1604,35 @@ describe.each([
})
describe.each([
[
"relationship fields",
(): Record<string, FieldSchema> => ({
user: {
name: "user",
relationshipType: RelationshipType.ONE_TO_MANY,
type: FieldType.LINK,
tableId: o2mTable._id!,
fieldName: "fk_o2m",
},
users: {
name: "users",
relationshipType: RelationshipType.MANY_TO_MANY,
type: FieldType.LINK,
tableId: m2mTable._id!,
fieldName: "fk_m2m",
},
}),
(tableId: string) =>
config.api.row.save(tableId, {
name: uuid.v4(),
description: generator.paragraph(),
tableId,
}),
(row: Row) => ({
_id: row._id,
primaryDisplay: row.name,
}),
],
// [
// "relationship fields",
// (): Record<string, FieldSchema> => ({
// user: {
// name: "user",
// relationshipType: RelationshipType.ONE_TO_MANY,
// type: FieldType.LINK,
// tableId: o2mTable._id!,
// fieldName: "fk_o2m",
// },
// users: {
// name: "users",
// relationshipType: RelationshipType.MANY_TO_MANY,
// type: FieldType.LINK,
// tableId: m2mTable._id!,
// fieldName: "fk_m2m",
// },
// }),
// (tableId: string) =>
// config.api.row.save(tableId, {
// name: uuid.v4(),
// description: generator.paragraph(),
// tableId,
// }),
// (row: Row) => ({
// _id: row._id,
// primaryDisplay: row.name,
// }),
// ],
[
"bb reference fields",
(): Record<string, FieldSchema> => ({
@ -1960,8 +1960,8 @@ describe.each([
]
await config.api.row.save(tableId, rows[0])
await config.api.row.save(tableId, rows[1])
await config.api.row.save(tableId, rows[2])
// await config.api.row.save(tableId, rows[1])
// await config.api.row.save(tableId, rows[2])
const res = await config.api.row.search(tableId)

View File

@ -14,6 +14,8 @@ import {
Schema,
TableSourceType,
DatasourcePlusQueryResponse,
FieldType,
FieldSubtype,
} from "@budibase/types"
import {
getSqlQuery,
@ -26,7 +28,7 @@ import {
import Sql from "./base/sql"
import { MSSQLTablesResponse, MSSQLColumn } from "./base/types"
import { getReadableErrorMessage } from "./base/errorMapping"
import sqlServer from "mssql"
import sqlServer, { IRecordSet, IResult } from "mssql"
const DEFAULT_SCHEMA = "dbo"
@ -503,10 +505,34 @@ class SqlServerIntegration extends Sql implements DatasourcePlus {
const operation = this._operation(json)
const queryFn = (query: any, op: string) => this.internalQuery(query, op)
const processFn = (result: any) =>
result.recordset ? result.recordset : [{ [operation]: true }]
result.recordset
? this._postProcessJson(json, result.recordset)
: [{ [operation]: true }]
return this.queryWithReturning(json, queryFn, processFn)
}
_postProcessJson(json: QueryJson, results: IRecordSet<any>) {
const table = json.meta?.table
if (!table) {
return results
}
for (const [name, field] of Object.entries(table.schema)) {
if (
field.type === FieldType.JSON ||
(field.type === FieldType.BB_REFERENCE &&
field.subtype === FieldSubtype.USERS)
) {
const fullName = `${table.name}.${name}`
for (let row of results) {
if (typeof row[fullName] === "string") {
row[fullName] = JSON.parse(row[fullName])
}
}
}
}
return results
}
async getExternalSchema() {
// Query to retrieve table schema
const query = `

View File

@ -1,10 +1,4 @@
import {
Row,
SearchFilters,
SearchParams,
SortOrder,
SortType,
} from "@budibase/types"
import { Row, SearchFilters, SearchParams, SortOrder } from "@budibase/types"
import { isExternalTableID } from "../../../integrations/utils"
import * as internal from "./search/internal"
import * as external from "./search/external"