Итак, я использую 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
Проблема postgres.js с двойными цитатами при создании перечисления ⇐ Javascript
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Почему многослойные строки с двойными цитатами работают в PHP 8.2 и 8.4 [дублировать]
Anonymous » » в форуме Php - 0 Ответы
- 51 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Помощники Openai с такими цитатами, как 【4: 2 † Источник】 и citeturnxfiley
Anonymous » » в форуме Python - 0 Ответы
- 3 Просмотры
-
Последнее сообщение Anonymous
-