Итак, я использую 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
Форум по Javascript
-
Anonymous
1750671605
Anonymous
Итак, я использую [b] postgres.js [/b] для создания приложения, и я создаю перечисление для пользовательских ролей, таких как следующее
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>
Подробнее здесь: [url]https://stackoverflow.com/questions/79675946/postgres-js-problem-with-double-quotes-when-creating-an-enum[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия