Koppla data
Viktigt
Stödet för Machine Learning Studio (klassisk) upphör den 31 augusti 2024. Vi rekommenderar att du byter till Azure Machine Learning innan dess.
Från och med den 1 december 2021 kan du inte längre skapa nya Machine Learning Studio-resurser (klassisk). Du kan fortsätta att använda befintliga Machine Learning Studio-resurser (klassisk) till och med den 31 augusti 2024.
- Se information om hur du flyttar maskininlärningsprojekt från ML Studio (klassisk) till Azure Machine Learning.
- Läs mer om Azure Machine Learning.
Dokumentationen om ML Studio (klassisk) håller på att dras tillbaka och kanske inte uppdateras i framtiden.
Ansluter till två datauppsättningar
Kategori: Datatransformering/manipulering
Anteckning
Gäller endast för: Machine Learning Studio (klassisk)
Liknande dra och släpp-moduler är tillgängliga i Azure Machine Learning designer.
Modulöversikt
Den här artikeln beskriver hur du använder modulen Join Data (Koppla data) i Machine Learning Studio (klassisk) för att sammanfoga två datauppsättningar med hjälp av en kopplingsåtgärd i databasformat.
Om du vill utföra en koppling på två datauppsättningar måste de vara relaterade till en enda nyckelkolumn. Sammansatta nycklar stöds inte.
Så här konfigurerar du kopplingsdata
I Machine Learning Studio (klassisk) lägger du till de datauppsättningar som du vill kombinera och drar sedan modulen Koppla data till experimentet.
Du hittar modulen i kategorin Datatransformering under Manipulation.
Anslut datauppsättningarna till modulen Koppla data.
Modulen Join Data (Koppla data) stöder inte en höger yttre koppling, så om du vill se till att rader från en viss datauppsättning ingår i utdata måste datauppsättningen finnas på vänster indata.
Klicka på Starta kolumnväljaren för att välja en enda nyckelkolumn för datauppsättningen till vänster.
Klicka på Starta kolumnväljaren för att välja en enda nyckelkolumn för datauppsättningen till höger indata.
Välj alternativet Matcha fall om du ansluter till en textkolumn och vill se till att koppling bevarar casekänsligheten.
Om du till exempel väljer det här alternativet
A1000
anses ett annat nyckelvärde äna1000
.Om du avmarkerar det här alternativet tillämpas inte ärendekänsligheten och
A1000
anses vara samma soma1000
.Använd listrutan Kopplingstyp för att ange hur datauppsättningarna ska kombineras. Typer:
Inre koppling: En inre koppling är den typiska kopplingsåtgärden. Den returnerar endast de kombinerade raderna när värdena för nyckelkolumnerna matchar.
Vänster yttre koppling: En vänster yttre koppling returnerar sammanfogade rader för alla rader från den vänstra tabellen. När en rad i den vänstra tabellen inte har några matchande rader i den högra tabellen innehåller den returnerade raden saknade värden för alla kolumner som kommer från den högra tabellen om du inte anger ett ersättningsvärde för saknade värden.
Fullständig yttre koppling: En fullständig yttre koppling returnerar alla rader från den vänstra tabellen (table1) och från den högra tabellen (table2).
För var och en av raderna i den vänstra tabellen som inte har några matchande rader i den högra tabellen innehåller kopplingsresultatet en rad som innehåller saknade värden från den högra tabellen.
För var och en av raderna i den högra tabellen som inte har några matchande rader i den vänstra tabellen innehåller kopplingsresultatet en rad som innehåller saknade värden för alla kolumner från den vänstra tabellen.
Vänster halvkoppling: En vänster halvkoppling returnerar endast värdena från den vänstra tabellen när värdena i nyckelkolumnerna matchar.
För alternativet Keep right key colums in joined table (Behåll höger nyckelkolumner i en ansluten tabell):
- Avmarkera alternativet för att hämta en enda nyckelkolumn i resultatet.
- Låt alternativet vara markerat för att visa nycklarna från båda indatatabellerna.
Kör experimentet eller välj modulen Join Data (Koppla data) och valt Run Selected (Kör valda) för att utföra koppling.
Om du vill visa resultatet högerklickar du på modulen Join Data (Koppla data). Välj Results dataset (Resultatdatauppsättning) och klicka på Visualize (Visualisera).
Exempel
Du kan se exempel på hur den här modulen används i Azure AI Gallery:
Canceridentifiering: Kopplingsdata används för att kombinera de positiva träningsfallen med de negativa träningsfallen när andelen fall har justerats.
Förutsägelse av flygfördröjning: I det här exemplet används Kopplingsdata för att samla användbara funktioner från externa datauppsättningar.
Filmrekommendation: Två datauppsättningar är sammanfogade så att vi kan presentera de rekommenderade filmtitlarna i stället för ett film-ID.
Förutsägelse av elevprestanda: I det här exemplet används Join Data för att hämta nya funktioner.
Teknisk information
I det här avsnittet beskrivs implementeringsinformation och svar på några vanliga frågor.
Begränsningar
Den kombinerade datauppsättningen kan inte ha två kolumner med samma namn. Om de vänstra och högra datauppsättningarna har dubblettkolumnnamn läggs ett numeriskt suffix till i kolumnnamnen för den högra datauppsättningen så att de blir unika.
Om båda datauppsättningarna till exempel hade en kolumn med namnet Month skulle kolumnen från den vänstra datauppsättningen förbli som den är och kolumnen från den högra datauppsättningen får namnet Month (1).
Algoritmen som används för jämförelse av nyckelvärden är hash-tvingad.
Varje kolumn i den sammanfogade datauppsättningen bevarar en kategorisk typ om motsvarande kolumn i indatauppsättningen är kategorisk.
Om det finns några saknade värden i vänster yttre kopplingar skapas en kategorisk nivå i den vänstra datauppsättningen för saknade värden. Detta gäller även om det inte finns några saknade värden i den sammanfogade datauppsättningen (höger).
Hur kan jag koppla en tabell till en sammansatt nyckel?
Om du behöver koppla en tabell som använder sammansatta nycklar (det vill säga att den primära nyckeln förlitar sig på två oberoende kolumner), använder du en modul som följande för att sammanfoga innehållet i de två nyckelkolumnerna:
-
Du kan till exempel använda kod som följande inuti R-skriptet för att sammanfoga den första och andra kolumnen i indataramen med ett bindestreck som avgränsare.
paste(inputdf$Col1,inputdf$Col2,sep="-")
-
Sammanfogningsoperatorn i SQLite är
||
.
Hur kan jag koppla tabeller som inte har en nyckel?
Om datauppsättningen inte har någon nyckelkolumn kan du fortfarande kombinera den med en annan datauppsättning, antingen genom att generera en nyckel eller genom att använda modulen Lägg till kolumner.
Modulen Lägg till kolumner fungerar som R och kan sammanslå två datauppsättningar rad för rad, om datauppsättningarna har samma antal rader. Ett fel uppstår om datauppsättningarna har en annan storlek.
Förväntade indata
Namn | Typ | Description |
---|---|---|
Datauppsättning1 | Datatabell | Första datauppsättningen som ska anslutas |
Datauppsättning2 | Datatabell | Andra datauppsättningen som ska anslutas |
Modulparametrar
Name | Intervall | Typ | Standardvärde | Description |
---|---|---|---|---|
Koppla nyckelkolumner för L | Valfri | ColumnSelection | Välj kopplingsnyckelkolumnerna för den första datauppsättningen. | |
Koppla nyckelkolumner för R | Valfri | ColumnSelection | Välj kopplingsnyckelkolumnerna för den andra datauppsättningen. | |
Matchningsfall | Valfri | Boolesk | Sant | Ange om en fallkänslig jämförelse tillåts i nyckelkolumner. |
Kopplingstyp | Lista | Typ | Inre koppling | Välj en kopplingstyp. |
Behåll rätt nyckelkolumner i en ansluten tabell | Valfri | Boolesk | Sant | Ange om du vill behålla nyckelkolumner från den andra datauppsättningen i den sammanfogade datauppsättningen. |
Utdata
Namn | Typ | Description |
---|---|---|
Resultatdatauppsättning | Datatabell | Resultat av kopplingsåtgärd |
Undantag
Undantag | Description |
---|---|
Fel 0001 | Ett undantag inträffar om det inte går att hitta en eller flera angivna kolumner i datauppsättningen. |
Fel 0003 | Ett undantag inträffar om en eller flera indata är null eller tomma. |
Fel 0006 | Ett undantag inträffar om parametern är större än eller lika med det angivna värdet. |
Fel 0016 | Ett undantag inträffar om de indatauppsättningar som skickas till modulen ska ha kompatibla kolumntyper, men de gör det inte. |
Fel 0017 | Ett undantag inträffar om en eller flera angivna kolumner har typer som inte stöds av den aktuella modulen. |
Fel 0020 | Ett undantag inträffar om antalet kolumner i vissa datauppsättningar som skickas till modulen är för litet. |
Fel 0028 | Ett undantag inträffar när kolumnuppsättningen innehåller dubblettkolumnnamn och det inte tillåts. |
Fel 0011 | Ett undantag inträffar om argumentet för den skickade kolumnuppsättningen inte gäller för några datauppsättningskolumner. |
Fel 0027 | Ett undantag inträffar när två objekt måste ha samma storlek, men det är de inte. |
En lista över fel som är specifika för Studio-moduler (klassisk) finns i Machine Learning felkoder.
En lista över API-undantag finns i Machine Learning REST API felkoder.