ホーム   フォーラム   FAQ
 
メインメニュー
ログイン
ユーザー名:

パスワード:


パスワード紛失

小数点書式の仕様変更?

  • このフォーラムに新しいトピックを立てることはできません
  • このフォーラムではゲスト投稿が禁止されています
前の投稿 - 次の投稿 | 親投稿 - 子投稿なし | 投稿日時 2010-4-3 17:38
mtaka  新米   投稿数: 5
> 追記 V8 でも変数の書式を N12.0 にすると結果が 90.5 になりました。

そうですか?

変数3つ(A,B,C)の書式をN12.0にして、簡単なオンラインプログラム(C=A/Bみたいな)を作成してみるとV8では小数点1位で、四捨五入され、小数は必ず0で表示されているのを確認してから投稿したんですが・・・・(uniPaaSでは、小数点にごみ?が入る)

なんか環境により左右されるんですかね?(逆に光が見えた!)
書式を許している以上、バグだと思いますんでMSJに確認してみます。
投票数:0 平均点:0.00
前の投稿 - 次の投稿 | 親投稿 - 子投稿なし | 投稿日時 2010-4-3 17:27
mtaka  新米   投稿数: 5
反応ありがとうございます。

私的にもなしですが、V8時代のSQLGateWayの問題だったかどうかあやふやですが、小数点を付けないと桁数が大きすぎますと言われ項目が定義できなかったので、無理やり小数点(.0)を付け内部形式をFloatにする事により回避していたんだと思います。

それでもV8では、どんな計算式を入れても小数点1位で、四捨五入して、小数には0が入っていたので、問題なかったです。
投票数:0 平均点:0.00
前の投稿 - 次の投稿 | 親投稿 - 子投稿.1 | 投稿日時 2010-3-30 15:27 | 最終変更
null  長老   投稿数: 191
> N12.0という書式は有りなのですか?
てっきり、N12 と N12.0 は同じ扱いだと思っていて、N12 で確認していたのですが、
N12.0 で確認すると結果が 90.5 になりました。

書式のところでズームして「数値型書式」で確認すると N12.1 と
同等の編集がされるように見えます。これはもしかすると不具合かもしれませんね。
書式で N12.0 と書いてあるところは N12 に変更した方が良いのかも。

追記 V8 でも変数の書式を N12.0 にすると結果が 90.5 になりました。
投票数:0 平均点:0.00
前の投稿 - 次の投稿 | 親投稿 - 子投稿.1 .2 | 投稿日時 2010-3-30 15:03
Jiro123  長老   投稿数: 271
横槍ですみません。

N12.0という書式は有りなのですか?

構文チェックでエラーにはなりませんが。。。

ドットの右がゼロということは、小数桁はゼロということですよね。

どのような扱いになるのでしょうか。

投票数:0 平均点:0.00
前の投稿 - 次の投稿 | 親投稿 - 子投稿.1 | 投稿日時 2010-3-30 14:37 | 最終変更
null  長老   投稿数: 191
インストール直後の Magic.ini を使用して確認してみましたが、
項目更新で N12 の変数に 1900 * 0.05 / (1 + 0.05) の結果を代入したところ、90 になりました。
もし、91 になるのであれば、設定の問題なのかもしれませんがそれらしい設定は見当たりません。

設定で直らないようであれば、計算結果を Fix() 関数で切り捨てするしか無いでしょう。
投票数:0 平均点:0.00
前の投稿 - 次の投稿 | 親投稿 - 子投稿.1 | 投稿日時 2010-3-27 17:54
mtaka  新米   投稿数: 5
V8のアプリで、金額の書式をN12.0で設定しているプログラムがあります。
これをuniPaaSに持ってくると動作が変わります。

V8 :小数点1桁目を四捨五入

(例)項目A = 1900 * 0.05 / ( 1 + 0.05 )

項目Aは、90.0

uniPaaS:小数点2桁目を四捨五入

(例)項目A = 1900 * 0.05 / ( 1 + 0.05 )

項目Aは、90.5

上記結果をDB(numeric12.0)に設定すると1円の誤差が出てしまいます。
答えを同じ値にする方法が、INI等の動作で変更する事が可能でしょうか?
投票数:0 平均点:0.00

  条件検索へ


Copyright (C) Magic Software Japan K.K. All Rights Reserved.
個人情報保護方針 会員規約