Maison >base de données >Oracle >Comment interroger des nombres dans Oracle
La base de données Oracle est un système de gestion de bases de données relationnelles populaire dans le monde entier. Il prend en charge plusieurs types de données, y compris les types numériques, tels que les entiers (INTEGER), les décimaux (FLOAT), la double précision (DOUBLE PRECISION), etc. Interroger des numéros dans une base de données Oracle est une opération de base. Apprenons-en plus ci-dessous.
1. Types de données numériques Oracle
Les types de données numériques dans la base de données Oracle incluent principalement des types entiers et des types décimaux. Les types entiers incluent : NUMBER et INTEGER, et les types décimaux incluent : FLOAT, DOUBLE PRECISION, BINARY FLOAT et BINARY_DOUBLE. Présentons-les un par un ci-dessous.
1. Type NUMBER
Le type NUMBER est le type de nombre le plus couramment utilisé dans la base de données Oracle, et sa plage est de -10^124~10^124. Le type NUMBER peut stocker n'importe quel nombre de chiffres. Si la précision et l'échelle ne sont pas spécifiées, il occupera le plus grand espace. Pour spécifier la précision et l'échelle, vous pouvez utiliser la méthode suivante :
NUMBER(precision,scale)
Dans l'instruction ci-dessus, la précision représente le nombre total de chiffres (maximum 38) et l'échelle représente la longueur de la partie décimale. (précision maximale) .
2. Type INTEGER
Le type INTEGER est utilisé pour stocker des entiers et sa plage est -2^31 ~ 2^31-1 Si une plage de nombres plus grande est requise, le type NUMBER doit être utilisé. Le type INTEGER ne nécessite pas de spécification de précision et d’échelle.
3. Type FLOAT
Le type FLOAT est utilisé pour stocker des nombres à virgule flottante, sa plage est de 1,17E^-38 ~ 3,4E^38 et la précision est de 126 bits. La précision en virgule flottante étant instable, soyez très prudent lorsque vous effectuez des comparaisons.
4. Type DOUBLE PRÉCISION
Le type DOUBLE PRÉCISION est également utilisé pour stocker des nombres à virgule flottante, avec une plage de 2,2E^-308 ~ 1,8E^308 et une précision de 15 chiffres. Il est plus précis que le type FLOAT et donc plus stable.
2. Requête numérique Oracle
Avec les types numériques ci-dessus, nous pouvons effectuer des requêtes numériques dans la base de données Oracle. La base de données Oracle fournit une variété d'instructions de requête, les plus couramment utilisées incluent SELECT, WHERE, GROUP BY, HAVING, ORDER BY, etc.
1. Requête SELECT
Dans la base de données Oracle, nous pouvons utiliser l'instruction SELECT pour interroger des nombres. Par exemple, nous pouvons interroger le score total de tous les étudiants en utilisant l'instruction suivante :
SELECT SUM(score) FROM student;
Ici, la fonction SUM peut additionner les nombres dans la colonne spécifiée pour obtenir le score total.
2. Requête WHERE
L'instruction WHERE est utilisée pour spécifier les conditions de requête et peut être utilisée pour les requêtes de type numérique. Par exemple, nous pouvons utiliser l'instruction suivante pour interroger tous les étudiants avec un score supérieur à 80 :
SELECT * FROM student WHERE score > 80 ;
Ici, l'instruction WHERE filtre les enregistrements avec un score supérieur à 80, puis utilise la requête SELECT pour afficher les résultats.
3. Requête GROUP BY
L'instruction GROUP BY est utilisée pour regrouper les mêmes valeurs. Par exemple, nous pouvons utiliser l'instruction suivante pour interroger le score moyen en fonction de la classe :
SELECT class, AVG(score) FROM student GROUP BY class ;
Ici, l'instruction GROUP BY regroupe les enregistrements par classe, puis utilise l'instruction GROUP BY. Fonction AVG pour calculer le score de chaque classe Score moyen.
4. Requête HAVING
L'instruction HAVING est utilisée pour spécifier les conditions de filtrage d'un certain nombre de fonctions Différentes de WHERE, HAVING filtre les résultats regroupés par GROUP BY. Par exemple, nous pouvons utiliser l'instruction suivante pour interroger les classes avec un score moyen supérieur à 80 :
SELECT class, AVG(score) FROM student GROUP BY class HAVING AVG(score) > 80;
Ici, l'instruction HAVING sélectionnera les classes avec un score moyen supérieur à 80 Classe filtrée.
5. Requête ORDER BY
L'instruction ORDER BY est utilisée pour trier les résultats de la requête. Par exemple, nous pouvons utiliser l'instruction suivante pour trier des scores élevés aux scores faibles :
SELECT * FROM student ORDER BY score DESC
Ici, DESC signifie ordre décroissant et ASC signifie ordre croissant.
3. Précautions pour les requêtes numériques Oracle
Lorsque vous effectuez des requêtes numériques Oracle, vous devez faire attention aux points suivants :
1. Soyez très prudent avec les requêtes numériques à virgule flottante car leur précision est instable.
2. La précision et l'échelle du type numérique doivent être précisées, sinon elles occuperont le plus grand espace.
3. Le filtrage des fonctions après GROUP BY doit utiliser l'instruction HAVING pour le jugement conditionnel.
4. Assurez-vous d'utiliser l'instruction ORDER BY pour trier les résultats afin de garantir l'exactitude des résultats.
Résumé
La base de données Oracle est un système de gestion de base de données relationnelle très puissant qui prend en charge une variété de types de nombres, tels que des entiers, des décimaux, etc. La requête numérique Oracle est une opération de base lors de l'utilisation de la base de données Oracle. Les instructions de requête courantes incluent SELECT, WHERE, GROUP BY, HAVING, ORDER BY, etc. Lorsque vous effectuez des requêtes numériques, vous devez prêter attention à des problèmes tels que la précision, la mise à l'échelle et la précision en virgule flottante instable pour garantir l'exactitude des résultats de la requête.
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!