Klíčový rozdíl - kde vs. mít klauzuli v SQL
Data jsou důležitá pro každou organizaci. Proto je nutné data ukládat organizovaně, aby je bylo možné načíst. Data jsou uložena v tabulkách. Databáze se skládá ze sbírky tabulek. Jedním běžným typem databáze jsou relační databáze. V relační databázi jsou tabulky vzájemně příbuzné. Například zákazník tabulky je připojen k tabulce objednávek. Relační systém správy databáze (RDBMS) je systém správy databáze, který je založen na relačním modelu. Používá se ke správě relačních databází. Některé příklady RDBMS jsou MySQL, MSSQL a Oracle. Jazyk strukturovaných dotazů (SQL) je jazyk používaný pro manipulaci a načítání dat v relační databázi. V SQL existují různé klauzule k provádění různých úkolů. Dva z nich jsou kde a mají. Tento článek pojednává o rozdílech mezi klauzulí kde a v SQL. Klíčový rozdíl mezi klauzulí where a having v SQL je ten, kde se klauzule používá k filtrování záznamů před seskupením nebo agregací, zatímco klauzule se používá k filtrování záznamů po seskupení nebo agregaci.
OBSAH
1. Přehled a klíčový rozdíl
2. Co je klauzule kde v SQL
3. Co má klauzule v SQL
4. Podobnosti mezi klauzulí kde a mají v SQL
5. Porovnání vedle sebe - kde vs mít klauzuli v SQL ve formě tabulky
6. souhrn
Co je klauzule kde v SQL?
Pomáhá získat, aktualizovat nebo odstranit konkrétní sadu dat z tabulky podle dané podmínky. Programátor může pomocí klauzule where omezit a načíst pouze požadovaná data. Dotaz se provede pouze u záznamů, kde je podmínka zadaná klauzulí kde true. Lze jej použít pro výběr, aktualizaci a mazání.
Viz níže uvedená tabulka studentů,
Chcete-li vybrat jméno a věk studenta, jehož student_id se rovná 3, lze použít následující dotaz SQL.
vyberte jméno, věk od studenta, kde student_id = 3;
Je také možné použít operátory, jako například není rovno (! =), Větší než (>), menší než (=), menší než nebo rovno (<=). Chcete-li vybrat student_id a jméno, jehož věk není roven 15, lze použít následující dotaz SQL.
vyberte student_id, jméno od studenta, kde věk! = 15;
Ke změně věku studenta od 2 do 13 let lze použít následující dotaz.
aktualizovat studentský věk = 13, kde id = 3;
Chcete-li odstranit záznam, jehož student_id je 4, můžete použít následující dotaz.
smazat od studenta, kde student_id = 4;
Operátory a nebo lze použít ke kombinaci více podmínek.
vyberte jméno od studenta, kde student_id = 1 a věk = 15; dotaz načte jméno Ann.
Toto je několik příkladů klauzule where v SQL. Pokud existuje klauzule Group By, klauzule where se objeví před tím.
Co má klauzule v SQL?
Pro snadné provádění výpočtu jsou k dispozici funkce poskytované jazykem SQL. Jsou známé jako agregační funkce. Min () se používá k nalezení nejmenší hodnoty vybraného sloupce. Funkce max () slouží k nalezení maximální hodnoty vybraného sloupce. Avg () slouží k vyhledání průměru ve sloupci a součet () slouží k nalezení součtu sloupce. Toto je několik příkladů agregačních funkcí. Viz níže uvedená tabulka objednávek,
Programátor může napsat dotaz SQL následujícím způsobem, aby získal zákazníky, jejichž zůstatek je více než 2000.
vyberte * ze skupiny objednávek zákazníkem, který má součet (zůstatek)> 2000.
Tím se vytisknou záznamy zákazníků, jejichž součet zůstatku je větší než 2000. Vytisknou se záznamy zákazníků Ann a Alex.
Klauzule having se používá k načtení hodnot pro skupiny, které splňují určité podmínky. Výsledkem bude skupina, která spadá do dané podmínky. Klauzule having se zobrazí po klauzuli group-by. Pokud klauzule group-by není k dispozici, pak klauzule having bude fungovat podobně jako klauzule where.
Jaké jsou podobnosti mezi kde a s klauzulí v SQL?
- Obě jsou klauze v jazyce strukturovaných dotazů.
- Oba lze použít k filtrování načtení sady dat.
Jaký je rozdíl mezi kde a s klauzulí v SQL?
Rozdílný článek uprostřed před tabulkou
kde vs mít klauzuli v SQL |
|
Kde je klauzule SQL, která se používá k určení podmínky při načítání dat z jedné tabulky nebo spojením s více tabulkami. | The having je klauzule SQL, která určuje, že příkaz SQL select by měl vracet pouze řádky, kde agregované hodnoty splňují zadané podmínky. |
Účel | |
Klauzule where se používá k filtrování řádků. | Klauzule having se používá k filtrování skupin. |
Agregace | |
Klauzuli where nelze použít s agregačními funkcemi, pokud není v poddotazu obsaženém v klauzuli having. | Funkce agregace lze použít s klauzulí having. |
Metoda filtrování | |
Klauzule where se chová jako předfiltr. | Klauzule having se chová jako post filtr. |
Objednávka seskupit podle klauzule | |
Klauzule where se používá před klauzulí Group By. | Klauzule having se používá po klauzuli Group By. |
Používá se s | |
Klauzuli where lze použít s výběrem, aktualizací a odstraněním. | Klauzule having se používá pouze u select. |
Shrnutí - kde vs mít klauzuli v SQL
Jazyk strukturovaných dotazů (SQL) je jazyk používaný v relačních databázích. Kde mají dvě klauzule v SQL. Tento článek pojednával o rozdílech mezi klauzulí where a having. Rozdíl mezi klauzulí where a having v SQL je ten, kde se používá k filtrování záznamů před seskupením nebo agregací, zatímco having se používá k filtrování záznamů po seskupení nebo agregaci.