Hem Personliga finanser Sammanfogning av tabeller med Hive-dummies

Sammanfogning av tabeller med Hive-dummies

Video: Sammanfoga celler 2024

Video: Sammanfoga celler 2024
Anonim

Du vet nog redan att experter i relationell databasmodellering och design brukar spendera mycket tid på att designa normaliserade databaser, eller scheman <. Databas Normalisering är en teknik som skyddar mot dataförluster, redundans och andra avvikelser eftersom data uppdateras och hämtas. Experterna följer ett antal regler för att komma fram till en normaliserad databas, men regel 1 är att du måste sluta med en

grupp av tabellerna. (Ett stort bord som lagrar alla dina data är inte normalt - punten är avsedda.) Det finns undantag, beroende på användningsfallet, men lagen i många tabeller följs vanligtvis noga, särskilt för databaser som stöder transaktioner eller analytisk bearbetning (business intelligence, till exempel).

När du börjar fråga och analysera dina data, sammanfogas tabeller baserat på de definierade relationerna mellan dem med hjälp av SQL - vilket innebär att diskarna i slutändan är upptagna på din server när du börjar ansluta tabeller och Upptagna skivor leder vanligtvis till långsammare användartider. Den goda nyheten är dock att RDBMSs och EDWs är inställda för att göra föreningar så fort som möjligt.

Vad har allt detta att göra med att gå med i Hive? Tja, kom ihåg att det underliggande operativsystemet för Hive är (överraskning!) Apache Hadoop: MapReduce är motorn för att ansluta till tabeller, och Hadoop File System (HDFS) är det underliggande lagret. Det är allt bra nyheter för användaren som vill skapa, hantera och analysera stora tabeller med Hive.

Möjligheten att låsa upp information som är dold i massiva datastrukturer är spännande. Men anslutningar med Hive brukar inte fungera lika bra som de gör i RDBMS / EDW-världen, så första gången användare blir ofta överraskad av "pokiness" av systemets svar.

Kom ihåg att MapReduce och HDFS optimeras för genomströmning med stor dataanalys och att i den här världen är

latenser - användartidstider, med andra ord - vanligtvis höga. Hive är konstruerad för analytisk bearbetning i batchformat, inte för snabb online-transaktionsbehandling. Användare som vill ha bästa möjliga prestanda med SQL på Apache Hadoop har lösningar tillgängliga.

Håll den här dynamiken i åtanke när du börjar ansluta tabeller med Hive. Observera också att Hive-arkitekter vanligtvis vanormaliserar sina databaser i viss mån, så att få färre större tabeller är vanliga. Därför tillhandahålls komplexa datatyper som STRUCTs och ARRAYs. Du kan använda dessa komplexa datatyper för att packa mycket mer data i ett enda bord.

Eftersom Hive-tabellen läser och skriver via HDFS brukar innebära mycket stora datablock, desto mer data kan du hantera helt och hållet i ett bord, desto bättre blir resultatet.

Disk- och nätverksåtkomst är mycket långsammare än minnesåtkomst, så att HDFS-läsaren minimeras och läses så mycket som möjligt.

Med den här bakgrundsinformationen i åtanke kan du ta itu med att du går med Hive. Lyckligtvis var Hive-utvecklingssamhället realistiskt och förstod att användarna skulle vilja och behöver ansluta sig till tabeller med HiveQL. Denna kunskap blir speciellt viktig med EDW augmentation. Använda fall som "förfrågningsbara" arkiv kräver ofta anslutningar för dataanalys.

Här är ett Hive Join-exempel med flygdatatabeller. Listan visar hur du skapar och visar en myflightinfo2007 tabell och en myflightinfo2008 tabell från de större FlightInfo2007 och FlightInfo2008 tabellerna. Planen hela tiden var att använda CTAS skapade myflightinfo2007 och myflightinfo2008 tabeller för att illustrera hur du kan utföra samverkan i Hive.

Figuren visar resultatet av ett inre sammanhang med myflightinfo2007 och myflightinfo2008-tabellerna med SQuirreL SQL-klienten.

Hive stöder

equi-joins, en särskild typ av medlemskap som endast använder jämlikhetsjämförelser i anslutningsprotikatet. (ON m8. FlightNum = m7. FlightNum är ett exempel på en equi-join.) Andra komparatorer som mindre än (<) stöds inte. Denna begränsning är bara på grund av begränsningar på den underliggande MapReduce-motorn. Du kan också inte använda ELLER i ON-klausulen. Figuren illustrerar det tidigare exemplet på den inre föreningen och två andra Hive-föreningar. Observera att du kan bekräfta resultatet av ett inre sammanhang genom att granska innehållet i myflight2007 och myflight2008-tabellerna.

Följande bild illustrerar hur ett inre sammanhang fungerar med ett Venn-diagram, om du inte är bekant med tekniken. Grundidén här är att ett inre parti returnerar de poster som matchar mellan två tabeller. Så ett inre sammanhang är ett perfekt analysverktyg för att bestämma vilka flygningar som är samma från JFK (New York) till ORD (Chicago) i juli 2007 och juli 2008.

Optimera Hive-medlemmar är ett hett ämne i Hive-community. För mer information om aktuella optimeringstekniker, se sidan Anpassa optimering på Hive wiki.

Sammanfogning av tabeller med Hive-dummies

Redaktörens val

Jewish Funeral Traditions - dummies

Jewish Funeral Traditions - dummies

Judiska begravningar sker vanligen i en synagoge, begravningshem eller på en kyrkogård. Med tradition är judiska begravningar enkla (symboliserar tron ​​att människor är alla lika i döden), men de varierar mycket och har ingen uppsättning liturgi. Att skicka blommor till ett begravnings- eller sorgshem är starkt avskräckt i judendomen. Inte bara kommer ...

Identifiera komplicerade grävande dummies

Identifiera komplicerade grävande dummies

Komplicerat roende är det tekniska namnet som sorgproffs ger till en sorgprocess som sitter fast vid något tillfälle , vilket gör det omöjligt för de förlorade att framgångsrikt starta eller avsluta sorgprocessen. Komplicerat sorg är ofta ett tecken på olösta problem i förhållandet mellan de förlorade och den avlidne som gör det ...

Redaktörens val

Hur man ställer in kartkontroller i Main_iPad. Storyboard i din iOS App - dummies

Hur man ställer in kartkontroller i Main_iPad. Storyboard i din iOS App - dummies

När du har en anpassad vy för MapController i din iOS-app, måste du berätta för iPad-storyboardet att du laddar in din anpassade vy i stället för en UIViewController. Följ dessa steg: Välj Projekt navigator genom att välja Main_iPad. storyboard och välj sedan View Controller i View Controller - Map Scene i dokumentutskriften. ...

Hur man roterar objekt i din iOS-app - dummies

Hur man roterar objekt i din iOS-app - dummies

Här hittar du hur man rotera en vy (i så fall vrid bilen runt) i din iOS-app. För att göra det uppdaterar du den roterande kodstuben du startade med och ersätter den med den fetstilta koden. - (void) rotera {CGAffineTransform transform = CGAffineTransformMakeRotation (M_PI); void (^ animation) () = ^ () {self. bil. transformera = transformera; ...

Hur man ställer in en WeatherController i Main_iPad. storyboard-fil för din iOS-app - dummies

Hur man ställer in en WeatherController i Main_iPad. storyboard-fil för din iOS-app - dummies

Bör du lägga till en ny anpassad vykontroll till din iOS-app innan du fortsätter till dessa steg. Du behöver fortfarande berätta för storyboardet att du vill att den ska ladda den nya anpassade vykontrollen istället för en UIViewController. Följ dessa steg:

Redaktörens val

Spara en grafisk stil i Adobe CS5 Illustrator - dummies

Spara en grafisk stil i Adobe CS5 Illustrator - dummies

Adobe Creative Suite 5 (Adobe CS5) Illustrator tillåter Du sparar en grafisk stil. En grafisk stil är en kombination av alla inställningar du väljer för ett visst filter eller en effekt i Utseendepanelen. Genom att spara informationen i en grafisk stil lagras du dessa attribut så att du snabbt och enkelt kan tillämpa ...

Välj som ett transformationsverktyg i Adobe CS5 Illustrator - dummies

Välj som ett transformationsverktyg i Adobe CS5 Illustrator - dummies

I Adobe Creative Suite 5 (Adobe CS5 ) Illustratör du kan använda markeringsverktyget för att skala och rotera ett valt objekt. Dra begränsningsboxens handtag för att ändra storlek på objektet, eller flytta dig utanför ett handtag och sedan, när markören ändras till en flippig pil (en böjd pil med pilhuvud i båda ändarna), dra till ...

Objekttransformation i Adobe CS5 Illustrator - dummies

Objekttransformation i Adobe CS5 Illustrator - dummies

Verktygen Rotate, Reflect, Scale och Shear i Adobe Creative Suite 5 (Adobe CS5) Illustrator använder alla samma grundläggande steg för att utföra transformationer. Här är fem sätt att transformera ett objekt: en för en godtycklig omvandling och fyra andra för exakta omvandlingar baserat på en numerisk mängd som du anger. Vilkårlig omvandlingsmetod Eftersom detta ...