Synonym vs Alias (i ORACLE-databaser) | Private synonymer og offentlige synonymer
På engelsk har synonym og alias nesten samme betydning. Men i databaser er det to forskjellige ting. Spesielt i ORACLE-databaser, er begge deres bruk forskjellige. Synonymer brukes til å referere objekter til et skjema eller en database fra et annet skjema. Så synonymt er en databaseobjekttype. Men aliaser kommer på en annen måte. Det betyr; de er ikke databaseobjekter. Aliaser brukes til å referere tabeller, synspunkter og kolonner i spørringer.
synonymer
Dette er en type databaseobjekter. De refererer til andre objekter i databasen. Den vanligste bruken av synonym er å referere til et objekt med et eget skjema ved å bruke et annet navn. Men synonymer kan opprettes for å referere gjenstandene til en annen database, i tillegg (i distribuerte databaser, ved hjelp av databasekoblinger). Tabeller, visninger, funksjoner, prosedyrer, pakker, sekvenser, materialiserte visninger, java klasse objekter og utløsere kan brukes som referanser for synonymer. Det finnes to typer synonymer.
Her er en enkel syntaks for å lage et synonym i en egen database,
opprett synonym myschema.mytable1 for [e-postbeskyttet]_link1
Siden vi har et synonym som heter mytable1 i myschema til [e-postbeskyttet]_link1 (distribuert database tabell), Vi kan enkelt se den distribuerte databasetabellen ved hjelp av mytable1. Vi trenger ikke å bruke det lange objektnavnet med databasekobling overalt.
Alias
Dette er bare et annet navn for en visning, et bord eller en kolonne i en forespørsel. De er ikke databaseobjekter. Derfor er aliaser ikke gyldige overalt i skjemaet / databasen. De er gyldige innenfor spørringen bare. La oss se dette eksemplet,
velg tab1.col1 som c1, tab2.col2 som c2
fra user1.tab1 tab1, user1.tab2 tab2
hvor tab1.col1 = tab2.col2
Her er c1 og c2 kolonnaliaser, som brukes til tab1.col1 og tab2.col2, og tab1 og tab2 er tabellaliaser, som brukes til user1.table1 og user2.table2. Alle disse aliasene er gyldige innenfor dette spørsmålet.
Hva er forskjellen mellom Synonym og Alias (i ORACLE-databaser)?
|