Squeak.ru - шаблоны программирования

Доктрина 2, десятичное число может содержать только 14 цифр.

РЕДАКТИРОВАТЬ: это было только что подтверждено как ошибка в Doctrine 2 http://www.doctrine-project.org/jira/browse/DDC-1112?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15724#action_15724


У меня есть объект Doctrine 2, и значение отображается следующим образом (с обычным геттером/сеттером):

/**
 * @Column(type="decimal", precision=40, scale=30)
 */
protected $someValue;

/**
 * @return decimal
 */
public function getSomeValue()
{
    return $this->someValue;
}

/**
 * @param decimal $someValue
 */
public function setSomeValue($someValue)
{
    $this->someValue = $someValue;
}

Когда я устанавливаю это значение из своего кода, оно правильно записывается в базу данных. Но, и это моя проблема, когда я получаю значение (через геттер или \Doctrine\Common\Util\Debug::dump()), он всегда дает мне число с максимальным числом 14 цифр и округляет значение. Прочитал запись с дефолтным findById().

eg: with value 1234567890.012345678901234567890123456789 I have 1234567890.0123
eg: with value 890.0123456789012345678901234567890123456 I have 890.01234567890

Мне, конечно, нужны все цифры, а не только 14. Поле в MySQL объявляется так:

someValue decimal(40,30) NOT NULL,

Когда я получаю значение с необработанным PHP и mysql_query(), оно возвращается правильно.

Изменить: похоже, проблема в том, что Doctrine возвращает число с плавающей запятой:

["someValue":protected]=> float(234567890.01235)

Что не так, что мне проверить дальше, как исправить, какие-нибудь подсказки?

12.04.2011

Ответы:


1

Похоже, что Doctrine2 возвращает значение с плавающей запятой и работает с точность с плавающей запятой в то время как mysql_query() возвращает значение в виде строки. Вы можете сделать var_dump() для каждой возвращаемой переменной и увидеть скалярный тип.

12.04.2011
  • похоже, что он действительно возвращает число с плавающей запятой: [someValue:protected]=› float(234567890.01235) это что-то, что я сделал неправильно или как мне это исправить? 12.04.2011
  • Если вы просто собираетесь отображать число, может быть способ, чтобы Doctrine возвращала значение в виде строки, но я не знаю Doctrine. Если вы собираетесь заниматься математикой, вы можете либо округлить ее до известного уровня точности. В файле ini есть настройка, которую вы можете изменить, чтобы увеличить количество цифр точность, но всегда есть предел. Лучшее объяснение можно найти здесь. 12.04.2011
  • подтверждено как ошибка, надеюсь, они скоро это исправят, спасибо за ваш вклад! 12.04.2011
  • Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

    Веселье с прокси-сервером JavaScript
    Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...