Arhn - архитектура программирования

Синтаксическая ошибка Propel, полученная при использовании зарезервированных ключевых слов в именах таблиц или столбцов

Есть ли способ заставить Propel автоматически экранировать имена столбцов, которые являются зарезервированными словами, при добавлении/обновлении строки?

Прямо сейчас у меня есть столбец с именем «заказ», и когда я пытаюсь обновить с помощью

$row->setOrder(1)->save();

Я получаю синтаксическую ошибку «Неустранимая ошибка PHP: необработанное исключение« PDOException »с сообщением« SQLSTATE [42601]: синтаксическая ошибка: 7 ОШИБКА: синтаксическая ошибка в или около« порядка »\nСТРОКА 1: ОБНОВЛЕНИЕ условий SET порядок = $ 1 ГДЕ условия. идентификатор=$2\n ^'"


Ответы:


1

Я нашел ответ на этот вопрос по адресу http://propelorm.org/documentation/reference/schema.html#database-element.

Добавление параметра identifierQuoting="true" к моему тегу <database> в файле schema.xml устранило проблему. Я считаю, что вы также можете добавить это к тегу <table>, чтобы ограничить его одной таблицей. Я не уверен, почему это не было бы настройкой по умолчанию.

19.03.2016
  • Могу предположить, что это общее правило для всех языков программирования: не использовать зарезервированные слова в качестве идентификаторов :о) 20.03.2016
  • @Abelisto это не просто идентификатор. Это имя столбца. Итак, если у вас есть столбец порядка в вашей логике БД - почему вы должны изменить его на что-то другое? Проще всего избежать полей запроса sql. Фактическая проблема заключается в том, что Propel по умолчанию не экранирует поля/имена. 04.01.2021
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..