Sqoop - Eval

Ce chapitre décrit comment utiliser l'outil Sqoop 'eval'. Il permet aux utilisateurs d'exécuter des requêtes définies par l'utilisateur sur les serveurs de base de données respectifs et de prévisualiser le résultat dans la console. Ainsi, l'utilisateur peut s'attendre à ce que les données de table résultantes soient importées. En utilisant eval, nous pouvons évaluer tout type de requête SQL qui peut être une instruction DDL ou DML.

Syntaxe

La syntaxe suivante est utilisée pour la commande Sqoop eval.

$ sqoop eval (generic-args) (eval-args) 
$ sqoop-eval (generic-args) (eval-args)

Sélectionnez Évaluation de la requête

En utilisant l'outil eval, nous pouvons évaluer tout type de requête SQL. Prenons un exemple de sélection de lignes limitées dans leemployee tableau de dbbase de données. La commande suivante est utilisée pour évaluer l'exemple donné à l'aide d'une requête SQL.

$ sqoop eval \
--connect jdbc:mysql://localhost/db \
--username root \ 
--query “SELECT * FROM employee LIMIT 3”

Si la commande s'exécute avec succès, elle produira la sortie suivante sur le terminal.

+------+--------------+-------------+-------------------+--------+
| Id   | Name         | Designation | Salary            | Dept   |
+------+--------------+-------------+-------------------+--------+
| 1201 | gopal        | manager     | 50000             | TP     |
| 1202 | manisha      | preader     | 50000             | TP     |
| 1203 | khalil       | php dev     | 30000             | AC     |
+------+--------------+-------------+-------------------+--------+

Insérer une évaluation de requête

L'outil Sqoop eval peut être applicable à la fois à la modélisation et à la définition des instructions SQL. Cela signifie que nous pouvons également utiliser eval pour insérer des instructions. La commande suivante est utilisée pour insérer une nouvelle ligne dans leemployee tableau de db base de données.

$ sqoop eval \
--connect jdbc:mysql://localhost/db \
--username root \ 
-e “INSERT INTO employee VALUES(1207,‘Raju’,‘UI dev’,15000,‘TP’)”

Si la commande s'exécute avec succès, elle affichera l'état des lignes mises à jour sur la console.

Ou bien, vous pouvez vérifier la table des employés sur la console MySQL. La commande suivante permet de vérifier les lignes deemployee tableau de db base de données en utilisant la requête de sélection.

mysql>
mysql> use db;
mysql> SELECT * FROM employee;
+------+--------------+-------------+-------------------+--------+
| Id   | Name         | Designation | Salary            | Dept   |
+------+--------------+-------------+-------------------+--------+
| 1201 | gopal        | manager     | 50000             | TP     |
| 1202 | manisha      | preader     | 50000             | TP     |
| 1203 | khalil       | php dev     | 30000             | AC     |
| 1204 | prasanth     | php dev     | 30000             | AC     |
| 1205 | kranthi      | admin       | 20000             | TP     |
| 1206 | satish p     | grp des     | 20000             | GR     |
| 1207 | Raju         | UI dev      | 15000             | TP     |
+------+--------------+-------------+-------------------+--------+