我正在制作Flask-SqlAlchemy应用程序.在一个模型中,我想将地理代码数据存储为纬度/经度.
从阅读其他帖子,我应该使用数字而不是浮动.
类型Numeric的文档列出了几个可用的参数:
precision=None, asdecimal=False, decimal_return_scale=None
Run Code Online (Sandbox Code Playgroud)
所以我尝试添加一列作为
db.Column(db.Numeric, precision=8, asdecimal=False, decimal_return_scale=None) — as the equivalent of DECIMAL(10,8)
Run Code Online (Sandbox Code Playgroud)
哪个返回错误:
"Unknown arguments passed to Column: " + repr(list(kwargs)))
Run Code Online (Sandbox Code Playgroud)
sqlalchemy.exc.ArgumentError:传递给Column的未知参数:['asdecimal','decimal_return_scale','precision']
如果我使用db.Column(db.Numeric),我可以创建表并写入它.
如果我在这里传递的语法错误,有人会向我解释:db.Column(db.Numeric,precision = 8,asdecimal = False,decimal_return_scale = None) - 相当于DECIMAL(10,8)
使用/定义数值类型列的正确方法是什么.
小智 7
您应该将额外的参数添加到db.Numeric,而不是db.Column:
db.Column(db.Numeric(precision=8, asdecimal=False, decimal_return_scale=None))
Run Code Online (Sandbox Code Playgroud)
小智 6
你也可以
db.Column(db.Numeric(10,2))
Run Code Online (Sandbox Code Playgroud)
第一个元素是整数位数,第二个参数表示小数位数.
| 归档时间: |
|
| 查看次数: |
7701 次 |
| 最近记录: |