如何解决如何截断Presto中的纬度和经度而不舍入或舍弃0s?
我遇到一个问题,我试图将纬度和经度截断为小数点后3位,但我不想ROUND
,因为它会更改位置。
我尝试了CAST((TRUNCATE(lat * 100) / 100) AS VARCHAR)
,但如果这样做,它将删除结尾的零(如果纬度为-122.200,它将返回-122.2
我认为我可以使用RPAD
选择字符串的一部分(在这种情况下为'。'),然后将其填充一定数量的空格(在这种情况下为3个空格。但是当我尝试{{ 1}}返回-12
任何想法都将不胜感激。谢谢!
解决方法
您应该使用正则表达式:
SELECT
regexp_replace( CAST(-122.219980 as varchar),'\.(\d{1,3})\d*','.$1' ),regexp_replace( CAST(-122.200911 as varchar),'.$1' )
将导致:
-122.219 -122.200
如要求。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。