在PostgreSQL中,"decimal"是一种数据类型,用于存储带有固定小数位数的数值。它与"numeric"数据类型是等价的,因此在PostgreSQL中也可以使用"numeric"来表示decimal类型。
Decimal类型在存储货币金额,科学计算等需要精确表示小数位数的场景中非常有用。它具有固定精度和范围,可以用于存储大范围的小数值。
在PostgreSQL中,使用DECIMAL或NUMERIC类型来定义decimal数据类型,其语法如下:
DECIMAL(precision, scale)
其中precision是总共的位数,包括小数点前和小数点后的位数,而scale是小数点后的位数。
例如,DECIMAL(10,2)表示总共10位数,其中包括2位小数位数,因此可以存储类似"12345.67"这样的数值。
以下是一个示例:
CREATE TABLE prices ( id SERIAL PRIMARY KEY, product_name VARCHAR(50), price DECIMAL(10,2) );
在上面的示例中,创建了一个名为"prices"的表,包含了产品名称和价格字段,价格字段的数据类型为DECIMAL(10,2),表示价格数据总共有10位数,包括2位小数位数。
这样就可以在数据库中存储精确的小数值,并确保其精度和范围。