首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将dbGetQuery设置为将integer64返回为整数

将dbGetQuery设置为将integer64返回为整数
EN

Stack Overflow用户
提问于 2017-07-18 15:54:05
回答 2查看 5.6K关注 0票数 20

默认情况下,当我从dbGetQuery()包中使用DBI时,它会将类型为integer64的列作为bit64integer64类返回。

然后,我使用dplyr尝试并过滤和操作我的结果,但是由于dplyr不支持integer64类型的对象,所以会遇到问题。

是否可以将dbGetQuery()设置为将integer64列返回为integer

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-12-08 09:55:35

DBI规范通过bigint参数提供此功能。司机之间的支持显然会有所不同。

代码语言:javascript
复制
dbConnect(drv, bigint="integer", ...)

以下值的行为如下:

“整数”:总是以整数的形式返回,无声溢出。 “数字”:总是以数字的形式返回,静默地循环。 “字符”:始终将十进制表示形式返回为字符 "integer64":作为数据类型返回,可以使用as.integer() (在溢出时发出警告)、as.numeric()和as.character()强制执行

来源:17

票数 20
EN

Stack Overflow用户

发布于 2017-07-18 21:59:18

即使没有64位整数的完全支持(请参阅GitHub问题),仍然可以使用dplyr进行integer64的变异。

代码语言:javascript
复制
library(dplyr, warn.conflicts = FALSE)
df <- data_frame(a = bit64::as.integer64(1:3), b = 1:3, c = 1.5:4)
df
#> # A tibble: 3 x 3
#>                 a     b     c
#>   <S3: integer64> <int> <dbl>
#> 1               1     1   1.5
#> 2               2     2   2.5
#> 3               3     3   3.5
df %>% mutate_if(bit64::is.integer64, as.integer)
#> # A tibble: 3 x 3
#>       a     b     c
#>   <int> <int> <dbl>
#> 1     1     1   1.5
#> 2     2     2   2.5
#> 3     3     3   3.5
票数 14
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45171762

复制
相关文章

相似问题

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