Мне все еще нужен красноречивый десятичный актер для десятичных (10,6) колонн в Laravel 12 / Php 8.2?Php

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Мне все еще нужен красноречивый десятичный актер для десятичных (10,6) колонн в Laravel 12 / Php 8.2?

Сообщение Anonymous »

Я строю сайт E -Commerce Laravel 12 (PHP 8.2).

Цены на продукты хранятся в MySQL как десятичный (10,6): < /p>
base_price DECIMAL(10,6),
profit DECIMAL(10,6)
< /code>
Многие статьи рекомендуют добавить актерский состав в модели, чтобы избежать ошибок с плавающей точкой: < /p>
App\Models\Product
protected function casts(): array
{
return [
'base_price' => 'decimal:6',
'profit' => 'decimal:6',
];
}
< /code>
Что я попробовал < /strong> < /p>

без листа и с десятичным знаком: 6 лист я получаю точно одинаковые результаты в моих расчетах. < /li>
Простой тест: < /li>
< /ul>

< /li>
< /ul>
$a = "1097.500000";
$b = "835.700000";
$c = $a - $b;
dd($c); // 261.8 (as expected)
< /code>
< /blockquote>
нет проблем с видимыми точности. < /p>

У меня также есть более сложный код, который касается прибыли, Base_price, Profer_price и вычислений с дисконтом пользователя-и до сих пор я не сталкивался с какими-либо проблемами с плавающей точкой или в результатах. />
$priceSource = (is_numeric($product->offer_price) && $product->offer_price != 0)
? $product->offer_price
: $product->base_price;

$grossPrice = $priceSource + $product->profit;
$price = $grossPrice - ($grossPrice * $userVipDiscount / 100);
< /code>
< /blockquote>
my confusive < /strong> < /p>

Если столбец уже десятичный (10,6), все еще нужен лит? Избыточный?>

Подробнее здесь: https://stackoverflow.com/questions/796 ... laravel-12
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

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