我是dplyr包的数据库连接功能的新功能,但我非常有兴趣将其用于sqlite连接.我跟着
this tutorial创建了一个sqlite数据库(my_db)
my_db <- src_sqlite("my_db.sqlite3",create = T)
并将数据帧(df)作为该数据库的表(my_table)插入.
copy_to(my_db,df,"my_table")
现在我想在此表中插入新行.我尝试过这样的东西(是的,我必须承认它甚至看起来不像有前途的…但是我还是尝试一下):
collect(build_sql("INSERT INTO my_table VALUES (",newdf,")",con=my_db))
您可以对通过dplyr创建的数据库/表执行sql操作,但必须还原为Rsqlite / DBI调用,并更改数据库/表的创建方式:
library(dplyr) my_db <- src_sqlite("my_db.sqlite3",create=TRUE) copy_to(my_db,iris,"my_table",temporary=FALSE) # need to set temporary to FALSE # grab the db connection from the object created by src_sqlite # and issue the INSERT That way res <- dbSendQuery(my_db$con,'INSERT INTO my_table VALUES (9.9,9.9,"new")')