Проблема postgres.js с двойными цитатами при создании перечисленияJavascript

Форум по Javascript
Ответить
Anonymous
 Проблема postgres.js с двойными цитатами при создании перечисления

Сообщение Anonymous »

Итак, я использую postgres.js для создания приложения, и я создаю перечисление для пользовательских ролей, таких как следующее
import { PostgresError } from 'postgres';
import sql from './database/index.js';

const RolesEnum = {
user : 'user',
moderator : 'moderator',
admin : 'admin'
} as const;

const Enum = ['user', 'moderator', 'admin'] as const;

async function Build() {
try {
await sql`DROP TYPE F_that;`.catch(() => {}); // IF DOESN'T EXIST THEN PASS
const { statement } = await sql`CREATE TYPE F_that AS ENUM (${sql(
Enum
)});`;
console.log(statement);
} catch (error) {
console.error(
(error as PostgresError).query ?? (error as Error).message ?? error
);
/* Logs the following
CREATE TYPE F_that AS ENUM ( "user", "moderator" , "admin" );*/
}
}

await Build() // Logs the following: CREATE TYPE F_that AS ENUM ( "user", "moderator" , "admin" );`

< /code>
Как вы видите, это двойные цитаты в значениях перечисления, которые дают ошибку в Postgres мой вопрос в том, как сделать их отдельные кавычки в запросе < /p>
Ближайшее решение, которое я получил, было добавлено в блок Catch < /p>
if (error instanceof postgres.PostgresError) {
error.query.replaceAll('"', "'"); // gets query with single quotes for the Enum
}
< /code>
, который дает правильный запрос, но я не могу использовать его, как выше
(всякий раз, когда я пытаюсь получить ошибку о позиционном параметре, я думаю, он работает во время выполнения?) < /p>

Подробнее здесь: https://stackoverflow.com/questions/796 ... ng-an-enum
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Javascript»