首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Flask-SQLAlchemy数值类型

Flask-SQLAlchemy数值类型
EN

Stack Overflow用户
提问于 2016-09-10 06:55:20
回答 2查看 19.2K关注 0票数 8

我正在做一个Flask-SqlAlchemy应用程序。在一个模型中,我希望将地理代码数据存储为经度/经度。

从阅读其他帖子来看,我应该使用数字而不是浮点数。

Numeric类型的文档列出了几个可用的参数:

代码语言:javascript
复制
precision=None, asdecimal=False, decimal_return_scale=None

因此我尝试添加一个列,如下所示

代码语言:javascript
复制
db.Column(db.Numeric, precision=8, asdecimal=False, decimal_return_scale=None) — as the equivalent of DECIMAL(10,8)

这返回了一个错误:

代码语言:javascript
复制
 "Unknown arguments passed to Column: " + repr(list(kwargs)))

sqlalchemy.exc.ArgumentError:传递给列的未知参数:'asdecimal','decimal_return_scale','precision‘

如果我使用db.Column(db.Numeric),我就能够创建表并对其进行写操作。

谁能解释一下我在这里传递的内容中是否存在语法错误: db.Column(db.Numeric,precision=8,asdecimal=False,decimal_return_scale=None) -等同于DECIMAL(10,8)

使用/定义数值类型列的正确方式是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-12-20 18:53:48

您应该将额外的参数添加到db.Numeric,而不是db.Column:

代码语言:javascript
复制
db.Column(db.Numeric(precision=8, asdecimal=False, decimal_return_scale=None))
票数 18
EN

Stack Overflow用户

发布于 2017-02-24 07:42:18

你也可以这样做

代码语言:javascript
复制
db.Column(db.Numeric(10,2))

其中第一个元素是整数位的数量,第二个参数表示小数位的数量。

票数 26
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39420754

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档