Проблема 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 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Почему многослойные строки с двойными цитатами работают в PHP 8.2 и 8.4 [дублировать]
    Anonymous » » в форуме Php
    0 Ответы
    51 Просмотры
    Последнее сообщение Anonymous
  • Langchain RAG с историей и цитатами
    Anonymous » » в форуме Python
    0 Ответы
    10 Просмотры
    Последнее сообщение Anonymous
  • Помощники Openai с такими цитатами, как 【4: 2 † Источник】 и citeturnxfiley
    Anonymous » » в форуме Python
    0 Ответы
    3 Просмотры
    Последнее сообщение Anonymous
  • Как установить клиент Postgres, совместимый с Postgres 15 [закрыто]
    Anonymous » » в форуме Linux
    0 Ответы
    21 Просмотры
    Последнее сообщение Anonymous
  • Не могу скачать Postgres: 9.6 через "Docker Pull Postgres: 9.6"
    Anonymous » » в форуме Linux
    0 Ответы
    23 Просмотры
    Последнее сообщение Anonymous

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