dbSendQuery
lub dbGetQuery
dotyczy tylko części "SQL", a nie poleceń psql, takich jak \i
.
W twoim przypadku najprostszym jest użycie readLines
ale potem zawiń dbGetQuery
w sapply
zadzwoń.
con <- dbConnect(...) #Fill this as usual
queries <- readLines("query.sql")
sapply(queries, function(x) dbGetQuery(con,x))
dbDisconnect(con)
Ponieważ używam tego bardzo często, mam skrót do tego w moim .Rprofile
plik:
dbGetQueries<-function(con,queries)sapply(queries,function(x)dbGetQuery(con,x))
Oczywiście możesz również przejść do system
sposób:
system("psql -U username -d database -h 127.0.0.1 -p 5432 -f query.sql") #Remember to use your actual username, database, host and port