用RSQLite只读一些列?

时间:2015-03-25 14:17:21

标签: r dplyr rsqlite

我只想从表中读取3列。现在我正在做一些我认为非常低效的事情

library(dplyr, quietly = T, warn.conflicts = F)
library(RSQLite, quietly = T) 
db <- dbConnect( SQLite() , "SIPP08.db" )
dbListTables(db) 
w13 <- dbReadTable( db , 'w13' )
dbDisconnect(db)

df = w13 %>%
  select(ssuid, epppnum,ejbind1)

有更好的方法吗?

谢谢!


我也试过像这样使用dplyr

my_db <- src_sqlite(path = "SIPP08.db")
w13 <- tbl(my_db, "w13")
df = w13 %>%
  select(ssuid, epppnum,ejbind1)

但它不起作用

1 个答案:

答案 0 :(得分:3)

最好直接查询SQLite数据库,这些内容

library(dplyr)
library(RSQLite)

db <- src_sqlite("SIPP08.db")
df <- tbl(db, sql("SELECT ssuid, epppnum, ejbind1 from wt13"))

我不知道为什么你有list,但你可以使用DBI包和RSQLitedata.frame

library(DBI)
db <- dbConnect(SQLite() , "SIPP08.db")
df <- dbGetQuery(db, "SELECT ssuid, epppnum, ejbind1 from wt13")

我没有您的数据,但第一个代码适用于我使用玩具数据集。