Table des matières
Hive - Premiers pas avec le partitionnement [Fichier] est stocké dans des catégories et ne peut être affiné qu'en [Fichier], mais le contenu ne peut pas être affiné. Cependant, une seule classe (zone) peut être spécifiée dans une seule. opération ;
3 : Le but du partitionnement est de restreindre la portée de la requête et d'améliorer la requête ; efficacité d'une seule table lors de l'interrogation d'une seule table
Maison développement back-end tutoriel php Cinq choses que vous devez apprendre pour éviter les pièges lorsque vous débutez avec les partitions HIVE

Cinq choses que vous devez apprendre pour éviter les pièges lorsque vous débutez avec les partitions HIVE

Sep 15, 2018 am 11:11 AM

Cet article vous apporte les cinq connaissances majeures que vous devez apprendre pour éviter les pièges lorsque vous débutez avec le partitionnement HIVE. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.

Hive - Premiers pas avec le partitionnement [Fichier] est stocké dans des catégories et ne peut être affiné qu'en [Fichier], mais le contenu ne peut pas être affiné. Cependant, une seule classe (zone) peut être spécifiée dans une seule. opération ;

2 : Une opération de partition dynamique peut être divisée en fonction du contenu spécifique du champ. Multi-catégorie (zone)

3 : Le but du partitionnement est de restreindre la portée de la requête et d'améliorer la requête ; efficacité d'une seule table lors de l'interrogation d'une seule table

4 : Comme la partition est spécifiée sur la ligne de commande pour le partitionnement statique, la couche inférieure n'exécute pas le programme mr (la partition dynamique relativement rigide exécute le programme mr et extrait) ; les champs correspondants (relativement intelligents)

Étapes de démonstration :
1. Créer une table de partition étudiante

95001, Li Yong ,Male,20,CS
95002, Liu Chen, Femme, 19 ans, IS

95003, Wang Min, Femme, 22 ans, MA

95004, Zhang Li, Homme, 19 ans, IS

95005, Liu Gang, homme, 18 ans, MA

95006, Sun Qing, homme, 23 ans, CS


Créer et voir si cela réussit


Ajouter du contenu
(1)charger

--分区表创建create table t_students(id int,name string,sex string)
partitioned by (age int,class string)row format delimited fields terminated by ',' ;
Copier après la connexion

(2)insert

Insert in Hive est principalement utilisé en conjonction avec l'instruction de requête select.
hive> set hive.cli.print.header=true;hive> select * from t_students;OK
t_students.id   t_students.name t_students.sex  t_students.age  t_students.class
Copier après la connexion


Après l'exécution, vous pouvez afficher la table SDS de métadonnées. informations

--静态分区load data local inpath '/root/logs/students.txt' into table t_students partition (age=19,class='MA');
Copier après la connexion


Après avoir ajouté à nouveau les données, les informations de la table SDS de métadonnées restent inchangées et les fichiers sous chaque chemin de partition deviennent deux copies
--动态分区set hive.exec.dynamic.partition=true;set hive.exec.dynamic.partition.mode=nonstrict;insert overwrite table t_students  partition (age,class) 
select * from t_student;
Copier après la connexion


Cinq choses que vous devez apprendre pour éviter les pièges lorsque vous débutez avec les partitions HIVEhive bucketing

--使用同样的数据,再次追加insert一次数据
hive> insert into table t_students  partition (age,class) select * from t_student;
Copier après la connexion
Le bucketing est une division plus fine des partitions relatives. Le bucketing divise l'intégralité du contenu des données en compartiments en fonction de la valeur de hachage d'un certain attribut de colonne. Pour diviser l'attribut de nom en trois compartiments, la valeur de hachage de la valeur de l'attribut de nom est modulée par 3 et les données sont divisées en compartiments en fonction. le résultat modulo. Par exemple, les enregistrements de données avec un résultat modulo de 0 sont stockés dans un fichier, les données avec une valeur modulo de 1 sont stockées dans un fichier et les enregistrements de données avec une valeur modulo de 2 sont stockés dans un fichier.

Remarque :
Tout d'abord, exécutez la commande hive.enforce.bucketiong=true avant le bucketing ; Cinq choses que vous devez apprendre pour éviter les pièges lorsque vous débutez avec les partitions HIVEDeuxièmement, utilisez le mot-clé clustered by pour spécifier le nom de la colonne sur laquelle la partition est basée, et spécifiez également le nombre de partitions. à diviser en. Bucket, spécifié ici est divisé en 3 buckets.

Troisièmement, contrairement au partitionnement, le partitionnement n'est pas basé sur les colonnes du fichier de table de données réelles, mais sur les pseudo-colonnes que nous spécifions, mais le bucketing est basé sur les colonnes réelles de la table de données au lieu des pseudo-colonnes. Par conséquent, lors de la spécification de la colonne basée sur le partitionnement, vous devez spécifier le type de colonne, car cette colonne n'existe pas dans le fichier de table de données, ce qui équivaut à créer une nouvelle colonne. Le bucketing est basé sur une colonne qui existe déjà dans la table. Le type de données de cette colonne est évidemment connu, il n'est donc pas nécessaire de spécifier le type de colonne.

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 de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Comment configurer Visual Studio Code (VS Code) pour le développement PHP Comment configurer Visual Studio Code (VS Code) pour le développement PHP Dec 20, 2024 am 11:31 AM

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

Comment analysez-vous et traitez-vous HTML / XML dans PHP? Comment analysez-vous et traitez-vous HTML / XML dans PHP? Feb 07, 2025 am 11:57 AM

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

Programme PHP pour compter les voyelles dans une chaîne Programme PHP pour compter les voyelles dans une chaîne Feb 07, 2025 pm 12:12 PM

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total

Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Apr 05, 2025 am 12:04 AM

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

7 fonctions PHP que je regrette de ne pas connaître auparavant 7 fonctions PHP que je regrette de ne pas connaître auparavant Nov 13, 2024 am 09:42 AM

Si vous êtes un développeur PHP expérimenté, vous aurez peut-être le sentiment d'y être déjà allé et de l'avoir déjà fait. Vous avez développé un nombre important d'applications, débogué des millions de lignes de code et peaufiné de nombreux scripts pour réaliser des opérations.

Expliquez la liaison statique tardive en PHP (statique: :). Expliquez la liaison statique tardive en PHP (statique: :). Apr 03, 2025 am 12:04 AM

Liaison statique (statique: :) ​​implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Quelles sont les méthodes PHP Magic (__construct, __ destruct, __ call, __get, __set, etc.) et fournir des cas d'utilisation? Quelles sont les méthodes PHP Magic (__construct, __ destruct, __ call, __get, __set, etc.) et fournir des cas d'utilisation? Apr 03, 2025 am 12:03 AM

Quelles sont les méthodes magiques de PHP? Les méthodes magiques de PHP incluent: 1. \ _ \ _ Construct, utilisé pour initialiser les objets; 2. \ _ \ _ Destruct, utilisé pour nettoyer les ressources; 3. \ _ \ _ Appel, gérer les appels de méthode inexistants; 4. \ _ \ _ GET, Implémentez l'accès à l'attribut dynamique; 5. \ _ \ _ SET, Implémentez les paramètres d'attribut dynamique. Ces méthodes sont automatiquement appelées dans certaines situations, améliorant la flexibilité et l'efficacité du code.

See all articles