Search Postgresql Archives

Re: Multiple currencies in a application

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Thanks to the three of you for your thoughts, those are very very helpful
perspectives that are going to help me design this. One note, I won't have
to worry about multiple currencies on the internal bookeeping side of
things, which is a major plus.


Jorge Godoy-2 wrote:
> 
> Alban Hertroys <alban@xxxxxxxxxxxxxxxxx> writes:
> 
>> A few things you'll probably want:
>> - Store prices in your db with their original currency
>> - Make sure you have up-to-date conversion rates (how up to date that
>> needs to be is up to you)
>> - Calculate actual prices on demand
> 
> - Keep the highest precision on prices you can, if you can get sub-cents
> its
>   better
> 
> You'll have to worry with rounding / truncation rules (they differ from
> country to country so you'll have to either state what you do and why this
> might not be accurate or you'll have to code it some way that you can do
> the
> right thing all the time...). 
> 
> If you store up to cents, then you might end up loosing money or charging
> too
> much.  
> 
> If you can get to the fourth decimal place you'll have a safe zone to work
> with cents if you deal with a few thousands units of the product.  The
> more
> you sell / buy, the more decimal places would be interesting to have.  Of
> course, I'm supposing that cents are important, if you're selling / buying
> products that cost thousands or millions of <currency here>, then this
> looses
> that importance (this is relative to how much monetary units the value
> represents in the destination currency).
> 
>> We are satisfied with daily updates to our conversion rates, which we
>> store in a table. Conversion isn't too difficult that way.
> 
> With webservices you can get almost real time rates and you don't even
> have to
> store these rates on your database (even though it is nice to have it for
> summaries and reports and also for auditing operations). 
> 
>> Say you want to convert the price of a product from dollars (the
>> original currency) to euros, your query would look something like this:
>>
>> SELECT price * target.rate / source.rate
>>   FROM products
>>    INNER JOIN rates source ON (products.currency = source.currency),
>> 	rates target
>>  WHERE products.id = 1234
>>    AND target.currency = 'euro';
>>
>> I don't think you'll need any functions, unless to retrieve real-time
>> conversion rates somehow. Otherwise a cron job will do nicely.
> 
> Yep...  There are some apps that request for the rate to be used when you
> login (they usually suppose you'll be working with two currencies: a
> reference
> currency and a local currency).
> 
> 
> I've also seem projects that have an artifical value for each product and
> then
> apply conversion rates from this value to any currency they want. 
> Something
> like making 1 unit equal to 10 cents, so a product that costs 10
> <currency>
> would be stored as costing "100 units".  Then you just have to have a
> conversion table from the basic unit value to the currency you want to
> deal
> with. 
> 
> This makes it easier to update prices and do some historical analisys
> besides
> making it easier to make a comparative analisys of each market.
> 
> 
> I've also seen systems where each "currency" (local, actually) can have a
> different price.  It makes a lot of sense since paying something like 2
> dollars for a coffee on the US doesn't sound all that much but it would be
> a
> robbery here in Brazil if the value of such product was converted to reais
> :-)
> 
> 
> Last but not less important you should also consider how you're going to
> add /
> represent S&H costs, import / export taxes, etc. and how this will impact
> on
> the value you'll be showing to the user.
> 
> 
> This is just the tip of the iceberg, but I hope it helps a little to see
> what
> is important or not for you.
> 
> -- 
> Jorge Godoy      <jgodoy@xxxxxxxxx>
> 
> ---------------------------(end of broadcast)---------------------------
> TIP 2: Don't 'kill -9' the postmaster
> 
> 

-- 
View this message in context: http://www.nabble.com/Multiple-currencies-in-a-application-tf2605959.html#a7498357
Sent from the PostgreSQL - general mailing list archive at Nabble.com.



[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Postgresql Jobs]     [Postgresql Admin]     [Postgresql Performance]     [Linux Clusters]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Postgresql & PHP]     [Yosemite]
  Powered by Linux