Redshift’e Giriş
Jason Myers
Principal Engineer
CREATE TABLE IDAHO_SITE_ID
(
'pk_siteid' INTEGER PRIMARY KEY,
'fk_monitoringlocation' INTEGER,
'organization_id' VARCHAR(31),
'organizationformalname' VARCHAR(68),
'organization' VARCHAR(16)
);

DISTKEY veya PRIMARY KEY kullanır| Name | Description | Usage |
|---|---|---|
| ALL | Tablonun tamamı her düğümde | Join'lerde sıkça gereken küçük look-up fact tabloları |
| KEY | DISTKEY sütunundaki veriye göre dağıtım | DISTKEY ile özetleme ya da join |
| EVEN | Satır bazında sırayla düğümlere dağıtım | Anahtarı olmayan büyük tablolar |
| AUTO | Küçük tablolar için ALL. Uygun DISTKEY varsa büyüdükçe KEY, yoksa EVEN | varsayılan |
CREATE TABLE IDAHO_SITE_ID
(
'pk_siteid' INTEGER PRIMARY KEY,
'fk_monitoringlocation' INTEGER,
'organization_id' VARCHAR(31),
'organizationformalname' VARCHAR(68),
'organization' VARCHAR(16)
)
-- Veri dağıtım anahtarını
-- organization_id olarak ayarlar
DISTKEY(organization_id);
CREATE TABLE IDAHO_SITE_ID
(
'pk_siteid' INTEGER PRIMARY KEY,
'fk_monitoringlocation' INTEGER,
-- Veri dağıtım anahtarını
-- organization_id olarak ayarlar
'organization_id' VARCHAR(31) DISTKEY,
'organizationformalname' VARCHAR(68),
'organization' VARCHAR(16)
);
CREATE TABLE IDAHO_SITE_ID
(
'pk_siteid' INTEGER PRIMARY KEY,
'fk_monitoringlocation' INTEGER,
'organization_id' VARCHAR(31),
'organizationformalname' VARCHAR(68),
'organization' VARCHAR(16)
)
DISTKEY(organization_id)
-- Dağıtım stilini key olarak ayarlar
DISTSTYLE KEY;
CREATE TABLE IDAHO_SITE_ID
(
'pk_siteid' INTEGER PRIMARY KEY,
'fk_monitoringlocation' INTEGER,
'organization_id' VARCHAR(31),
'organizationformalname' VARCHAR(68),
'organization' VARCHAR(16)
)
DISTKEY(organization_id)
DISTSTYLE KEY
-- Veri sıralama anahtarını
-- fk_monitoringlocation olarak ayarlar
SORTKEY(fk_monitoringlocation);
CREATE TABLE IDAHO_SITE_ID
(
'pk_siteid' INTEGER PRIMARY KEY,
'fk_monitoringlocation' INTEGER,
'organization_id' VARCHAR(31),
'organizationformalname' VARCHAR(68),
'organization' VARCHAR(16)
)
-- fk_monitoringlocation, organization_id alanlarını bileşik sort key yapar
COMPOUND SORTKEY(fk_monitoringlocation, organization_id);
-- Bir sütunun dist ve sortkey
-- durumunu görüntüleyin
SELECT column_name,
distkey,
sortkey
FROM SVV_REDSHIFT_COLUMNS
-- Yalnızca spectrumdb şemasında
WHERE schema_name = 'spectrumdb'
-- ecommerce_sales tablosu için
AND table_name = 'ecommerce_sales';
Sonuçlar
column | distkey | sortkey
============|=========|========
year_qtr | t | 1
total_sales | f | 2
ecom_sales | f | 0
Distkey Sütunu
SVV_TABLE_INFOtable | encoded | diststyle | sortkey1 | skew_sortkey1 | skew_rows
===============|=========|=================|==============|===============|===========
ecommerce_sales| N | KEY(year_qtr) | year_qtr | |
date | N | ALL | dateid | 1.00 |
SELECT table
diststyle
FROM SVV_TABLE_INFO
WHERE schema like 'spectrumdb';
table | diststyle
================|==============
ecommerce_sales | KEY(year_qtr)
Redshift’e Giriş