Maison >base de données >tutoriel mysql >Comment puis-je transmettre des variables R aux requêtes SQL à l'aide de la fonction sqlQuery de RODBC ?

Comment puis-je transmettre des variables R aux requêtes SQL à l'aide de la fonction sqlQuery de RODBC ?

Barbara Streisand
Barbara Streisandoriginal
2024-12-30 22:59:101017parcourir

How Can I Pass R Variables to SQL Queries Using RODBC's sqlQuery Function?

Transmettre la variable R à sqlQuery de RODBC

Dans le package RODBC, transmettre des variables R à la fonction sqlQuery permet l'exécution de requêtes dynamiques. Voici comment y parvenir pour différents scénarios :

Fonction scalaire/à valeur table et procédure stockée

Pour transmettre une variable à une fonction scalaire/à valeur table ou stockée procédure, utilisez la fonction paste() pour construire la chaîne de requête. Par exemple :

x <- 1
example <- sqlQuery(myDB, paste("SELECT * FROM dbo.my_table_fn (", x, ")"))

Clause WHERE

Pour passer une variable à la clause WHERE d'une instruction SELECT, utilisez la fonction sprintf() :

example2 <- sqlQuery(myDB, sprintf("SELECT * FROM dbo.some_random_table AS foo WHERE foo.ID = %d", x))

Exécution de procédure stockée

Pour exécuter une procédure stockée avec un argument, utilisez sprintf :

example3 <- sqlQuery(myDB, sprintf("EXEC dbo.my_stored_proc (%d)", x))

En construisant la chaîne de requête de manière dynamique, vous pouvez transmettre des variables R comme arguments aux fonctions et instructions SQL.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn