Oracle
 sql >> Teknologi Basis Data >  >> RDS >> Oracle

Masukkan beberapa baris dari R Dataframe ke Oracle Database

Dengan asumsi kolom R dataframe adalah kolom yang persis sama dan dalam urutan yang sama di Oracle (tidak lebih atau kurang), pertimbangkan apply untuk paste dengan runtuh semua nilai di setiap baris:

sqls <- sprintf("INSERT INTO MYTABLE VALUES (%s)", 
                apply(df, 1, function(i) paste(i, collapse=",")))    
sqls
# [1] "INSERT INTO MYTABLE VALUES (2,10,9,50,34,37,29)" 
# [2] "INSERT INTO MYTABLE VALUES (7,24,33,21,21,20,3)" 
# [3] "INSERT INTO MYTABLE VALUES (39,38,2,33,43,33,7)" 
# [4] "INSERT INTO MYTABLE VALUES (30,11,33,1,29,26,11)"
# [5] "INSERT INTO MYTABLE VALUES (50,45,13,27,3,35,36)"
# [6] "INSERT INTO MYTABLE VALUES (41,5,39,17,5,22,5)"  
# [7] "INSERT INTO MYTABLE VALUES (21,50,39,30,2,11,49)"

# RECOMMENDED APPROACH TO SPECIFY COLUMNS
sqls <- sprintf("INSERT INTO MYTABLE (Col1, Col2, Col3, Col4, Col5, Col6, Col7) VALUES (%s)", 
                apply(df, 1, function(i) paste(i, collapse=",")))

connHandle <- odbcConnect("DBName", uid="user", pwd="password")
lapply(sqls, function(s) sqlQuery(connHandle, s))
close(connHandle)

Dan pendekatan yang lebih baik lagi adalah menggunakan parameterisasi dengan RODBCext di mana Anda hanya meneruskan kerangka data asli tanpa loop:

library(RODBCext)

connHandle <- odbcConnect("DBName", uid="user", pwd="password")
query <- "INSERT INTO MYTABLE (Col1, Col2, Col3, Col4, Col5, Col6, Col7) VALUES (?, ?, ?, ?, ?, ?, ?)"
sqlExecute(connHandle, query, df)

odbcClose(connHandle)



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Urutan Oracle tetapi kemudian di MS SQL Server

  2. Pisahkan String dengan posisi pembatas menggunakan Oracle

  3. Panjang dinamis pada format angka di to_number Oracle SQL

  4. Urutkan karakter di varchar2 menurut abjad

  5. jalankan urutan perubahan segera tidak berfungsi