{"templateName":"quickstart-page-template","allowedRenditionsWidth":["320","480","640","768","960","1200","1440","1920"],"cssClassNames":"page basicpage summit-page","language":"en","title":"StreamSets' Transformer for Snowflake: Hands on Lab","analyticsPageType":"quickstart-page-template","analyticsCategory":"general","analyticsSubCategory":"","excludeFromAnalytics":false,":mappedPath":"/en/developers/guides/streamsets-transformer-for-snowflake-hol/",":type":"snowflake-site/components/structure/page","isPasswordProtected":false,"coveoConfig":{"pipeline":"snowflake.com","apiKey":"xx335921a6-2a0a-40f2-a167-e390b4766c3d","organizationId":"snowflakecomputingproduction8neljofn","searchHub":"snowflake.com"},"analyticsDebugMode":false,"analyticsData":{"excludeFromAnalytics":false,"subCategory":"","pageType":"quickstart-page-template","templateName":"quickstart-page-template","siteName":"snowflake","pageUrl":"/content/snowflake-site/global/en/developers/guides/streamsets-transformer-for-snowflake-hol","language":"en","category":"general","pageName":"StreamSets' Transformer for Snowflake: Hands on Lab","contentTags":["snowflake-site:taxonomy/product/data-engineering","snowflake-site:taxonomy/solution-center/certification/quickstart","snowflake-site:taxonomy/exclude-tags/hidden"]},"analyticsContentTags":["snowflake-site:taxonomy/product/data-engineering","snowflake-site:taxonomy/solution-center/certification/quickstart","snowflake-site:taxonomy/exclude-tags/hidden"],"analyticsEnabled":true,":items":{"root":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"markup_editor_1950346551":"aem-GridColumn aem-GridColumn--default--12","experiencefragment-banner":"aem-GridColumn aem-GridColumn--default--12","experiencefragment-header":"aem-GridColumn aem-GridColumn--default--12","responsivegrid":"aem-GridColumn aem-GridColumn--default--12","experiencefragment-footer":"aem-GridColumn aem-GridColumn--default--12","modal_container":"aem-GridColumn aem-GridColumn--default--12","markup_editor":"aem-GridColumn aem-GridColumn--default--12"},"columnCount":12,":items":{"experiencefragment-banner":{"id":"experiencefragment-44f30c7f12","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/pushdown-banner/master/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"pushdown_banner_copy":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-fcad4e26ab","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"pushdown_banner_copy":{"id":"pushdown-banner-89e7f3449a","contentHeadline":"Snowflake World Tour hits your city","contentDescription":"See how leading teams deploy agents at scale. Find a stop near you. Register free.","contentJustifyContent":"center","linkStyle":"text-white","linkCTA":{"id":"link-cta","heapButtonClasses":["pushdown_banner"],"showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"/en/world-tour/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Register now"},":type":"snowflake-site/components/pushdown-banner","appliedCssClassNames":"snowflake-pushdown-banner-text-white snowflake-pushdown-banner-background-black"}},":itemsOrder":["pushdown_banner_copy"]},"image":{":type":"nt:unstructured"},"cq:metadata":{":type":"nt:unstructured"}},":itemsOrder":["root","image","cq:metadata"],"classNames":"aem-xf"},"experiencefragment-header":{"id":"experiencefragment-163d020736","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"mega_header":"aem-GridColumn aem-GridColumn--default--12","markup_editor":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-f8c8378d57","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"markup_editor":{"id":"markup-editor-68ac092509","title":" ","cssContent":".footer-nav__link-group .snowflake-button-container,.subnav__item--button,.snowflake-card-v2-advanced-button .snowflake-button-container{justify-content:flex-start}.mega-nav__sign-in.snowflake-button-container{display:none}@media screen and (min-width:768px){.mega-nav__sign-in.snowflake-button-container{display:inline-block;font-family:'Texta',sans-serif;font-weight:800 !important}}@media screen and (min-width:1024px) and (max-width:1199px){.snowflake-mega-nav-header-buttons-container .snowflake-button-blue .snowflake-button-container{font-size:13px !important}.snowflake-language-navigation .language-icon{width:18px !important;height:18px !important;margin-right:4px !important}}.mega-nav__sign-in svg{display:none}.nav-item__platform-parent-why-sf.snowflake-mega-nav-nav-item\u003Ea:hover,.nav-item__platform-parent.snowflake-mega-nav-nav-item\u003Ea:hover{background-color:transparent !important}.nav-platform-sidebar .snowflake-mega-nav-nav-item:hover.blue-icon .snowflake-mega-nav-nav-item-icon__inner{background-color:var(--ui-01) !important}@media screen and (min-width:1024px){.snowflake-mega-nav-navigation-dropdown{overflow:hidden}.meganav-platform-features{padding-left:64px}.meganav-platform-features::before{content:'';transform:translateX(-64px);display:block;z-index:0;width:100%;height:100%;position:absolute;top:0;background:#f7f9fa}.nav-item--si.snowflake-mega-nav-nav-item\u003Ea:hover{background-color:transparent}.nav-item--si{border-bottom:1px solid #ccc;padding-bottom:16px;margin-bottom:8px}.nav-item__platform-parent{border-bottom:1px solid #ccc;margin-bottom:8px;padding-bottom:16px}.nav-item__platform-parent-why-sf .snowflake-mega-nav-nav-item-description::after{content:'What Snowflake can do for you \u003E';display:block;color:var(--ui-01);margin-top:16px}.nav-item__platform-parent .snowflake-mega-nav-nav-item-description::after{content:'View the platform \u003E';display:block;color:var(--ui-01);margin-top:16px}}@media screen and (min-width:1367px){.snowflake-mega-nav-nav-item-description{font-size:13px !important;line-height:20px !important}.snowflake-mega-nav-nav-item-title-wrapper\u003E.snowflake-mega-nav-nav-item-title{font-size:17px !important}.nav-item__platform-parent-why-sf .snowflake-mega-nav-nav-item-title,.nav-item__platform-parent .snowflake-mega-nav-nav-item-title{font-size:24px !important;line-height:32px !important;margin-bottom:8px !important}.nav-item__platform-parent-why-sf .snowflake-mega-nav-nav-item-description,.nav-item__platform-parent .snowflake-mega-nav-nav-item-description{font-size:14px !important;line-height:20px !important}}html.wf-texta-n9-loading .display-1-v2{font-size:48px!important;line-height:50px!important;letter-spacing:-.5px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .heading-4-v2{font-size:18px!important;line-height:24px!important;font-family:sans-serif!important}@media screen and (min-width:768px){html.wf-texta-n9-loading .display-2-v2{font-size:48px!important;line-height:50px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .display-1-v2{font-size:55.5px!important;line-height:54px!important;letter-spacing:-.5px!important;font-family:sans-serif!important}html.wf-lato-n4-loading .body-2,html.wf-lato-n4-loading .heading-5-v2,html.wf-lato-n4-loading .snowflake-card-v2-advanced-text .snowflake-text p{font-size:15.5px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .heading-2,html.wf-texta-n9-loading .heading-2-v2{font-size:34px!important;line-height:38px!important;letter-spacing:-.75px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .heading-6-v2.snowflake-mega-nav-navigation-title{font-size:13.5px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .heading-4,html.wf-texta-n8-loading .snowflake-button-container,html.wf-texta-n8-loading .snowflake-button-regular .snowflake-button-container{font-size:13px!important;line-height:20px!important;letter-spacing:.25px!important;font-family:sans-serif!important}}@media screen and (min-width:1024px){html.wf-lato-n4-loading .snowflake-mega-nav-nav-item-description{font-size:11.5px!important;font-family:sans-serif!important}html.wf-lato-n4-loading .body-2,html.wf-lato-n4-loading .text-size-regular .snowflake-text li,html.wf-lato-n4-loading .text-size-regular .snowflake-text p,html.wf-lato-n4-loading .text-size-regular .snowflake-text span[data-testid=text-content],html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom li,html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom p,html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom span[data-testid=text-content]{font-size:13.5px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .snowflake-button-compact .snowflake-button-container{font-size:12px!important;letter-spacing:0!important;line-height:18px!important}}@media screen and (min-width:1367px){html.wf-lato-n4-loading .hp-hero__eyebrow a\u003Eb:first-child{font-size:11px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .hp-hero__eyebrow a{font-size:13px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .display-2-v2{font-size:61px!important;line-height:60px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .display-1-v2{font-size:74.5px!important;line-height:74px!important;letter-spacing:-.75px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .heading-2,html.wf-texta-n9-loading .heading-2-v2{font-size:41px!important;letter-spacing:-.75px!important;font-family:sans-serif!important}html.wf-texta-n9-loading .heading-3-v2{font-family:sans-serif!important;letter-spacing:-.75px!important;font-size:33.75px!important}html.wf-texta-n9-loading .heading-4-v2{font-size:19.5px!important;line-height:26px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .heading-6-v2{font-size:12px!important;font-family:sans-serif!important}html.wf-texta-n8-loading .heading-6-v2.snowflake-mega-nav-navigation-title{font-size:14px!important;font-family:sans-serif!important}html.wf-lato-n4-loading .body-1,html.wf-lato-n4-loading .cq-Editable-dom[data-cq-data-path*=text] ol\u003Eli,html.wf-lato-n4-loading .snowflake-text li,html.wf-lato-n4-loading .snowflake-text p,html.wf-lato-n4-loading .text-size-large .snowflake-text li,html.wf-lato-n4-loading .text-size-large .snowflake-text p,html.wf-lato-n4-loading .text-size-large .snowflake-text span[data-testid=text-content],html.wf-lato-n4-loading .text-size-large.cq-Editable-dom li,html.wf-lato-n4-loading .text-size-large.cq-Editable-dom p,html.wf-lato-n4-loading .text-size-large.cq-Editable-dom span[data-testid=text-content],html.wf-lato-n4-loading.cq-Editable-dom[data-cq-data-path*=text]\u003Ep,html.wf-lato-n4-loading.cq-Editable-dom[data-cq-data-path*=text]\u003Eul\u003Eli{font-size:17.5px!important;font-family:sans-serif!important}html.wf-lato-n4-loading .body-2,html.wf-lato-n4-loading .text-size-regular .snowflake-text li,html.wf-lato-n4-loading .text-size-regular .snowflake-text p,html.wf-lato-n4-loading .text-size-regular .snowflake-text span[data-testid=text-content],html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom li,html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom p,html.wf-lato-n4-loading .text-size-regular.cq-Editable-dom span[data-testid=text-content],html.wf-texta-n8-loading .snowflake-button-link .snowflake-button-container,html.wf-texta-n8-loading .snowflake-button-link-back .snowflake-button-container{font-size:15.5px!important;font-family:sans-serif!important}html.wf-lato-n4-loading .body-3,html.wf-lato-n4-loading .text-size-small .snowflake-text li,html.wf-lato-n4-loading .text-size-small .snowflake-text p,html.wf-lato-n4-loading .text-size-small .snowflake-text span[data-testid=text-content],html.wf-lato-n4-loading .text-size-small.cq-Editable-dom li,html.wf-lato-n4-loading .text-size-small.cq-Editable-dom p,html.wf-lato-n4-loading .text-size-small.cq-Editable-dom span[data-testid=text-content]{font-size:13.5px!important;font-family:sans-serif!important}}#industryPlatformSection,.sc-hero{background-position:top left;background-size:20% auto}.bwalignc,.bwalignr{list-style-position:inside}.snowflake-text p sup{font-size:10px}#industryPlatformSection .industry-platform__row .snowflake-flexible-column-container-items,.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container,.snowflake-hero-system-content-container{gap:16px}.agenda-item p,.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv,.partner-details p{margin:0!important}.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container::after,.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container::before,.hide-logo .snowflake-case-study-card-logo,.partner-page__powered-by-logo,.sc-hero div.code-toolbar\u003E.toolbar,.snowflake-card-v2-advanced.no-link .snowflake-card-v2-advanced-button,.snowflake-partner-hero-card-badge-container{display:none!important}.section--card-mobile-carousel .snowflake-flexible-column-container-items-with-carousel{max-width:100%!important}@media screen and (min-width:768px){.button-group-pair .snowflake-button-container.inline-button--desktop,.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:auto!important;display:inline-block!important}.button-group-pair\u003E.container\u003E.cmp-container\u003E.aem-container{align-items:center;justify-content:flex-start!important}.button-group-pair.center\u003E.container\u003E.cmp-container\u003E.aem-container{justify-content:center!important}.section--card-mobile-carousel{margin-left:var(--tablet-portrait-margin,48px)!important;margin-right:var(--tablet-portrait-margin,48px);width:calc(100% - 96px)!important;width:calc(100% - var(--tablet-portrait-margin) * 2)!important}}@media screen and (min-width:1024px){.section--card-mobile-carousel{margin-left:var(--tablet-horizontal-margin,48px)!important;margin-right:var(--tablet-horizontal-margin,48px);width:calc(100% - 96px)!important;width:calc(100% - var(--tablet-horizontal-margin) * 2)!important}.snowflake-mega-nav-header-mobile-icon{display:none!important}}@media screen and (min-width:1367px){.section--card-mobile-carousel{margin-left:var(--desktop-margin,6.5%)!important;margin-right:var(--desktop-margin,6.5%);width:87%!important;width:calc(100% - var(--desktop-margin) * 2)!important}.logo-container{min-width:143px}.sc-hero__headline .heading-1-v2{font-size:60px}.snowflake-mega-nav-navigation-title{font-size:17px}.snowflake-mega-nav-dropdown-footer-wrapper .snowflake-title-v2 .snowflake-title-v2-line:first-child{font-size:16px!important;line-height:24px!important}}.hero--home{overflow:hidden;background-color:var(--ui-01);z-index:2}.hp-hero__subheadline{width:90%}.hero--home .snowflake-button-container{transition:.3s}.hero--home .snowflake-button-primary a:hover,.hero--home .snowflake-button-secondary a:hover,.hero--home .snowflake-button-white a:hover{transition:.3s;background-color:var(--ui-02)!important;color:var(--ui-05)!important}.hero--home .snowflake-button-secondary a:hover{border-color:var(--ui-05)!important}.hero--home .snowflake-button-primary a:hover,.hero--home .snowflake-button-white a:hover{border-color:var(--ui-02)!important}.bwalignc,.hp-hero__eyebrow{text-align:center}.hp-hero__eyebrow a{display:inline-flex;flex-direction:column;justify-content:center;cursor:pointer;padding:8px;border-radius:var(--spacing-01);gap:8px;align-items:center;background-color:#45aee3;color:var(--ui-03);font-family:Texta,sans-serif;font-weight:800;font-size:16px;line-height:22px;transition:background-color .3s}.hp-hero__eyebrow a:hover{background-color:#7fc6ea;text-decoration:none;transition:background-color .3s}.hp-hero__eyebrow a\u003Eb:first-child{text-transform:uppercase;white-space:nowrap;display:inline-block;background-color:var(--ui-02);color:var(--ui-05);font-size:12px!important;line-height:16px!important;font-family:Lato,sans-serif;font-weight:500!important;padding:3px 6px;border-radius:2px;letter-spacing:1px}@media screen and (min-width:767px){.hp-hero__eyebrow{text-align:left}.hp-hero__eyebrow a{flex-direction:row;text-align:left}}.hero--home__inner .offset-video,.hero--home__inner .snowflake-experience-fragment,.offset-video__bg-image{max-height:200px;overflow:hidden}.hero--home__inner .offset-video .wistia-responsive-padding{padding-top:100%}.hero--home__inner .snowflake-experience-fragment,.offset-video__bg-image{position:absolute!important;top:0;left:0;width:100%}.offset-video__bg-image{z-index:-1}@media screen and (min-width:768px){.hero--home__inner .snowflake-experience-fragment,.offset-video,.offset-video__bg-image{position:absolute!important;max-height:none;top:0;left:0;width:250%;padding-bottom:250%;transform:translate(0,-50%);height:0}.workloads_7.unistore{max-width:317px}}.promo-banner--homepage{z-index:2}.homepage-banner-offset-container::after{content:\"\";display:block;position:absolute;bottom:0;z-index:1;left:0;width:100%;height:80%;background:#fff}.section--quicklinks .snowflake-button-full-width a{padding-left:24px!important;padding-right:24px!important;transition:box-shadow .25s cubic-bezier(.4,0,.2,1);text-align:left;display:flex;justify-content:center;align-items:center}.section--quicklinks .snowflake-button-full-width a:hover{box-shadow:0 16px 16px 0 rgb(0 0 0 / .16);transition:box-shadow .25s cubic-bezier(.4,0,.2,1)}.section--quicklinks .snowflake-button-container:focus-visible a::before,.section--quicklinks .snowflake-button-full-width a::before{content:\"\";width:23px;height:23px;flex-shrink:0;margin-right:12px;display:inline-block;background-size:cover;background-repeat:no-repeat;background-position:center}#industryPartnerSlider .snowflake-navigation-icon.swiper-button-disabled,#partnerResources .section--resource-hub a svg,.button-tabs span.snowflake-tabs-navigation-item:after,.customer-card--hide-cta .snowflake-case-study-card-button,.dot-tabs span.snowflake-tabs-navigation-item::after,.partner-sidebar__mobile-expand,html:not(.aem-AuthorLayer-initial):not(.aem-AuthorLayer-Edit) .tab-content:not(.is-active){display:none}.section--quicklinks .snowflake-button-full-width a.pricing::before{background-image:url(https://www.snowflake.com/content/dam/snowflake-site/general/icons/decorative-icons/pricing-icon.svg)}.section--quicklinks .snowflake-button-full-width a.snowflake_on_snowflake::before{background-image:url(https://www.snowflake.com/content/dam/snowflake-site/general/icons/navigation/nav-icon_snowflake-bug.svg)}.section--quicklinks .snowflake-button-full-width a.virtual_hands_on_labs::before{background-image:url(https://www.snowflake.com/content/dam/snowflake-site/general/icons/navigation/nav-icon__training.svg)}.section--quicklinks .snowflake-button-full-width a.weekly_demo::before{background-image:url(https://www.snowflake.com/content/dam/snowflake-site/general/icons/navigation/nav-icon__webinars.svg)}@media screen and (min-width:1024px){.hero--home__inner .snowflake-experience-fragment,.offset-video,.offset-video__bg-image{left:-50%}.section--quicklinks .snowflake-flexible-column-container-items{gap:24px}.snowflake-quote-item-inner{padding:32px 24px 24px!important}}#communitiesOuter_overflowBottomGray::after{max-height:100px}#caseStudyOuter_overflowBottomMidBlue::after{max-height:180px}#caseStudyInner .snowflake-case-study-card .snowflake-wistia-video{border-radius:0!important}#caseStudyInner .snowflake-case-study-card{box-shadow:none!important;border-radius:0}#caseStudyInner{max-width:1200px;margin:0 auto;box-shadow:rgb(152 162 179 / .1) 0 10px 20px 0,rgb(152 162 179 / .25) 0 2px 6px 0;border-radius:8px;overflow:hidden;position:relative;z-index:1}.case-study__logo-bar\u003E.snowflake-flexible-column-container-items{background:#f7f9fa;padding:32px 16px 40px}.case-study__logo-bar .cmp-image__image{width:90%;margin:0 auto;max-width:240px}.hp-platform__text-group\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:not(:first-child),.sc-sidebar__group .snowflake-button-link{margin-top:8px}.workloads_7.unistore{margin-left:auto;margin-right:auto}#homepageFootnotesInner .snowflake-simple-stat-disclaimer .snowflake-text p{color:#fff!important}.snowflake-simple-stat-disclaimer .snowflake-text p\u003Ea{border-bottom:1px solid var(--ui-03);color:var(--text-03)}.snowflake-card-v2-advanced{color:inherit}#workloadCardGridOuter .snowflake-card-v2-base-front{gap:0}.video-modal.snowflake-modal-window-open-inner{background-color:#fff0;padding:8px;border:none}.snowflake-container-arrow-dotted-faded .snowflake-container-arrow-dotted-faded-image{width:40%!important;max-width:420px;top:4%!important}.list--blue-bullets ul{margin:0!important;padding:0!important;list-style-type:none}.list--blue-bullets li{margin:0;padding:0 0 0 32px;position:relative}.list--blue-bullets li::before{content:\"\";display:block;border-radius:100%;background:#29b5e8;width:18px;height:18px;position:absolute;top:4px;left:0;border:5px solid #e5f2f7;box-sizing:border-box}.list--blue-bullets li:not(:last-child){margin-bottom:1rem}.logo-tabs .snowflake-navigation-container,.snowflake-simple-stat-content:empty,.summit-speaker-card .snowflake-card-v2-advanced-text{margin-bottom:0}#techResourceInner,#techResourceOuter,div.overflow-bottom--blue,div.overflow-bottom--gray,div.overflow-bottom--mid-blue,div.overflow-bottom--white,div.overflow-top--blue,div.overflow-top--gray,div.overflow-top--mid-blue,div.overflow-top--white,div[id$=overflowBottomGray],div[id$=overflowBottomMidBlue],div[id$=overflowTopBlue],div[id$=overflowTopGray]{position:relative}div.overflow-bottom--blue::after,div.overflow-bottom--gray::after,div.overflow-bottom--mid-blue::after,div.overflow-bottom--white::after,div.overflow-top--blue::after,div.overflow-top--gray::after,div.overflow-top--mid-blue::after,div.overflow-top--white::after,div[id$=overflowBottomGray]::after,div[id$=overflowBottomMidBlue]::after,div[id$=overflowBottomWhite]::after,div[id$=overflowTopBlue]::after,div[id$=overflowTopGray]::after,div[id$=overflowTopWhite]::after{content:\"\";display:block;position:absolute;left:0;width:100%;height:40%}div.overflow-top--blue::after,div.overflow-top--gray::after,div.overflow-top--mid-blue::after,div.overflow-top--white::after,div[id$=overflowTopBlue]::after,div[id$=overflowTopGray]::after,div[id$=overflowTopWhite]::after{top:0}div.overflow-bottom--blue::after,div.overflow-bottom--gray::after,div.overflow-bottom--mid-blue::after,div.overflow-bottom--white::after,div[id$=overflowBottomGray]::after,div[id$=overflowBottomMidBlue]::after,div[id$=overflowBottomWhite]::after{bottom:0}div.overflow-bottom--white::after,div.overflow-top--white::after,div[id$=overflowBottomWhite]::after,div[id$=overflowTopWhite]::after{background:#fff!important}div.overflow-bottom--gray::after,div.overflow-top--gray::after,div[id$=overflowBottomGray]::after,div[id$=overflowTopGray]::after{background:#f6f9fa!important}div.overflow-bottom--mid-blue::after,div.overflow-top--mid-blue::after,div[id$=overflowBottomMidBlue]::after,div[id$=overflowTopMidBlue]::after{background:#11567f!important}div.overflow-bottom--blue::after,div.overflow-top--blue::after,div[id$=overflowBottomBlue]::after,div[id$=overflowTopBlue]::after{background:#259edc!important}.snowflake-premium-content-banner.promo-banner--no-shadow{box-shadow:none!important}#industryPartnerSlider .cmp-image__image,#industryPartnerSlider .section--partner-tabs .snowflake-image-container .cmp-image__image,#partnerSidebar,.has-shadow .cmp-image__image{box-shadow:0 10px 20px 0 rgb(152 162 179 / .1),0 2px 6px 0 rgb(152 162 179 / .25)}.content-chip--has-desc{align-items:flex-start;padding:20px!important}.content-chip--has-desc .snowflake-content-chip-image{max-width:100px}.content-chip--has-desc .snowflake-content-chip-image__image{aspect-ratio:1}.content-chip--has-desc .snowflake-title-v2-line:first-child{font-size:18px!important}.content-chip--has-desc .snowflake-title-v2-line:nth-child(2){color:#000!important;font-weight:500!important;font-size:16px!important;line-height:22px!important;margin-top:2px!important}.content-chip--has-desc .snowflake-content-chip-button{margin-top:6px!important;font-size:18px!important;display:none}.square-image .snowflake-content-chip-image{aspect-ratio:1;max-width:120px}.section--logo-bar.smaller-logos .snowflake-image-container .cmp-image__image{max-width:200px;margin:0 auto}.snowflake-card-v2-advanced-tag,.snowflake-content-chip-tag{padding:3px 6px!important}.sc-overview__webinar-promo-banner .snowflake-content-chip-button,.snowflake-card-v2-advanced-title:first-child,.summit-pricing-block__aside ul{margin-top:0}.dot-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item{width:40px;height:40px;display:flex;justify-content:center;align-items:center;margin:0!important}.dot-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item p{width:12px;height:12px;background:var(--ui-12);border-radius:100%}.dot-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item p,.logo-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item p{font-size:0!important}.dot-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item.active p{background:var(--ui-01)}.button-tabs .snowflake-navigation-container .swiper-wrapper{padding:8px 0}.button-tabs .snowflake-navigation-container .swiper-slide{margin:0 6px}.button-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item{padding:8px 24px;background-color:#f6f9fa;border-radius:48px;margin:0}.button-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item p{text-transform:uppercase;font-family:Texta,sans-serif;font-weight:700}.button-tabs .border-top{border-top:1px solid #ccc}.button-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item.active{background-color:var(--ui-01);box-shadow:0 2px 6px 0 rgb(152 162 179 / .25),0 10px 20px 0 rgb(152 162 179 / .1)}.button-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item.active p{color:#fff}.button-tabs.has-icons .snowflake-navigation-container .snowflake-tabs-navigation-item p::before{content:\"\";display:inline-block;width:20px;height:20px;background-size:contain;background-repeat:no-repeat;background-position:center center;margin-right:12px;vertical-align:middle;margin-top:-3px}.logo-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item{width:220px;padding-bottom:50%;height:0;margin:0 8px!important;background-size:cover;background-repeat:no-repeat;opacity:.5;transition:opacity .3s}.logo-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item:hover{opacity:.75;transition:opacity .3s}.logo-tabs .snowflake-navigation-container .snowflake-tabs-navigation-item.active{opacity:1;transition:opacity .3s}.dot-tabs .aem-container.cmp-tabs,.logo-tabs .aem-container.cmp-tabs{display:flex;flex-direction:column-reverse}.snowflake-icon.is-center{margin:0 auto;display:block}#industryPartnerSlider .snowflake-flexible-column-container-items,#partnerLogoSquare .snowflake-flexible-column-container-items{gap:24px}#techResourceOuter::after{content:\"\";display:block;position:absolute;top:0;left:0;width:100%;height:40%;background:#f6f9fa}#techResourceInner{z-index:1}.partner-tier-tag h6{display:inline-block!important;padding:2px 6px;border-radius:2px;color:#666}.partner-tier-tag.registered h6{background-color:#f6f9fa}.partner-tier-tag.elite h6{background-color:#11567f;color:#fff}.partner-tier-tag.premier h6{background-color:#b14c77;color:#fff}.partner-tier-tag.select h6{background-color:#5094a0;color:#fff}.partner-details\u003Espan{display:flex;gap:24px}.partner-details a{color:inherit!important;font-weight:400!important}.partner-details p::before{content:\"\";display:inline-block;vertical-align:middle;width:16px;height:16px;background-repeat:no-repeat;background-position:center;transform:translateY(-1px);background-size:auto 90%;margin-right:6px}.partner-details__location::before{background-image:url(\"data:image/svg+xml,%3Csvg width='13' height='18' viewBox='0 0 13 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M6.25 17.7531C6.4375 17.7531 6.6 17.6844 6.7375 17.5531C6.875 17.4219 6.95 17.2531 6.95 17.0531C6.95 16.8531 7.075 16.4281 7.3 15.7969C7.5875 15.0281 7.925 14.3156 8.30625 13.6406C8.8 12.7781 9.3125 12.1031 9.85 11.6094C10.75 10.7969 11.4125 9.96563 11.85 9.12188C12.2875 8.27813 12.5063 7.40313 12.5063 6.49063C12.5063 5.36563 12.2187 4.31563 11.6437 3.33438C11.0937 2.40313 10.3438 1.65938 9.4 1.10938C8.43125 .534376 7.375 .246876 6.24375 .246876C5.1125 .246876 4.06875 .534376 3.0875 1.10938C2.15625 1.65938 1.4125 2.40313 .862498 3.33438C.287498 4.31563 0 5.36563 0 6.49063C0 7.47188 .262499 8.42813 .787499 9.35938C1.14375 10.0031 1.65625 10.6656 2.3125 11.3344C2.75625 11.8031 3.24375 12.4781 3.78125 13.3656C4.225 14.0969 4.63125 14.8594 5 15.6656C5.35 16.3844 5.53125 16.8531 5.55625 17.0656C5.55625 17.2594 5.625 17.4156 5.7625 17.5531C5.9 17.6844 6.0625 17.7531 6.25 17.7531ZM6.16875 14.9156C5.775 14.0656 5.325 13.2469 4.825 12.4594C4.275 11.5594 3.7625 10.8719 3.28125 10.3969C2.625 9.71563 2.1375 9.05938 1.825 8.43438C1.5125 7.80313 1.35625 7.16563 1.35625 6.50313C1.35625 5.61563 1.575 4.80313 2.0125 4.05313C2.45 3.30313 3.04375 2.71563 3.7875 2.27813C4.5375 1.84063 5.35 1.62188 6.2375 1.62188C7.125 1.62188 7.9375 1.84063 8.6875 2.27813C9.4375 2.71563 10.0312 3.30313 10.475 4.04688C10.9187 4.80313 11.1375 5.62188 11.1375 6.50313C11.1375 7.90313 10.3937 9.26563 8.9125 10.5969C8.35 11.1094 7.8125 11.7906 7.3 12.6406C6.88125 13.3344 6.50625 14.0969 6.16875 14.9219V14.9156ZM6.26875 8.36563C6.65625 8.36563 7.01875 8.26563 7.35625 8.07188C7.69375 7.87813 7.95625 7.60938 8.14375 7.28438C8.3375 6.95313 8.43125 6.59063 8.43125 6.19688C8.43125 5.80313 8.33125 5.43438 8.1375 5.10313C7.9375 4.76563 7.675 4.50313 7.3375 4.31563C7 4.12813 6.6375 4.02813 6.24375 4.02813C5.85 4.02813 5.4875 4.12813 5.15625 4.32188C4.825 4.52188 4.56875 4.78438 4.375 5.12188C4.18125 5.45938 4.0875 5.82188 4.0875 6.20938C4.0875 6.59688 4.1875 6.95938 4.38125 7.29688C4.58125 7.63438 4.84375 7.89688 5.18125 8.08438C5.51875 8.27813 5.88125 8.37188 6.26875 8.37188V8.36563ZM6.24375 7.50313C5.8875 7.50313 5.575 7.37188 5.31875 7.11563C5.0625 6.85938 4.93125 6.55313 4.93125 6.19063C4.93125 5.82813 5.0625 5.52188 5.31875 5.26563C5.575 5.00938 5.88125 4.87813 6.24375 4.87813C6.60625 4.87813 6.9125 5.00938 7.16875 5.26563C7.425 5.52188 7.55625 5.82813 7.55625 6.19063C7.55625 6.55313 7.425 6.85938 7.16875 7.11563C6.9125 7.37188 6.60625 7.50313 6.24375 7.50313Z' fill='%2329B5E8'/%3E%3C/svg%3E%0A\")}.partner-details__website::before{background-image:url(\"data:image/svg+xml,%3Csvg width='18' height='16' viewBox='0 0 18 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2.61587 2.96889C2.61587 2.75109 2.79633 2.57062 3.01413 2.57062C3.23192 2.57062 3.41238 2.75109 3.41238 2.96889C3.41238 3.18669 3.23192 3.36716 3.01413 3.36716C2.79633 3.36716 2.61587 3.18669 2.61587 2.96889ZM4.21512 2.96889C4.21512 2.75109 4.39558 2.57062 4.61338 2.57062C4.83117 2.57062 5.01163 2.75109 5.01163 2.96889C5.01163 3.18669 4.83117 3.36716 4.61338 3.36716C4.39558 3.36716 4.21512 3.18669 4.21512 2.96889ZM5.81438 2.96889C5.81438 2.75109 5.99484 2.57062 6.21264 2.57062C6.43043 2.57062 6.61089 2.75109 6.61089 2.96889C6.61089 3.18669 6.43043 3.36716 6.21264 3.36716C5.99484 3.36716 5.81438 3.18669 5.81438 2.96889ZM17.2518 .697559H1.19085C.811258 .697559 .506348 1.0025 .506348 1.38209V14.6179C.506348 14.9975 .811258 15.3024 1.19085 15.3024H17.2518C17.6314 15.3024 17.9363 14.9975 17.9363 14.6179V1.38209C17.9363 1.0025 17.6314 .697559 17.2518 .697559ZM16.5673 2.06035V3.90853H1.86914V2.06035H16.5673ZM1.86914 13.9334V4.78593H16.5673V13.9334H1.86914Z' fill='%2329B5E8'/%3E%3C/svg%3E%0A\")}#partnerSidebar{border-radius:4px;background-color:#fff;padding:24px 24px 32px;border-bottom:6px solid #29b5e8}#partnerSidebar h5,.newsletter-disclaimer p{font-size:14px!important}#partnerSidebar ul{margin-top:0;list-style-type:none;padding:0;display:flex;flex-wrap:wrap;gap:8px}#partnerSidebar li{border:1px solid;border-radius:2px;padding:0 4px!important;font-size:11px!important;letter-spacing:.25px;text-transform:uppercase}div.snowflake-partner-hero-card{width:100%;margin:0}.partner-details__logo{max-width:380px;margin:0 auto}@media screen and (max-width:767px){.left-alignment .hp-hero__subheadline{margin-left:auto;margin-right:auto}.left-alignment .hp-hero__headline .snowflake-title-v2-line,.left-alignment .hp-hero__subheadline .snowflake-title-v2-line{text-align:center}.hero--home__inner .snowflake-flexible-column-container-items-top-padding-large{padding-top:var(--spacing-02)}.section--logo-bar\u003E.snowflake-flexible-column-container-items{display:flex;flex-wrap:wrap;flex-direction:row;justify-content:center;gap:8px}.section--logo-bar\u003E.snowflake-flexible-column-container-items\u003Ediv{width:calc(33.33% - 8px)}.partner-sidebar__mobile-expand{display:inline-block;color:#249edc;border-color:#249edc!important}#partnerSidebar li:nth-child(n+6),.summit-nav__links .snowflake-button-tertiary{display:none}.sc-body__sidebar{background-color:#f6f9fa;padding:24px}.sc-body__content{padding:0 24px 24px}.summit-speaker-card .snowflake-card-v2-advanced-content{padding:24px}}#partnerResources h6,.snowflake-tabs-navigation-item p.body-1{font-size:16px!important}#partnerResources .section--resource-hub{padding:0 16px}#partnerResources .section--resource-hub a,.bwalignl{text-align:left}@media screen and (max-width:1023px){.hero--workload .snowflake-hero-system-media-container{width:100%}}.section--timely-content .snowflake-content-chip,.snowflake-mega-nav-dropdown-footer-wrapper{align-items:center}.section--timely-content .snowflake-content-chip-image{max-width:94px}.section--timely-content .snowflake-content-chip-image__inner{line-height:0}.section--timely-content .snowflake-content-chip-image__image{aspect-ratio:1;height:auto}.section--workload-overview .workload-overview__headline{max-width:280px;margin:0 auto}#industryPartnerSlider .swiper-slide{margin-top:0!important;padding:0 12px}#industryPartnerSlider .snowflake-tabs-navigation-item{margin-left:0!important;margin-right:0!important}#industryPartnerSlider .snowflake-premium-content-banner-background-grad-white .snowflake-premium-content-banner{box-shadow:none}#industryPartnerSlider .logo-slider__slide .aem-container{display:flex;padding:0 8px!important;flex-wrap:wrap;gap:16px!important;justify-content:center}#industryPartnerSlider .logo-slider__slide .aem-container\u003Ediv{width:48%;max-width:200px}#useCaseTabs{padding-top:24px;padding-bottom:24px;padding-right:24px}#useCaseTabs .tab-content.is-active{display:block}#useCaseTabs .vert-tab{border-bottom:1px solid #a0bbcc;padding-bottom:16px}#useCaseTabs .vert-tab p{display:inline-block}#useCaseTabs .vert-tab p:hover{cursor:pointer}#useCaseTabs .vert-tab p,#useCaseTabs .vert-tab.is-active p.not-active{color:#249edc}#useCaseTabs .vert-tab p.is-active,#useCaseTabs .vert-tab.is-active p{color:#000}#industryPlatformSection{background-image:url(/adobe/dynamicmedia/deliver/dm-aid--db074ad5-7122-4c51-87a3-76c3aa466182/double-arrow-bg%403x.png);background-repeat:no-repeat}.snowflake-text p.featured-quote__source{font-weight:900!important;text-transform:uppercase;font-size:16px!important;margin-top:2rem!important}.snowflake-text p.featured-quote__title{margin-top:0!important;font-size:16px!important}.snowflake-case-study-card-logo img{width:auto!important;height:100px!important;transform:translateX(-15%)}.snowflake-quote-item-quote-text{font-weight:600!important}#customerStoryStatsInner\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-direction:row}#customerStoryStat1,#customerStoryStat2{max-width:240px}#storyHighlights{border-radius:4px;padding:1rem}.sc-overview__webinar-promo-banner .snowflake-content-chip-content .snowflake-title-v2-line,.summit-pricing-block__tile .black-blue-text-color .snowflake-title-v2-line{color:#000!important}.snowflake-youtube-embedded-wrapper{border-radius:var(--small-border-radius)}#arcticNavItem::before,#offset::before,#open-source::before{color:var(--text-05);font-family:Texta,sans-serif!important}#offset,.sc-architecture-caption{margin-top:16px}.hero--press .snowflake-title-v2-line{text-transform:none!important}@media screen and (min-width:768px){.subpage-timely-content__inner\u003E.snowflake-flexible-column-container-items{box-shadow:0 10px 20px 0 rgb(152 162 179 / .1),0 2px 6px 0 rgb(152 162 179 / .25);padding:var(--spacing-04);border-radius:4px;overflow:hidden}#partnerLogoSquare{padding:0 0 0 48px}.hero--workload .snowflake-container{max-width:1440px;margin:0 auto!important;align-items:center}#industryPartnerSlider.snowflake-flexible-column-container-2-column-40-60\u003E.snowflake-flexible-column-container-items{grid-template-columns:minmax(40%,4fr) minmax(0,6fr)}#industryPartnerSlider .swiper-slide{padding:0 24px}.sc-body{padding:48px}.sc-body\u003E.snowflake-flexible-column-container-items{grid-template-columns:7fr 3fr;gap:124px}}.snowflake-button-container.has-icon{display:inline-flex;justify-content:center;align-items:center;text-align:left}.snowflake-button-container.has-icon::before{content:\"\";display:inline-block;width:20px;height:20px;margin-right:12px;background-size:contain;background-repeat:no-repeat;background-position:center}.snowflake-button-container.is-video::before{background-image:url(\"data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 18 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M9 1.28663C13.2523 1.28663 16.7134 4.74768 16.7134 9C16.7134 13.2523 13.2523 16.7134 9 16.7134C4.74768 16.7198 1.28663 13.2588 1.28663 9C1.28663 4.74124 4.74768 1.28663 9 1.28663ZM9 0C4.0336 0 0 4.0336 0 9C0 13.9664 4.0336 18 9 18C13.9728 18 18 13.9664 18 9C18 4.0336 13.9728 0 9 0Z' fill='white'/%3E%3Cpath d='M7.75106 6.18211C7.42941 6.16925 7.16565 6.42658 7.16565 6.74823V11.2772C7.16565 11.7082 7.65457 11.9848 8.02126 11.7597L11.7975 9.4952C12.1578 9.27647 12.1578 8.74252 11.7975 8.52379L8.02126 6.25931C7.93763 6.21428 7.84756 6.18211 7.75106 6.18211Z' fill='white'/%3E%3C/svg%3E%0A\")}.snowflake-button-container.is-github::before{background-image:url(\"data:image/svg+xml,%3Csvg width='20' height='21' viewBox='0 0 20 21' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M10 .651794C4.475 .651794 0 5.12679 0 10.6518C0 15.0768 2.8625 18.8143 6.8375 20.1393C7.3375 20.2268 7.525 19.9268 7.525 19.6643C7.525 19.4268 7.5125 18.6393 7.5125 17.8018C5 18.2643 4.35 17.1893 4.15 16.6268C4.0375 16.3393 3.55 15.4518 3.125 15.2143C2.775 15.0268 2.275 14.5643 3.1125 14.5518C3.9 14.5393 4.4625 15.2768 4.65 15.5768C5.55 17.0893 6.9875 16.6643 7.5625 16.4018C7.65 15.7518 7.9125 15.3143 8.2 15.0643C5.975 14.8143 3.65 13.9518 3.65 10.1268C3.65 9.03929 4.0375 8.13929 4.675 7.43929C4.575 7.18929 4.225 6.16429 4.775 4.78929C4.775 4.78929 5.6125 4.52679 7.525 5.81429C8.325 5.58929 9.175 5.47679 10.025 5.47679C10.875 5.47679 11.725 5.58929 12.525 5.81429C14.4375 4.51429 15.275 4.78929 15.275 4.78929C15.825 6.16429 15.475 7.18929 15.375 7.43929C16.0125 8.13929 16.4 9.02679 16.4 10.1268C16.4 13.9643 14.0625 14.8143 11.8375 15.0643C12.2 15.3768 12.5125 15.9768 12.5125 16.9143C12.5125 18.2518 12.5 19.3268 12.5 19.6643C12.5 19.9268 12.6875 20.2393 13.1875 20.1393C17.1375 18.8143 20 15.0643 20 10.6518C20 5.12679 15.525 .651794 10 .651794Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\")}.snowflake-button-container.is-quickstart::before{background-image:url(\"data:image/svg+xml,%3Csvg width='15' height='21' viewBox='0 0 15 21' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M13.8489 2.79368H11.6439V2.38493C11.6439 1.71368 11.1451 .967427 10.4251 .967427H8.94762C8.80887 .359927 8.37387 .299927 7.89762 .299927H7.23012C6.85512 .299927 6.26637 .299927 6.08637 .967427H4.68387C3.94887 .967427 3.35637 1.74368 3.35637 2.38493V2.79368H1.15137C.738867 2.79368 .401367 3.13118 .401367 3.54368V20.2537C.401367 20.6662 .738867 21.0037 1.15137 21.0037H13.8489C14.2614 21.0037 14.5989 20.6662 14.5989 20.2537V3.54368C14.5989 3.13118 14.2614 2.79368 13.8489 2.79368ZM4.29387 2.38493C4.29387 2.18243 4.54137 1.90493 4.68387 1.90493H6.50262C6.76137 1.90493 6.97137 1.69493 6.97137 1.43618C6.97137 1.33868 6.97887 1.27868 6.98637 1.24118C7.05012 1.23368 7.15512 1.23368 7.23387 1.23368H7.90137C7.95012 1.23368 8.00637 1.23368 8.05137 1.23368C8.05512 1.27868 8.05887 1.34243 8.05887 1.43243C8.05887 1.69118 8.26887 1.90118 8.52762 1.90118H10.4289C10.5301 1.90118 10.7101 2.14493 10.7101 2.38118V2.78993H4.29762V2.38118L4.29387 2.38493ZM13.0989 19.4999H1.90137V4.29368H13.0989V19.5037V19.4999Z' fill='%23249EDC'/%3E%3Cpath d='M3.82512 16.0424H11.1751C11.4339 16.0424 11.6439 15.8324 11.6439 15.5736V6.88486C11.6439 6.62611 11.4339 6.41611 11.1751 6.41611H3.82512C3.56637 6.41611 3.35637 6.62611 3.35637 6.88486V15.5736C3.35637 15.8324 3.56637 16.0424 3.82512 16.0424ZM4.29387 15.1049V13.3686H10.7064V15.1049H4.29387ZM10.7101 7.35361V12.4311H4.29762V7.35361H10.7101Z' fill='%23249EDC'/%3E%3Cpath d='M6.16512 9.35989H8.83887C9.09762 9.35989 9.30762 9.14989 9.30762 8.89114C9.30762 8.63239 9.09762 8.42239 8.83887 8.42239H6.16512C5.90637 8.42239 5.69637 8.63239 5.69637 8.89114C5.69637 9.14989 5.90637 9.35989 6.16512 9.35989Z' fill='%23249EDC'/%3E%3Cpath d='M6.16512 11.3624H8.83887C9.09762 11.3624 9.30762 11.1524 9.30762 10.8937C9.30762 10.6349 9.09762 10.4249 8.83887 10.4249H6.16512C5.90637 10.4249 5.69637 10.6349 5.69637 10.8937C5.69637 11.1524 5.90637 11.3624 6.16512 11.3624Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\")}.snowflake-button-container.is-download::before{background-image:url(\"data:image/svg+xml,%3Csvg width='16' height='18' viewBox='0 0 16 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M15.2017 17.1637H.798265C.364425 17.1637 0 16.7993 0 16.3655V12.3568C0 11.923 .364425 11.5585 .798265 11.5585C1.2321 11.5585 1.59653 11.923 1.59653 12.3568V15.5498H14.4035V12.3568C14.4035 11.923 14.7679 11.5585 15.2017 11.5585C15.6356 11.5585 16 11.923 16 12.3568V16.3655C16 16.7993 15.6529 17.1637 15.2017 17.1637Z' fill='%23249EDC'/%3E%3Cpath d='M7.94793 12.9642C7.84381 12.9642 7.73969 12.9468 7.63557 12.8947C7.34056 12.7733 7.14967 12.4783 7.14967 12.1485L7.18437 .938127C7.18437 .504287 7.5488 .139862 7.98264 .139862C8.41648 .139862 8.7809 .504287 8.7809 .938127L8.7462 10.257L12.8416 6.33509C13.154 6.02273 13.6746 6.04008 13.9696 6.35244C14.282 6.66481 14.2646 7.18542 13.9523 7.48043L8.50325 12.7386C8.36442 12.8774 8.15617 12.9642 7.94793 12.9642Z' fill='%23249EDC'/%3E%3Cpath d='M7.94793 12.9642C7.73969 12.9642 7.54881 12.8947 7.39262 12.7386L2.03037 7.53249C1.718 7.22012 1.70065 6.71687 2.01301 6.40451C2.32538 6.09214 2.82863 6.07479 3.141 6.38715L8.50325 11.5932C8.81562 11.9056 8.83297 12.4088 8.52061 12.7212C8.36442 12.8774 8.15617 12.9642 7.94793 12.9642Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\")}.snowflake-button-container.is-expand::before{background-image:url(\"data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 18 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.64375 10.9125C6.9375 11.2062 6.93125 11.6812 6.64375 11.9687L2.57502 16H3.79375C4.20625 16 4.54376 16.3375 4.54376 16.75C4.54376 17.1625 4.20625 17.5 3.79375 17.5H.756264C.556264 17.5 .36876 17.4187 .22501 17.2812C.22501 17.2812 .206248 17.25 .193748 17.2375C.143748 17.1812 .100004 17.1125 .0625038 17.0437C.0375038 16.9687 .0187492 16.8937 .0187492 16.8187C.0187492 16.8 .0062561 16.7813 .0062561 16.7625V13.725C.0187561 13.3125 .356257 12.9875 .768757 12.9937C1.16876 13 1.48752 13.325 1.50002 13.725V14.9688L5.5875 10.9187C5.88125 10.6312 6.35 10.6312 6.64375 10.9187V10.9125ZM17.5063 .743732C17.5063 .543732 17.425 .356235 17.2875 .218735C17.2875 .218735 17.2562 .199998 17.2437 .193748C17.1875 .137498 17.1188 .0937347 17.0438 .0624847C16.9688 .0374847 16.8938 .0187492 16.8188 .0187492C16.8 .0187492 16.7813 .00623703 16.7625 .00623703H13.725C13.3125 .00623703 12.975 .343745 12.975 .756245C12.975 1.16874 13.3125 1.50623 13.725 1.50623H14.9688L11.1312 5.37498C10.8437 5.67498 10.8563 6.14999 11.1563 6.43124C11.45 6.71249 11.9063 6.70624 12.1938 6.43124L16.0125 2.575V3.79375C16.0125 4.20625 16.35 4.54372 16.7625 4.54372C17.175 4.54372 17.5125 4.20625 17.5125 3.79375V.756245L17.5063 .743732ZM16.7562 12.9688C16.3437 12.9688 16.0063 13.3063 16.0063 13.7188V14.8937L12.1938 10.925C11.9063 10.625 11.4375 10.6188 11.1375 10.9063C10.8375 11.1938 10.8313 11.6625 11.1188 11.9625L15 16.0062H13.7188C13.3063 16.0062 12.9688 16.3437 12.9688 16.7562C12.9688 17.1687 13.3063 17.5063 13.7188 17.5063H16.7562C16.85 17.5063 16.95 17.4875 17.0375 17.45C17.0875 17.425 17.1313 17.3937 17.175 17.3625C17.2063 17.3437 17.2438 17.325 17.275 17.3C17.3313 17.2375 17.375 17.1687 17.4125 17.1C17.4188 17.0875 17.4375 17.075 17.4438 17.0562C17.45 17.025 17.4563 16.9938 17.4625 16.9625C17.4813 16.9 17.5 16.8375 17.5 16.7687V13.725C17.5 13.3125 17.1687 12.975 16.7562 12.975V12.9688ZM.750008 4.53125C1.16251 4.53125 1.50002 4.19374 1.50002 3.78124V2.5L5.59376 6.43124C5.89376 6.71874 6.36251 6.70626 6.65001 6.41251C6.93751 6.11876 6.92501 5.64375 6.63126 5.35625L2.61251 1.49998H3.7875C4.2 1.49998 4.53751 1.16249 4.53751 .749989C4.53751 .337489 4.2 0 3.7875 0H.743752C.668752 0 .600004 .0187355 .531254 .0437355C.506254 .0499855 .481263 .0437477 .462513 .0562477C.443763 .0687477 .425015 .0812462 .406265 .0937462C.337515 .124996 .275004 .168741 .218754 .224991H.212498C.212498 .224991 .175 .28125 .15625 .3125C.11875 .3625 .0812477 .4125 .0562477 .46875C.0374977 .525 .0249992 .587499 .0187492 .643749C.0124992 .674999 0 .712482 0 .743732V3.78124C0 4.19374 .337508 4.53125 .750008 4.53125Z' fill='white'/%3E%3C/svg%3E%0A\")}@keyframes slow-scroll{100%{transform:translateY(-50%)}}.sc-hero{overflow:hidden;background-color:#212d35;background-repeat:repeat-y;background-image:url(\"data:image/svg+xml,%3Csvg width='389' height='17' viewBox='0 0 389 17' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M.638672 7.80824L.638672 9.2566C.638672 9.52364 .85538 9.74024 1.12262 9.74024H2.57204C2.83928 9.74024 3.05598 9.52364 3.05598 9.2566V7.80824C3.05598 7.54119 2.83928 7.32472 2.57204 7.32472L1.12262 7.32472C.85538 7.32472 .638672 7.54119 .638672 7.80824Z' fill='url(%23paint0_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M10.9639 7.80824V9.2566C10.9639 9.52364 11.1806 9.74024 11.4478 9.74024L12.8972 9.74024C13.1645 9.74024 13.3812 9.52364 13.3812 9.2566V7.80824C13.3812 7.54119 13.1645 7.32471 12.8972 7.32471L11.4478 7.32471C11.1806 7.32471 10.9639 7.54119 10.9639 7.80824Z' fill='url(%23paint1_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M21.2891 7.80823V9.2566C21.2891 9.52364 21.5058 9.74024 21.773 9.74024L23.2224 9.74024C23.4897 9.74024 23.7064 9.52364 23.7064 9.2566V7.80823C23.7064 7.54119 23.4897 7.32471 23.2224 7.32471L21.773 7.32471C21.5058 7.32471 21.2891 7.54119 21.2891 7.80823Z' fill='url(%23paint2_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M31.6143 7.80823V9.2566C31.6143 9.52364 31.831 9.74024 32.0982 9.74024H33.5476C33.8149 9.74024 34.0316 9.52364 34.0316 9.2566V7.80823C34.0316 7.54119 33.8149 7.32471 33.5476 7.32471L32.0982 7.32471C31.831 7.32471 31.6143 7.54119 31.6143 7.80823Z' fill='url(%23paint3_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M41.9395 7.80823V9.2566C41.9395 9.52364 42.1562 9.74024 42.4234 9.74024H43.8728C44.1401 9.74024 44.3568 9.52364 44.3568 9.2566V7.80823C44.3568 7.54119 44.1401 7.32471 43.8728 7.32471L42.4234 7.32471C42.1562 7.32471 41.9395 7.54119 41.9395 7.80823Z' fill='url(%23paint4_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M52.5076 7.80823V9.2566C52.5076 9.52364 52.7243 9.74024 52.9916 9.74024H54.441C54.7082 9.74024 54.9249 9.52364 54.9249 9.2566V7.80823C54.9249 7.54119 54.7082 7.32471 54.441 7.32471L52.9916 7.32471C52.7243 7.32471 52.5076 7.54119 52.5076 7.80823Z' fill='url(%23paint5_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M62.8331 7.80823V9.2566C62.8331 9.52364 63.0493 9.74024 63.3165 9.74024H64.7664C65.0332 9.74024 65.2504 9.52364 65.2504 9.2566V7.80823C65.2504 7.54119 65.0332 7.32471 64.7664 7.32471L63.3165 7.32471C63.0493 7.32471 62.8331 7.54119 62.8331 7.80823Z' fill='url(%23paint6_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M73.1583 7.80823V9.2566C73.1583 9.52364 73.3745 9.74024 73.6417 9.74024H75.0916C75.3584 9.74024 75.5756 9.52364 75.5756 9.2566V7.80823C75.5756 7.54119 75.3584 7.32471 75.0916 7.32471L73.6417 7.32471C73.3745 7.32471 73.1583 7.54119 73.1583 7.80823Z' fill='url(%23paint7_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M83.4835 7.80823V9.2566C83.4835 9.52364 83.6997 9.74024 83.9669 9.74024H85.4168C85.6836 9.74024 85.9008 9.52364 85.9008 9.2566V7.80823C85.9008 7.54119 85.6836 7.32471 85.4168 7.32471L83.9669 7.32471C83.6997 7.32471 83.4835 7.54119 83.4835 7.80823Z' fill='url(%23paint8_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M93.8087 7.80823V9.2566C93.8087 9.52364 94.0249 9.74024 94.2921 9.74024H95.742C96.0088 9.74024 96.226 9.52364 96.226 9.2566V7.80823C96.226 7.54119 96.0088 7.32471 95.742 7.32471L94.2921 7.32471C94.0249 7.32471 93.8087 7.54119 93.8087 7.80823Z' fill='url(%23paint9_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M104.134 7.80823V9.2566C104.134 9.52364 104.35 9.74024 104.617 9.74024H106.067C106.334 9.74024 106.551 9.52364 106.551 9.2566V7.80823C106.551 7.54119 106.334 7.32471 106.067 7.32471L104.617 7.32471C104.35 7.32471 104.134 7.54119 104.134 7.80823Z' fill='url(%23paint10_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M114.702 7.80823V9.2566C114.702 9.52364 114.918 9.74024 115.185 9.74024L116.635 9.74024C116.902 9.74024 117.119 9.52364 117.119 9.25659V7.80823C117.119 7.54119 116.902 7.32471 116.635 7.32471L115.185 7.32471C114.918 7.32471 114.702 7.54119 114.702 7.80823Z' fill='url(%23paint11_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M125.027 7.80823V9.25659C125.027 9.52364 125.243 9.74024 125.511 9.74024L126.961 9.74024C127.227 9.74024 127.445 9.52364 127.445 9.25659V7.80823C127.445 7.54119 127.227 7.32471 126.961 7.32471L125.511 7.32471C125.243 7.32471 125.027 7.54119 125.027 7.80823Z' fill='url(%23paint12_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M135.352 7.80823V9.25659C135.352 9.52364 135.569 9.74024 135.836 9.74024H137.286C137.553 9.74024 137.77 9.52364 137.77 9.25659V7.80823C137.77 7.54119 137.553 7.32471 137.286 7.32471L135.836 7.32471C135.569 7.32471 135.352 7.54119 135.352 7.80823Z' fill='url(%23paint13_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M145.678 7.80823V9.25659C145.678 9.52364 145.894 9.74024 146.161 9.74024H147.611C147.878 9.74024 148.095 9.52364 148.095 9.25659V7.80823C148.095 7.54119 147.878 7.32471 147.611 7.32471L146.161 7.32471C145.894 7.32471 145.678 7.54119 145.678 7.80823Z' fill='url(%23paint14_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M156.003 7.80823V9.25659C156.003 9.52364 156.219 9.74024 156.486 9.74024H157.936C158.203 9.74024 158.42 9.52364 158.42 9.25659V7.80823C158.42 7.54119 158.203 7.32471 157.936 7.32471L156.486 7.32471C156.219 7.32471 156.003 7.54119 156.003 7.80823Z' fill='url(%23paint15_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M166.328 7.80823V9.25659C166.328 9.52363 166.544 9.74024 166.811 9.74024H168.261C168.528 9.74024 168.745 9.52363 168.745 9.25659V7.80823C168.745 7.54119 168.528 7.32471 168.261 7.32471L166.811 7.32471C166.544 7.32471 166.328 7.54119 166.328 7.80823Z' fill='url(%23paint16_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M176.896 7.80823V9.25659C176.896 9.52363 177.112 9.74023 177.38 9.74023H178.83C179.096 9.74023 179.313 9.52363 179.313 9.25659V7.80823C179.313 7.54119 179.096 7.32471 178.83 7.32471L177.38 7.32471C177.112 7.32471 176.896 7.54119 176.896 7.80823Z' fill='url(%23paint17_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M187.221 7.80823V9.25659C187.221 9.52363 187.438 9.74023 187.705 9.74023H189.155C189.421 9.74023 189.639 9.52363 189.639 9.25659V7.80823C189.639 7.54119 189.421 7.32471 189.155 7.32471L187.705 7.32471C187.438 7.32471 187.221 7.54119 187.221 7.80823Z' fill='url(%23paint18_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M199.639 7.80824V9.2566C199.639 9.52364 199.855 9.74024 200.123 9.74024H201.572C201.839 9.74024 202.056 9.52364 202.056 9.2566V7.80824C202.056 7.54119 201.839 7.32472 201.572 7.32472L200.123 7.32472C199.855 7.32472 199.639 7.54119 199.639 7.80824Z' fill='url(%23paint19_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M209.964 7.80824V9.2566C209.964 9.52364 210.181 9.74024 210.448 9.74024L211.897 9.74024C212.164 9.74024 212.381 9.52364 212.381 9.2566V7.80824C212.381 7.54119 212.164 7.32471 211.897 7.32471L210.448 7.32471C210.181 7.32471 209.964 7.54119 209.964 7.80824Z' fill='url(%23paint20_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M220.289 7.80823V9.2566C220.289 9.52364 220.506 9.74024 220.773 9.74024L222.222 9.74024C222.49 9.74024 222.706 9.52364 222.706 9.2566V7.80823C222.706 7.54119 222.49 7.32471 222.222 7.32471L220.773 7.32471C220.506 7.32471 220.289 7.54119 220.289 7.80823Z' fill='url(%23paint21_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M230.614 7.80823V9.2566C230.614 9.52364 230.831 9.74024 231.098 9.74024H232.548C232.815 9.74024 233.032 9.52364 233.032 9.2566V7.80823C233.032 7.54119 232.815 7.32471 232.548 7.32471L231.098 7.32471C230.831 7.32471 230.614 7.54119 230.614 7.80823Z' fill='url(%23paint22_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M240.939 7.80823V9.2566C240.939 9.52364 241.156 9.74024 241.423 9.74024H242.873C243.14 9.74024 243.357 9.52364 243.357 9.2566V7.80823C243.357 7.54119 243.14 7.32471 242.873 7.32471L241.423 7.32471C241.156 7.32471 240.939 7.54119 240.939 7.80823Z' fill='url(%23paint23_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M251.508 7.80823V9.2566C251.508 9.52364 251.724 9.74024 251.992 9.74024H253.441C253.708 9.74024 253.925 9.52364 253.925 9.2566V7.80823C253.925 7.54119 253.708 7.32471 253.441 7.32471L251.992 7.32471C251.724 7.32471 251.508 7.54119 251.508 7.80823Z' fill='url(%23paint24_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M261.833 7.80823V9.2566C261.833 9.52364 262.049 9.74024 262.317 9.74024H263.766C264.033 9.74024 264.25 9.52364 264.25 9.2566V7.80823C264.25 7.54119 264.033 7.32471 263.766 7.32471L262.317 7.32471C262.049 7.32471 261.833 7.54119 261.833 7.80823Z' fill='url(%23paint25_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M272.158 7.80823V9.2566C272.158 9.52364 272.374 9.74024 272.642 9.74024H274.092C274.358 9.74024 274.576 9.52364 274.576 9.2566L274.576 7.80823C274.576 7.54119 274.358 7.32471 274.092 7.32471L272.642 7.32471C272.374 7.32471 272.158 7.54119 272.158 7.80823Z' fill='url(%23paint26_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M282.483 7.80823V9.2566C282.483 9.52364 282.7 9.74024 282.967 9.74024H284.417C284.684 9.74024 284.901 9.52364 284.901 9.2566V7.80823C284.901 7.54119 284.684 7.32471 284.417 7.32471L282.967 7.32471C282.7 7.32471 282.483 7.54119 282.483 7.80823Z' fill='url(%23paint27_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M292.809 7.80823L292.809 9.2566C292.809 9.52364 293.025 9.74024 293.292 9.74024H294.742C295.009 9.74024 295.226 9.52364 295.226 9.2566V7.80823C295.226 7.54119 295.009 7.32471 294.742 7.32471L293.292 7.32471C293.025 7.32471 292.809 7.54119 292.809 7.80823Z' fill='url(%23paint28_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M303.134 7.80823L303.134 9.2566C303.134 9.52364 303.35 9.74024 303.617 9.74024H305.067C305.334 9.74024 305.551 9.52364 305.551 9.2566V7.80823C305.551 7.54119 305.334 7.32471 305.067 7.32471L303.617 7.32471C303.35 7.32471 303.134 7.54119 303.134 7.80823Z' fill='url(%23paint29_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M313.702 7.80823L313.702 9.2566C313.702 9.52364 313.918 9.74024 314.185 9.74024L315.635 9.74024C315.902 9.74024 316.119 9.52364 316.119 9.25659V7.80823C316.119 7.54119 315.902 7.32471 315.635 7.32471L314.185 7.32471C313.918 7.32471 313.702 7.54119 313.702 7.80823Z' fill='url(%23paint30_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M324.027 7.80823V9.25659C324.027 9.52364 324.243 9.74024 324.511 9.74024L325.961 9.74024C326.227 9.74024 326.445 9.52364 326.445 9.25659V7.80823C326.445 7.54119 326.227 7.32471 325.961 7.32471L324.511 7.32471C324.243 7.32471 324.027 7.54119 324.027 7.80823Z' fill='url(%23paint31_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M334.352 7.80823V9.25659C334.352 9.52364 334.569 9.74024 334.836 9.74024H336.286C336.553 9.74024 336.77 9.52364 336.77 9.25659L336.77 7.80823C336.77 7.54119 336.553 7.32471 336.286 7.32471L334.836 7.32471C334.569 7.32471 334.352 7.54119 334.352 7.80823Z' fill='url(%23paint32_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M344.678 7.80823V9.25659C344.678 9.52364 344.894 9.74024 345.161 9.74024H346.611C346.878 9.74024 347.095 9.52364 347.095 9.25659L347.095 7.80823C347.095 7.54119 346.878 7.32471 346.611 7.32471L345.161 7.32471C344.894 7.32471 344.678 7.54119 344.678 7.80823Z' fill='url(%23paint33_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M355.003 7.80823V9.25659C355.003 9.52364 355.219 9.74024 355.486 9.74024H356.936C357.203 9.74024 357.42 9.52364 357.42 9.25659L357.42 7.80823C357.42 7.54119 357.203 7.32471 356.936 7.32471L355.486 7.32471C355.219 7.32471 355.003 7.54119 355.003 7.80823Z' fill='url(%23paint34_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M365.328 7.80823V9.25659C365.328 9.52363 365.544 9.74024 365.811 9.74024H367.261C367.528 9.74024 367.745 9.52363 367.745 9.25659V7.80823C367.745 7.54119 367.528 7.32471 367.261 7.32471L365.811 7.32471C365.544 7.32471 365.328 7.54119 365.328 7.80823Z' fill='url(%23paint35_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M375.896 7.80823V9.25659C375.896 9.52363 376.112 9.74023 376.38 9.74023H377.83C378.096 9.74023 378.313 9.52363 378.313 9.25659V7.80823C378.313 7.54119 378.096 7.32471 377.829 7.32471L376.38 7.32471C376.112 7.32471 375.896 7.54119 375.896 7.80823Z' fill='url(%23paint36_linear_8295_70635)'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M386.221 7.80823V9.25659C386.221 9.52363 386.438 9.74023 386.705 9.74023H388.155C388.421 9.74023 388.639 9.52363 388.639 9.25659V7.80823C388.639 7.54119 388.421 7.32471 388.155 7.32471L386.705 7.32471C386.438 7.32471 386.221 7.54119 386.221 7.80823Z' fill='url(%23paint37_linear_8295_70635)'/%3E%3Cdefs%3E%3ClinearGradient id='paint0_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint1_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint2_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint3_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint4_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint5_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint6_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint7_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint8_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint9_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint10_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint11_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint12_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint13_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint14_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint15_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint16_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint17_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint18_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint19_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint20_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint21_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint22_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint23_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint24_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint25_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint26_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint27_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint28_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint29_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint30_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint31_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint32_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint33_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint34_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint35_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint36_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3ClinearGradient id='paint37_linear_8295_70635' x1='-47.5' y1='8.99989' x2='332' y2='8.99989' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%2329B5E8' stop-opacity='.8'/%3E%3Cstop offset='1' stop-color='%2329B5E8' stop-opacity='0'/%3E%3C/linearGradient%3E%3C/defs%3E%3C/svg%3E%0A\")}.sc-hero__inner\u003E.snowflake-flexible-column-container-items\u003Ediv:first-child{position:relative;z-index:3}.sc-hero__inner\u003E.snowflake-flexible-column-container-items\u003Ediv:last-child{position:absolute;height:100%;width:100%;top:0;left:-24px}.sc-hero__inner\u003E.snowflake-flexible-column-container-items\u003Ediv:last-child::before{content:\"\";display:block;z-index:1;position:absolute;top:-64px;left:0;width:150%;height:calc(100% + 160px);background-color:rgb(32 44 53 / .9)}.sc-body__content .heading-3-v2,.sc-hero__headline .heading-1-v2{text-transform:none}.sc-body__content span.snowflake-image-caption{display:block!important;font-style:italic}.sc-body__content .snowflake-text p+ul{margin-top:24px!important;padding-left:16px!important}.white-blue-text-color .snowflake-title-v2.solution-center-hero__certification .snowflake-typographyv2\u003Espan.snowflake-title-v2-line{color:#e9eaeb!important;font-size:16px}.white-blue-text-color .snowflake-title-v2.solution-center-hero__certification.is-large .snowflake-typographyv2\u003Espan.snowflake-title-v2-line{color:#fff!important;font-size:18px}.solution-center-hero__certification\u003E.snowflake-title-v2-line\u003Espan:first-child{display:flex;justify-content:flex-start;align-items:center;gap:8px}.solution-center-hero__certification\u003E.snowflake-title-v2-line\u003Espan:first-child::before{content:\"\";display:inline-block;width:16px;height:16px;background-image:url(\"data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8 0C3.58146 0 0 3.58146 0 8C0 12.4185 3.58146 16 8 16C12.4185 16 16 12.4185 16 8C16 3.58146 12.4185 0 8 0ZM12.7184 5.91984L7.33471 11.3026C7.31293 11.3244 7.31293 11.3454 7.29198 11.3454L7.20653 11.4308C6.94933 11.688 6.54132 11.7525 6.21962 11.6235C6.11238 11.5808 6.00514 11.5163 5.9197 11.4308L5.83425 11.3454C5.83425 11.3454 5.83425 11.3236 5.81246 11.3236L3.28149 8.79347C2.93799 8.44997 2.93799 7.87107 3.28149 7.50664L3.36694 7.42119C3.71044 7.07769 4.28934 7.07769 4.65377 7.42119L6.58401 9.35143L11.3877 4.5477C11.7312 4.2042 12.3101 4.2042 12.6746 4.5477L12.76 4.63315C13.0826 4.99758 13.0828 5.55541 12.7184 5.91984Z' fill='%230E8A16'/%3E%3C/svg%3E%0A\");background-size:contain;background-repeat:no-repeat;background-color:#fff;border-radius:100%}.sc-hero__byline{padding-top:8px}.sc-hero__byline p{color:#e2e2e2;margin-top:0!important}.sc-hero pre[class*=language-]{overflow:visible}.snowflake-code-snippet,.snowflake-code-snippet code,.snowflake-code-snippet pre{font-size:16px}.sc-hero__code-snippet:not(pre)\u003Ecode[class*=language-],.sc-hero__code-snippet pre[class*=language-]{background:0 0}.sc-hero__code-snippet{opacity:.8;background-color:transparent!important;position:absolute;top:0;right:0;width:100%;animation:240s linear 1s forwards slow-scroll}.sc-hero__button-container .snowflake-flexible-column-container-items{padding:0 0 24px;margin-top:-8px;margin-left:24px}.sc-sidebar__partner-logo{width:100%;max-width:140px;margin-top:8px}.sc-sidebar__partner-logo .cmp-image__image{border-radius:0}.sc-tag-cluster.snowflake-text ul{list-style-type:none;padding:0;display:flex;flex-wrap:wrap;gap:8px;margin:0}.sc-tag-cluster.snowflake-text li{color:#373f41;border-radius:4px;display:inline-block;padding:6px;text-transform:uppercase;letter-spacing:1px;font-size:12px!important;line-height:12px!important;margin:0!important;background-color:#f3f3f3}.sc-body .share-icon svg{height:24px;cursor:pointer}.sc-body .share-icon svg:hover path{fill:var(--ui-02)}.sc-overview__webinar-promo-banner{align-items:center;border:1px solid #ccc;padding:var(--spacing-02)}.sc-overview__webinar-promo-banner .snowflake-content-chip-image{max-width:32px;margin-right:var(--spacing-02);line-height:0}.sc-overview__webinar-promo-banner .snowflake-content-chip-image__image,.summit-speaker-card .snowflake-card-v2-advanced-image__image{aspect-ratio:1}.sc-overview__webinar-promo-banner .snowflake-content-chip-content .heading-5-v2{font-size:14px;font-family:Lato,sans-serif}.sc-overview__webinar-promo-banner .snowflake-content-chip-content .snowflake-title-v2-line:not(:first-child){font-weight:400}.sc-overview__webinar-promo-banner .snowflake-content-chip-button .snowflake-button-container{font-size:14px!important}.diagram-group__button{position:absolute;bottom:24px;right:24px;background-color:#212c35!important}.section--mountains-bottom,.summit-hp-hero{position:relative}.sc-cert-banner{background-color:#212d35;border-radius:8px;padding:24px;overflow:hidden}.sc-cert-banner\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-direction:row;align-items:center}:root{--text-secondary:#706f6f;--summit-bg-ltblue:#eaf8fd;--summit-bg-blue:#249edc;--summit-border:#d2d1d4;--summit-border-radius:8px;--summit-card-padding:32px;--summit-card-padding-sm:28px}.section--mountains-bottom::after,.section--mountains-bottom::before{content:\"\";display:block;position:absolute;bottom:-1px;max-width:400px;background-size:100% auto;height:100%;width:30%;line-height:0;background-repeat:no-repeat}.button-group\u003E.container\u003E.cmp-container\u003E.aem-container{justify-content:center;align-items:center}.button-group\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:auto!important;margin:0 8px!important}.button-group .snowflake-button-container{font-family:Texta,sans-serif}.section--summit-bg-ltblue{background-color:var(--summit-bg-ltblue)}.section--summit-bg-blue,.summit-hero-secondary{background-color:var(--summit-bg-blue)}.section--mountains-bottom::before{left:0;background-image:url(\"data:image/svg+xml,%3Csvg width='402' height='309' viewBox='0 0 402 309' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M401.523 308.761H0V0L181.63 182.431L228.479 135.531L401.523 308.761Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\");background-position:bottom left}.section--mountains-bottom::after{right:0;background-image:url(\"data:image/svg+xml,%3Csvg width='402' height='309' viewBox='0 0 402 309' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 308.761H401.523V0L219.893 182.431L173.044 135.531L0 308.761Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\");background-position:bottom right}.summit-hp-hero{overflow:hidden}.summit-hero__bg-video{position:absolute;top:50%;left:50%;width:120%;height:100%;opacity:.3;transform:translate(-50%,-50%)}.summit-hero__bg-svg,.summit-prefooter__bg-image,.summit-secondary-hero__bg-image{position:absolute;bottom:0;left:0;width:100%}.summit-hp-promo-banner__headline .heading-4-v2{font-weight:900}.summit-hero-secondary .hero-lottie__left{position:absolute;bottom:0;left:0;width:30%;line-height:0}.summit-timeline__card::after,.summit-timeline__card::before{bottom:0;left:50%;position:absolute;display:block;background-color:var(--ui-01);content:\"\"}.summit-hero-secondary .snowflake-text p{font-size:24px!important;line-height:32px!important;max-width:720px;margin:0 auto}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;justify-content:center}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:auto!important;max-width:25%}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:not(:last-child){border-right:1px solid #fff}.summit-timeline__card{border:1px solid var(--summit-border);border-radius:var(--summit-border-radius);padding:var(--summit-card-padding);position:relative;background-color:#fff}.summit-timeline__card::before{width:20px;height:20px;border-radius:100%;transform:translate(-50%,50%)}.summit-timeline__card::after{width:3px;height:50px;transform:translate(-50%,100%)}.summit-timeline-card__icon{width:48px;height:48px}.summit-timeline-card__headline .heading-3-v2{font-size:32px}.faq-group{border:1px solid var(--ui-12);border-radius:4px;background-color:#fff}.faq-group__question{padding:24px}.faq-group__question:hover{color:var(--ui-01);cursor:pointer}.faq-group__question .heading-4-v2,.faq-group__question .heading-5-v2{position:relative;padding-right:64px}.faq-group__question .heading-4-v2::after,.faq-group__question .heading-5-v2::after{content:\"\";display:block;width:32px;height:32px;background-image:url(\"data:image/svg+xml,%3Csvg width='29' height='16' viewBox='0 0 29 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M14.16 14.6807C14.2537 14.7957 14.3719 14.8884 14.506 14.952C14.64 15.0157 14.7866 15.0487 14.935 15.0487C15.0834 15.0487 15.2299 15.0157 15.3639 14.952C15.498 14.8884 15.6162 14.7957 15.71 14.6807V14.6807L28.51 2.00068C29.07 1.43068 29.07 .92068 28.51 .44068C27.95 -.0393204 27.43 -.11932 26.96 .44068L14.94 12.0007L2.99996 .45068C2.90725 .322624 2.7855 .218374 2.6447 .146483C2.50389 .0745926 2.34805 .0371094 2.18996 .0371094C2.03187 .0371094 1.87603 .0745926 1.73522 .146483C1.59442 .218374 1.47267 .322624 1.37996 .45068C.819961 .93068 .819961 1.45068 1.37996 2.01068L14.16 14.6807Z' fill='black'/%3E%3C/svg%3E%0A\");background-size:80% auto;background-repeat:no-repeat;background-position:center;position:absolute;top:-2px;right:0;transition:.3s 150ms}.faq-group__question .heading-5-v2::after{top:-4px}.faq-group__answer{max-height:0;overflow:hidden;width:95%;padding:0 24px;transition:.5s}.faq-group__answer\u003Espan{display:block;padding-bottom:24px}.is-open .faq-group__answer{max-height:600px;transition:1s}.is-open .faq-group__question .heading-4-v2::after,.is-open .faq-group__question .heading-5-v2::after{transform:rotate(180deg);transition:.3s}.summit-agenda{box-shadow:2px 4px 10px 0 rgb(156 156 156 / .52);border-radius:8px;background-color:#fff;max-width:980px;margin-left:auto;margin-right:auto;padding:40px;width:90%}.agenda-item{border-radius:8px;background-color:#d4f0fa;padding:16px;border-left:4px solid var(--ui-01);position:relative}.summit-pricing-block__tile.is-past,.summit-pricing-block__tile.is-upcoming{pointer-events:none;border-color:#d2d1d4}p.agenda-item__time{width:25%;font-family:Texta!important;font-size:32px!important;font-weight:900!important;text-transform:uppercase!important;max-width:140px}@media screen and (max-width:991px){#partnerResources .section--resource-hub .snowflake-button-link .snowflake-button-container{font-size:14px!important;line-height:20px!important;margin-top:4px}#industryPartnerSlider\u003E.snowflake-flexible-column-container-items{display:flex;flex-direction:column}#industryPartnerSlider\u003E.snowflake-flexible-column-container-items\u003Ediv{width:100%}.sc-cert-banner__left{text-align:center}.sc-cert-banner__left .solution-center-hero__certification .snowflake-title-v2-line{justify-content:center}.summit-hero__bg-video{width:200%}.summit-leadership-grid .snowflake-flexible-column-container-items{grid-template-columns:repeat(2,1fr)}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:50%!important;max-width:50%!important}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:not(:last-child){border-right:none!important}.summit-agenda{padding:24px}p.agenda-item__time{font-size:24px!important;width:auto;white-space:nowrap;padding-right:24px}}.agenda-item\u003Espan{display:flex;align-items:center}.summit-add-on-block,.summit-pricing-block{border:1px solid #d2d1d4;border-radius:8px;overflow:hidden;box-shadow:2px 4px 10px 0 rgb(156 156 156 / .52);background-color:#fff}.summit-add-on-block__content,.summit-pricing-block__content{padding:0 20px 20px}.summit-pricing-block__tile{padding:24px 20px;border-radius:4px;background:#fff;border:1px solid var(--ui-01);position:relative;transition:background-color .3s}.summit-pricing-block__tile:hover{background-color:var(--ui-01);transition:background-color .3s}.summit-pricing-block__tile.is-past{background-color:#d4f0fa}.summit-pricing-block__tile:hover .black-blue-text-color .snowflake-title-v2-line{color:#fff!important;transition:color .3s}.partner-card__logo-grid\u003E.container\u003E.cmp-container\u003E.aem-container::after,.partner-card__logo-grid\u003E.container\u003E.cmp-container\u003E.aem-container::before,.summit-add-on-block__content\u003E.container\u003E.cmp-container\u003E.aem-container::after,.summit-add-on-block__content\u003E.container\u003E.cmp-container\u003E.aem-container::before,.summit-pricing-block__tile.is-past .snowflake-content-chip-button,.summit-pricing-block__tile.is-upcoming .snowflake-content-chip-button,.summit-speaker-card .snowflake-card-v2-advanced-tag-indicator{display:none}.summit-pricing-block__tile.is-past .black-blue-text-color .snowflake-title-v2-line{color:#7cc7eb!important}.summit-pricing-block__tile.is-upcoming .black-blue-text-color .snowflake-title-v2-line{color:#8c8c8c!important}.summit-pricing-block__aside{background-color:#d4f0fa;border:1px solid #d2d1d4;border-radius:8px;padding:24px;width:100%}.summit-pricing-block__aside li::marker{color:var(--ui-01)}.summit-pricing-block__aside-headline .heading-5-v2{font-weight:900;margin-bottom:12px}.summit-pricing-block__header{background:#000;padding:24px 40px}.summit-pricing-block__header .heading-4-v2{font-weight:900;letter-spacing:.5px}.bwwidth100,.snowflake-mega-nav-dropdown-footer-content,.summit-pricing-block__tile .black-blue-text-color{width:100%}.summit-pricing-block__tile .heading-5-v2{position:static}.summit-pricing-block__tile .heading-5-v2 span.snowflake-title-v2-line:first-child{text-transform:uppercase;font-weight:900!important;letter-spacing:.25px;font-size:24px!important}.summit-pricing-block__tile .heading-5-v2 span.snowflake-title-v2-line:nth-child(2){margin-top:8px;font-family:Lato,sans-serif;font-size:14px;font-style:normal;font-weight:400;line-height:16px}.summit-pricing-block__tile .heading-5-v2 span.snowflake-title-v2-line:last-child{font-weight:900!important;font-size:40px!important}.snowflake-mega-nav-nav-item\u003Ea:hover .snowflake-mega-nav-nav-item-title-wrapper\u003E.snowflake-mega-nav-nav-item-title,.summit-pricing-block__tile:not(.is-upcoming):not(.is-past) .heading-5-v2 span.snowflake-title-v2-line:last-child{color:var(--ui-01)!important}.summit-pricing-block__tile:hover:not(.is-upcoming):not(.is-past) .heading-5-v2 span.snowflake-title-v2-line:last-child{color:#fff!important}.summit-pricing-block__tile.is-past .heading-5-v2 span.snowflake-title-v2-line:last-child{text-decoration:line-through}.summit-pricing-block__tile .snowflake-content-chip-button{margin-top:0;white-space:nowrap;display:none}.snowflake-card-v2-advanced.no-link{pointer-events:none!important}.snowpro-card{border:1px solid var(--summit-border);border-radius:var(--summit-border-radius);padding:var(--summit-card-padding-sm);display:flex;height:100%}.snowpro-card__headline{margin:24px 0 12px}.snowpro-card__pricing{margin-top:48px}.snowpro-card .snowflake-text .snowpro-card__price{color:var(--ui-01);font-weight:900;font-size:40px!important;font-family:Texta,sans-serif}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-direction:row;flex-wrap:wrap}.summit-stat-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:not(:last-child){border-right:1px solid var(--summit-border)}.summit-stat-card{padding:0 40px}.summit-stat .heading-2-v2 .snowflake-title-v2-line:first-child{font-size:64px;line-height:52px;margin-bottom:8px}.summit-stat .heading-2-v2 .snowflake-title-v2-line:last-child{font-size:32px;line-height:30px;margin-bottom:16px}.summit-speaker-card .snowflake-card-v2-advanced-title{margin-bottom:var(--spacing-01)}.summit-add-on-card{padding:24px;border:1px solid #d2d1d4;border-radius:8px}.summit-add-on__subhead{padding-left:40px;padding-right:40px}.partner-card__logo-grid,.partner-card__logo-single{padding:40px}.partner-card__logo-grid .snowflake-image-container .cmp-image__image,.partner-card__logo-single .snowflake-image-container .cmp-image__image{border-radius:0;max-width:240px;margin:0 auto}.partner-card\u003E.container,.partner-card\u003E.container\u003E.aem-container,.partner-card\u003E.container\u003E.cmp-container{height:100%}.summit-add-on-block__content\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-direction:row;gap:24px;align-items:stretch}.partner-card__logo-grid\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-direction:row;flex-wrap:wrap;gap:40px 24px;justify-content:center;align-items:center}.partner-card__logo-grid\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(33.3333% - 24px);margin:0!important}.partner-card{border-radius:8px;border:1px solid #d2d1d4;overflow:hidden;height:100%;background-color:#fff}.partner-card__header{padding:16px 24px;border-bottom:1px solid #d2d1d4}.partner-card__header.is-purple{background-color:#7d44cf}.partner-card__header h4{display:flex;flex-direction:row!important;align-items:center;gap:12px}.partner-card__header h4::before{vertical-align:middle;content:\"\";display:inline-block;width:20px;height:20px;background-size:contain;background-repeat:no-repeat;background-image:url(\"data:image/svg+xml,%3Csvg width='21' height='23' viewBox='0 0 21 23' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M20.0375 12.8374C20.1644 12.439 20.2172 12.0289 20.2077 11.6237C20.193 11.3305 20.1548 11.0373 20.0712 10.7441C19.8196 9.83306 19.223 9.01989 18.3294 8.50724L5.61817 1.2017C3.82388 .173815 1.53618 .784335 .506483 2.56804C-.533615 4.34915 .0797871 6.62351 1.87408 7.65398L8.97715 11.7427L1.87408 15.8201C.0797871 16.8527 -.531016 19.1271 .506483 20.9156C1.53618 22.6941 3.82388 23.302 5.61817 22.2746L18.3294 14.9643C19.1871 14.4728 19.7693 13.7027 20.0375 12.8374Z' fill='black'/%3E%3C/svg%3E%0A\")}.partner-card__header.is-purple h4::before{background-image:url(\"data:image/svg+xml,%3Csvg width='21' height='23' viewBox='0 0 21 23' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M20.0375 12.8374C20.1644 12.439 20.2172 12.0289 20.2077 11.6237C20.193 11.3305 20.1548 11.0373 20.0712 10.7441C19.8196 9.83306 19.223 9.01989 18.3294 8.50724L5.61817 1.2017C3.82388 .173815 1.53618 .784335 .506483 2.56804C-.533615 4.34915 .0797871 6.62351 1.87408 7.65398L8.97715 11.7427L1.87408 15.8201C.0797871 16.8527 -.531016 19.1271 .506483 20.9156C1.53618 22.6941 3.82388 23.302 5.61817 22.2746L18.3294 14.9643C19.1871 14.4728 19.7693 13.7027 20.0375 12.8374Z' fill='white'/%3E%3C/svg%3E%0A\")}.sf-blue-mountains{background-size:90% auto;background-repeat:no-repeat;background-position:center bottom;background-image:url(\"data:image/svg+xml,%3Csvg width='1361' height='410' viewBox='0 0 1361 410' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1360.25 410L1065.53 114.309L976.256 203.875L773.049 0L364.393 410H1360.25Z' fill='%233AA8DF'/%3E%3Cpath d='M274.778 410L137.467 272.238L.15625 410H274.778Z' fill='%233AA8DF'/%3E%3C/svg%3E%0A\")}.bwalignr,.main-pr-body .bwalignr{text-align:right}.bwblockalignl{margin-left:0;margin-right:auto}.bwcellpmargin{margin-top:0;margin-bottom:0}.bwlistdisc{list-style-type:disc}.bwpadb3{padding-bottom:4px}.bwpadb4{padding-bottom:5px}.bwpadl0{padding-left:0}.bwpadl3{padding-left:15px}.bwpadl6{padding-left:30px}.bwpadl9{padding-left:45px}.bwpadl12{padding-left:60px}.bwpadr0{padding-right:0}.bwtablemarginb{margin-bottom:10px}.bwvertalignb{vertical-align:bottom}.bwvertalignt{vertical-align:top}.bwsinglebottom{border-bottom:1pt solid #000}.bwdoublebottom{border-bottom:2.25pt double #000}.bwwidth1{width:1%}.bwwidth2{width:2%}.bwwidth6{width:6%}.bwwidth7{width:7%}.bwwidth8{width:8%}.bwwidth10{width:10%}.bwwidth12{width:12%}.bwwidth32{width:32%}.bwwidth44{width:44%}.bwwidth72{width:72%}.bwwidth97{width:97%}.main-pr-body{font-size:18px;line-height:26px}.main-pr-body img{display:block;width:100%;height:auto!important;border-radius:var(--small-border-radius)}.main-pr-body table{width:100%;display:block}.main-pr-body tbody{background-color:#f7f7f7}.main-pr-body .bwsinglebottom{border-bottom:1pt solid #000!important}.main-pr-body td.bwwidth44{padding-right:40px}.main-pr-body .bw-release-story{font-family:Lato,sans-serif}.main-pr-body .bw-release-story sup,.snowflake-mega-nav-dropdown-header-content-right a{white-space:nowrap}.main-pr-body .bw-release-story\u003E*,.main-pr-body\u003Espan\u003E*{margin-bottom:2rem!important}.snowflake-text.main-pr-body tbody,.snowflake-text.main-pr-body tbody p{font-size:14px!important;line-height:20px!important;width:100%;display:block}.press-body .snowflake-flexible-column-container-items{gap:var(--spacing-08)}.about-snowflake{border:1px solid #ccc;background-color:var(--ui-background-05);padding:24px;border-radius:8px;margin-top:0}.about-snowflake__logo{max-width:140px;margin-top:16px}.hero--press .snowflake-hero-system-inner{max-width:1408px;margin:0 auto!important}#arcticNavItem{flex-direction:column}#arcticNavItem::before{content:\"Featured Open Source Technologies\";display:block;margin-top:48px;margin-bottom:24px;font-size:16px!important;line-height:16px!important;font-weight:800!important;text-transform:uppercase}@media screen and (min-width:768px){.sc-hero__inner\u003E.snowflake-flexible-column-container-items\u003Ediv:last-child{position:relative;height:100%;top:auto;left:auto;width:auto}.sc-hero__inner\u003E.snowflake-flexible-column-container-items\u003Ediv:last-child::before{background:linear-gradient(180deg,#202c35 -7.5%,#fff0 51.25%,#202c35 107.69%)}.sc-hero__byline\u003Espan{display:flex;flex-wrap:wrap}.sc-hero__byline p:not(:last-child)::after{content:\"|\";margin:0 12px;opacity:.5}.sc-hero__button-container .snowflake-flexible-column-container-items{position:absolute;bottom:0;padding:0;margin:0 24px 0 0}.sc-hero__button-container .hero-watch-the-demo{padding:12px 16px!important;float:right;margin-bottom:48px;background-color:rgb(35 45 54 / .8)}.summit-overview-stat{padding:0 40px}.summit-timeline{border-bottom:3px solid var(--ui-01);margin-bottom:64px}.summit-add-on-block__content,.summit-pricing-block__content{padding:0 40px 40px}#arcticNavItem::before{font-size:12px!important;margin-bottom:8px;margin-top:16px}.snowflake-mega-nav-nav-item-title-wrapper\u003E.snowflake-mega-nav-nav-item-title{line-height:20px!important}.snowflake-card .heading-2.snowflake-title-line{font-size:24px!important;line-height:28px!important}}@media screen and (min-width:992px){.hp-hero__eyebrow a{gap:12px;margin-left:0;margin-right:0}.hp-hero__eyebrow a::after{content:\"\";background-image:url(\"data:image/svg+xml,%3Csvg width='6' height='11' viewBox='0 0 6 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M5.49134 5.79438C5.53447 5.75922 5.56923 5.71489 5.5931 5.66463C5.61697 5.61436 5.62935 5.55941 5.62935 5.50376C5.62935 5.44811 5.61697 5.39316 5.5931 5.34289C5.56923 5.29263 5.53447 5.2483 5.49134 5.21314L.736339 .413136C.522589 .203135 .331339 .203135 .151339 .413136C-.0286612 .623135 -.0586612 .818135 .151339 .994386L4.48634 5.50188L.155089 9.97938C.107068 10.0142 .0679743 10.0598 .0410153 10.1126C.0140562 10.1654 0 10.2238 0 10.2831C0 10.3424 .0140562 10.4009 .0410153 10.4537C.0679743 10.5065 .107068 10.5521 .155089 10.5869C.335089 10.7969 .530089 10.7969 .740089 10.5869L5.49134 5.79438Z' fill='black'/%3E%3C/svg%3E%0A\");display:inline-block;width:12px;height:12px;background-repeat:no-repeat;background-size:auto 100%;background-position:left center}.promo-banner--homepage{padding-top:32px}.homepage-banner-offset-container::after{height:50%}#storyHighlights{padding:2rem}.body-display-v2.snowflake-quote-item-quote-text{line-height:28px!important}.snowflake-hero-system-headline .heading-1-v2{line-height:48px;font-size:54px!important}.sc-overview__webinar-promo-banner .snowflake-content-chip-content{flex-direction:row;justify-content:space-between;align-items:center;width:100%}.sc-overview__webinar-promo-banner .snowflake-content-chip-content .heading-5-v2{flex-direction:row}.sc-overview__webinar-promo-banner .snowflake-content-chip-content .snowflake-title-v2-line:not(:first-child)::before{content:\"|\";margin:0 6px}.sc-cert-banner{padding:40px}.sc-cert-banner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{margin:0!important;width:50%}.sc-cert-banner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{flex-grow:1;padding-right:24px}.sc-cert-banner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:last-child{max-width:240px}.summit-pricing-block__content\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:last-child{width:70%;padding-left:40px}.summit-pricing-block__content\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{width:30%}.summit-add-on-block__content\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(33.3333% - 24px);margin:0!important;display:flex}.summit-pricing-block__tile .snowflake-content-chip-content{display:flex;flex-direction:row;align-items:center;width:calc(100% - 200px)}.summit-pricing-block__tile .heading-5-v2 span.snowflake-title-v2-line:last-child{position:absolute;top:50%;transform:translate(0,-50%);right:40px}.press-body\u003E.snowflake-flexible-column-container-items\u003Ediv:last-child{position:sticky;top:120px}.snowflake-mega-nav-navigation-title:hover{color:var(--ui-01)}}@media screen and (min-width:1024px){.about-snowflake{padding:28px}.about-snowflake__logo{max-width:none;padding:0 0 0 48px;margin-bottom:0}.hero--press .snowflake-hero-system-layout-70-30 .snowflake-hero-system-content-container{width:85%}.snowflake-hero-system{padding-bottom:var(--spacing-04);padding-top:var(--spacing-07)}.hero--press .display-2-v2{font-size:64px;line-height:56px}.about-snowflake\u003E.container\u003E.cmp-container\u003E.aem-container{flex-direction:row;flex-wrap:nowrap;align-items:center}.about-snowflake\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:last-child{max-width:280px}.about-snowflake\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{flex-grow:1;margin-bottom:0!important}#polarisNavItem{margin-top:40px}.snowflake-mega-nav-nav-item-description{line-height:18px!important}.snowflake-mega-nav-column-items{gap:var(--spacing-01);grid-gap:var(--spacing-01)}.snowflake-mega-nav-navigation-title{text-transform:none}}div[id*=blueIcon] .snowflake-mega-nav-nav-item-icon__inner{background:var(--ui-01);padding:8px}div[id*=blueIcon]:hover .snowflake-mega-nav-nav-item-icon__inner{background:var(--ui-01)!important}.snowflake-mega-nav-nav-item-icon__inner{border-radius:4px;background:var(--ui-background-05);padding:6px}.snowflake-mega-nav-nav-item:hover .snowflake-mega-nav-nav-item-icon__inner{background:#fff!important}.snowflake-mega-nav-nav-item-icon.snowflake-image-container{height:40px;width:40px}.snowflake-mega-nav-dropdown-footer-links\u003E.snowflake-button-link\u003E.snowflake-button-container{font-size:16px!important;font-family:Texta!important;font-weight:800!important}.snowflake-mega-nav-dropdown-footer-icon.snowflake-image-container{margin-right:8px;width:40px!important;height:40px!important}#viewAllCapabilities a:hover{background:0 0!important}#platformFooter .snowflake-title-v2 .snowflake-title-v2-line:last-child{font-family:Lato;font-size:14px;font-weight:500}#platformFooter .snowflake-mega-nav-dropdown-footer-links{flex-grow:1;justify-content:flex-end;align-items:center}#platformFooter .snowflake-mega-nav-dropdown-footer-content{flex-direction:row}#offset,#open-source{flex-direction:column;border-top:1px solid #ccc}#offset::before,#open-source::before{content:\" \";display:block;width:100%;font-weight:800!important;font-size:12px!important;line-height:14px;text-transform:uppercase;white-space:nowrap;margin-top:16px;margin-bottom:8px}#open-source::before{content:\"Open Source Technologies\"}.snowflake-mega-nav-dropdown-menu-close-button{margin:var(--spacing-04) 0 var(--spacing-03)}.snowflake-mega-nav-column{gap:var(--spacing-02)!important}.snowflake-mega-nav-nav-item\u003Ea{width:100%;margin-left:-8px;padding:8px;border-radius:4px}.snowflake-mega-nav-nav-item\u003Ea:hover{background-color:var(--ui-background-05)}.snowflake-mega-nav-nav-item-description{margin-top:2px;display:block}#promobanner_overflowBottomDarkBlue::before{content:'';display:block;position:absolute;bottom:0;left:0;width:100%;height:50%;background:#212d35}#promobanner_overflowTopDarkBlue::before{content:'';display:block;position:absolute;top:0;left:0;width:100%;height:50%;background:#212d35}.overview-card\u003Ediv{box-shadow:0 0 14px 0 rgba(0,0,0,.10);background-color:#fff;border-radius:16px;overflow:hidden}.overview-card-text{padding:40px}.overview-card-image img{border-radius:0 !important}.overview-card-text h3,.overview-card-text .heading-3-v2{font-size:18px;line-height:1.1;margin-top:0}",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false},"mega_header":{"additionalClasses":"heap-nav-header","id":"container-2508f3f908","layout":"SIMPLE",":type":"snowflake-site/components/mega-header",":items":{"nav_mega":{"activeItem":"item_1719963657751_c_663444255","id":"tabs-7326a669ba",":type":"snowflake-site/components/nav/nav-mega",":items":{"item_1719963657751_c_663444255":{"id":"nav-dropdown-menu-f3d469a698","enableDropdown":true,"nav_column_container":{"id":"container-c0c7633fed","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column":{"additionalClasses":"nav-platform-sidebar","numberOfSubColumns":"one-column","minWidth":"230","maxWidth":"350","id":"container-75227c6d00","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_copy_2_793631646":{"id":"nav-item-2cc7081b19","additionalClasses":"nav-item__platform-parent is-platform","linkDescription":"Develop AI products, apps and more on a fully managed platform that securely connects businesses globally — across any type or scale of data.","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/platform/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"The Snowflake Platform"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-be70f82520","additionalClasses":"nav-item nav-item--si is-si","linkDescription":"All your knowledge. One trusted enterprise agent.","flag":"NOW GA","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/snowflake-cowork/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake CoWork"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy_2_836345186":{"id":"nav-item-310d8ef3e1","additionalClasses":"blue-icon is-analytics","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/analytics/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Analytics"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy_2":{"id":"nav-item-dce2cc407d","additionalClasses":"blue-icon is-ai","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/ai/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"AI"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy_2_1314771042":{"id":"nav-item-da2f14988e","additionalClasses":"blue-icon is-data-eng","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/data-engineering/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Data Engineering"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_144634":{"id":"nav-item-5b2928e389","additionalClasses":"blue-icon is-apps-collab","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/applications-and-collaboration/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Applications & Collaboration"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_144634_2013333117":{"id":"nav-item-6eed61de1a","additionalClasses":"blue-icon is-transactions","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/transactions/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Transactions"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_copy_2_793631646","nav_item","nav_item_copy_copy_2_836345186","nav_item_copy_copy_2","nav_item_copy_copy_2_1314771042","nav_item_copy_144634","nav_item_copy_144634_2013333117"]},"nav_column_copy_copy":{"additionalClasses":"meganav-platform-features","navColumnTitle":"Featured Capabilities","numberOfSubColumns":"one-column","id":"container-b0a828220c","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_212715":{"id":"nav-item-62e67cd549","additionalClasses":"is-cortex-code","linkDescription":"Snowflake-native AI coding agent ","flag":"New","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/snowflake-coco/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake CoCo"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-07a192d057","additionalClasses":"is-cortex-ai","linkDescription":"Instant access to industry-leading LLMs","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/cortex/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Cortex AI"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590635":{"id":"nav-item-86e7b7da8c","additionalClasses":"is-marketplace","linkDescription":"Third-party data sources connected within minutes","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/marketplace/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Marketplace"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590":{"id":"nav-item-876e598ed6","additionalClasses":"is-snowpark","linkDescription":"Libraries and code execution environments that run Python and more","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/snowpark/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Snowpark"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590_983061516":{"id":"nav-item-27937771dc","additionalClasses":"is-streamlit","linkDescription":"Framework for transforming Python scripts into web apps","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/streamlit-in-snowflake/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Streamlit"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_212715","nav_item","nav_item_copy_660590635","nav_item_copy_660590","nav_item_copy_660590_983061516"]},"nav_column_692142673":{"navColumnTitle":" ","numberOfSubColumns":"one-column","id":"container-58940403b3","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_660590_1739526127":{"id":"nav-item-34b6fe25ac","additionalClasses":"is-postgres","linkDescription":"Fully compatible open source Postgres running on Snowflake","flag":"Now GA","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/features/postgres/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Postgres"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_185565":{"id":"nav-item-1283015f98","additionalClasses":"is-dcr","linkDescription":"Streamlined model development and MLOps from a centralized UI","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/features/end-to-end-ml-workflows/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake ML"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_212715":{"id":"nav-item-250aa45159","additionalClasses":"is-openflow","linkDescription":"Effortless data movement for integrations","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/openflow/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Openflow"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590":{"id":"nav-item-23d1b4f1ae","additionalClasses":"is-notebooks","linkDescription":"Interactive dev environment for data and AI teams","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/notebooks/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Notebooks"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_258535199":{"id":"nav-item-56ea90d7b0","propertiesId":"workload-nav-1","additionalClasses":"is-native-apps","linkDescription":"End-to-end, Snowflake-native app creation and distribution","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/product/features/native-apps/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Native Apps"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_660590_1739526127","nav_item_copy_185565","nav_item_copy_212715","nav_item_copy_660590","nav_item_258535199"]},"nav_column_782221091":{"navColumnTitle":" ","numberOfSubColumns":"one-column","id":"container-c02a94b953","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy":{"id":"nav-item-04e69b7657","additionalClasses":"is-light-gray-icon is-horizon-catalog","linkDescription":"Universal AI catalog","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/features/horizon/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Horizon Catalog"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590_1293798742":{"id":"nav-item-4e1fc677b1","additionalClasses":"is-snowflake-ml","linkDescription":"Governed context layer that keeps AI, BI and data apps working from one truth","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/features/horizon-context/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Horizon Context"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_511717659_c":{"id":"nav-item-ad760f73ba","additionalClasses":"is-unistore","linkDescription":"Unify transactional and analytical workloads in Snowflake for enhanced simplicity","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/features/unistore/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Unistore"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_511717659_c_1443811525":{"id":"nav-item-bdb1f3707f","additionalClasses":"is-observe","linkDescription":"AI-powered observability for faster production troubleshooting","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/observe/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Observe"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_511717659_c_1006104884":{"id":"nav-item-462c961dea","additionalClasses":"is-observe","linkDescription":"Use any engine on a single governed data copy","flag":"Now GA","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/use-cases/interoperable-lakehouse/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Interoperable Lakehouse"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy","nav_item_copy_660590_1293798742","nav_item_511717659_c","nav_item_511717659_c_1443811525","nav_item_511717659_c_1006104884"]}},":itemsOrder":["nav_column","nav_column_copy_copy","nav_column_692142673","nav_column_782221091"]},":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Product"},"nav_dropdown_menu_2":{"id":"nav-dropdown-menu-7c2bc6040a","enableDropdown":true,"nav_column_container":{"id":"container-9158529c4d","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column":{"navColumnTitle":"INDUSTRIES","numberOfSubColumns":"one-column","minWidth":"280","id":"container-cdccff3e67","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_361384_2056203141":{"id":"nav-item-bfcd9e3338","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"All Industries"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-f628b471d6","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/advertising-media-entertainment/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Advertising, Media & Entertainment"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-04d7475d6e","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/financial-services/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Financial Services"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1970515619":{"id":"nav-item-0f56852dcc","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/healthcare-and-life-sciences/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Healthcare & Life Sciences"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1533429516":{"id":"nav-item-fd6ddbdbfb","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/manufacturing/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Manufacturing"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1444458226":{"id":"nav-item-c1cb0ad58c","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/public-sector/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Public Sector"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1149488919":{"id":"nav-item-fa08b29d4e","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/retail-consumer-goods/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Retail & Consumer Goods"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_57417040":{"id":"nav-item-581f6e5675","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/technology/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Technology"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_361384674":{"id":"nav-item-38bf657811","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/telecom/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Telecom"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_361384":{"id":"nav-item-14cd706299","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/travel-hospitality/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Travel & Hospitality"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_361384_2056203141","nav_item","nav_item_copy","nav_item_copy_1970515619","nav_item_copy_1533429516","nav_item_copy_1444458226","nav_item_copy_1149488919","nav_item_copy_57417040","nav_item_copy_361384674","nav_item_copy_361384"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-extra-small"},"nav_column_copy":{"navColumnTitle":"DEPARTMENTS","numberOfSubColumns":"one-column","minWidth":"160","id":"container-b842dc5ee9","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-325a87e37a","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/solutions/departments/finance/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Finance"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-42cd1daf64","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/solutions/departments/information-technology/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"IT"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1970515619":{"id":"nav-item-205a9b04fd","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/solutions/departments/marketing/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Marketing"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_copy","nav_item_copy_1970515619"]},"nav_column_833417450":{"navColumnTitle":"Enablement Solutions","numberOfSubColumns":"one-column","id":"container-87ba6b8f7d","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_107772":{"id":"nav-item-a57e8aa243","linkDescription":"Confident migration to a unified platform","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/migrate-to-the-cloud/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Migrate to the AI Data Cloud"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/nav_dropdown_menu_2/nav_column_container/nav_column_833417450/nav_item_copy_107772/icon.coreimg.svg/1723828484100/nav-icon-cloud.svg","alt":"Cloud icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy":{"id":"nav-item-f0e2304d27","linkDescription":"Snowflake experts to help you accelerate and achieve business goals","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/services-delivery/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Services Delivery"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/nav_dropdown_menu_2/nav_column_container/nav_column_833417450/nav_item_copy_copy/icon.coreimg.svg/1768354429188/nav-icon--migrate.svg","alt":"Migrate icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_107772","nav_item_copy_copy"]},"nav_column_copy_copy":{"navColumnTitle":"PARTNER SOLUTIONS","numberOfSubColumns":"one-column","id":"container-d32c13dee5","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-100d0ab018","linkDescription":"Programs with product, solutions and cloud partners","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/partners/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake Partner Network"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/nav_dropdown_menu_2/nav_column_container/nav_column_copy_copy/nav_item/icon.coreimg.svg/1723828498700/nav-icon--partner-network.svg","alt":"Partner Network icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-8a7b658825","linkDescription":"Partners, apps and solutions for enhanced deployment","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/partners/all-partners/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Partner Finder"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/nav_dropdown_menu_2/nav_column_container/nav_column_copy_copy/nav_item_copy/icon.coreimg.svg/1726173927645/nav-icon--partner-finder.svg","alt":"Partner Finder icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1970515619":{"id":"nav-item-89f2a0306d","linkDescription":"Live and virtual events","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/partners/event-partnership-opportunities/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Event Partnership Opportunities"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/nav_dropdown_menu_2/nav_column_container/nav_column_copy_copy/nav_item_copy_1970515619/icon.coreimg.svg/1726173935655/nav-icon--events.svg","alt":"Calendar icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_copy","nav_item_copy_1970515619"]}},":itemsOrder":["nav_column","nav_column_copy","nav_column_833417450","nav_column_copy_copy"]},":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Solutions"},"item_1719963657751_c":{"id":"nav-dropdown-menu-c2fe961c01","enableDropdown":true,"nav_column_container":{"id":"container-e940c38f5b","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column":{"numberOfSubColumns":"one-column","minWidth":"230","maxWidth":"350","id":"container-2ecaa23142","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_copy_2_793631646":{"id":"nav-item-1ac342db2f","additionalClasses":"nav-item__platform-parent-why-sf","linkDescription":"Collaborate locally and globally to reveal new insights, create previously unforeseen business opportunities, and identify your customers with seamless experiences.","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Why Snowflake"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy_copy_2_793631646"]},"nav_column_copy_copy":{"additionalClasses":"meganav-platform-features","numberOfSubColumns":"two-columns","maxWidth":"1200","id":"container-9af7886ad1","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-a194f07f59","propertiesId":"testID","linkDescription":"Case studies and videos showcasing how global organizations use Snowflake","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/customers/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Customers"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751_c/nav_column_container/nav_column_copy_copy/nav_item/icon.coreimg.svg/1739839279367/nav-icon--partner-network.svg","alt":"Customer icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_258535199":{"id":"nav-item-4f05288479","propertiesId":"workload-nav-1","linkDescription":"Learn how to connect, share and integrate the data and apps on the AI Data Cloud","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/what-is-data-cloud/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"The AI Data Cloud Explained"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751_c/nav_column_container/nav_column_copy_copy/nav_item_258535199/icon.coreimg.svg/1739840490955/nav-icon-cloud.svg","alt":"Cloud icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_185565":{"id":"nav-item-c76a4bb542","linkDescription":"Comprehensive security through built-in features, robust cloud infrastructure protection, and more","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/snowflake-security-hub/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Security Hub"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751_c/nav_column_container/nav_column_copy_copy/nav_item_copy_185565/icon.coreimg.svg/1758909528089/user-security-admins-ciso-icon.svg","alt":"User with security lock icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-0ae5a8007f","additionalClasses":"is-light-gray-icon","linkDescription":"Maximize economic value through minimizing TCO and continuously optimizing price for performance","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/pricing-options/cost-and-performance-optimization/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Cost and Performance Optimization"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751_c/nav_column_container/nav_column_copy_copy/nav_item_copy/icon.coreimg.svg/1758909542267/nav-icon-cost-optimization-performance.svg","alt":"Cost Optimization icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_185565_903555964":{"id":"nav-item-218389631b","linkDescription":"Startups building applications in the AI Data Cloud","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/startup-program/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake for Startups"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751_c/nav_column_container/nav_column_copy_copy/nav_item_copy_185565_903555964/icon.coreimg.svg/1758732224323/launch.svg","alt":"Launch","lazyEnabled":true,"width":"65",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_258535199","nav_item_copy_185565","nav_item_copy","nav_item_copy_185565_903555964"]}},":itemsOrder":["nav_column","nav_column_copy_copy"]},":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Why Snowflake"},"item_1719961362824":{"id":"nav-dropdown-menu-2e0634c469","enableDropdown":true,"nav_column_container":{"id":"container-e19275c248","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column_copy":{"navColumnTitle":"Connect","numberOfSubColumns":"one-column","minWidth":"124","id":"container-610b583ce1","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-ddeed1d3f4","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/blog/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Blog"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_180298689":{"id":"nav-item-a3b2194bee","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/events/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Events"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_1639361946":{"id":"nav-item-fe46eab97b","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/support/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Support"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_680912746":{"id":"nav-item-5601e82a3f","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/contact/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Contact us"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_180298689","nav_item_1639361946","nav_item_680912746"]},"nav_column_44600420__826130542":{"navColumnTitle":"Learn","numberOfSubColumns":"two-columns","id":"container-e148b5f03d","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy":{"id":"nav-item-d3d6a3432e","linkDescription":"Ebooks, videos, white papers and more","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/resources/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Resource Library"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy/icon.coreimg.svg/1736877128196/nav-icon--notebooks.svg","alt":"Notebooks icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-77c53d99a7","linkDescription":"Overview of Snowflake's educational offerings","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/resources/learn/training/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Training"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item/icon.coreimg.svg/1722385094416/nav-icon--training.svg","alt":"Training icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_144634_1984107859":{"id":"nav-item-5604bfd8bf","linkDescription":"Expert-led discussions and demos across industries and use cases","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/webinars/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Webinars"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_144634_1984107859/icon.coreimg.svg/1759424691990/nav-icon--webinars.svg","alt":"Webinars icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1438098918":{"id":"nav-item-b405c9047b","linkDescription":"Snowflake's technical industry professional certifications","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/resources/learn/certifications/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Certifications"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_1438098918/icon.coreimg.svg/1722382780833/nav-icon--cert.svg","alt":"Certification icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_143809":{"id":"nav-item-e2f70a2fdb","linkDescription":"Weekly product demos showcasing key features and live Q&A ","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/webinars/demo/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Live Demos"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_143809/icon.coreimg.svg/1759424359543/nav-icon--live-demo.svg","alt":"Live Demo icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890638":{"id":"nav-item-b8ef14d6cd","linkDescription":"Training courses for all levels, on-demand or instructor-led","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://learn.snowflake.com/en/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Snowflake University"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_333890638/icon.coreimg.svg/1722382769808/nav-icon--education.svg","alt":"Education icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_189945":{"id":"nav-item-817b9cdb12","linkDescription":"Instructor-led virtual workshops for exploring key Snowflake features","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/webinars/virtual-hands-on-lab/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Hands-On Labs"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_189945/icon.coreimg.svg/1759388182903/nav-icon--labs.svg","alt":"Hands-on Labs icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890":{"id":"nav-item-2e61042548","linkDescription":"Academic papers written by Snowflake researchers","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/resources/publications/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake Research Publications"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_333890/icon.coreimg.svg/1756326371387/copy.svg","alt":"Copy","lazyEnabled":true,"width":"65",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890_930852828":{"id":"nav-item-e12a385c2a","linkDescription":"Informative articles about AI and data topics","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/fundamentals/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Fundamentals"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719961362824/nav_column_container/nav_column_44600420__826130542/nav_item_copy_333890_930852828/icon.coreimg.svg/1756853637155/data-sheet.svg","alt":"Document with list","lazyEnabled":true,"width":"65",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item_copy","nav_item","nav_item_copy_144634_1984107859","nav_item_copy_1438098918","nav_item_copy_143809","nav_item_copy_333890638","nav_item_copy_189945","nav_item_copy_333890","nav_item_copy_333890_930852828"]}},":itemsOrder":["nav_column_copy","nav_column_44600420__826130542"]},"nav_promo_section":{"id":"nav-promo-section-c24a781bac","experience_fragment_1":{"id":"experiencefragment-2be1cad921","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/master1/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-0204b0d36f","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-c1edbf612e","openInNewWindow":true,"layout":"horizontal","headline":"Dev Day Virtual - June 25","description":"Don’t just hear about AI — build it. Luminary talks and hands-on labs","linkTitle":"Learn more","linkUrl":"/en/dev-day/americas-virtual/","image":{"id":"image","height":"540","src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--de231e36-6645-4550-abd9-0f8de758ac66/web-dev-day-26-960x540-1x.png?quality=85&preferwebp=true","alt":"dev day","lazyEnabled":true,"width":"960",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-promo-card"}},":itemsOrder":["nav_promo_card"]},"cq:metadata":{":type":"nt:unstructured"}},":itemsOrder":["root","cq:metadata"],"classNames":"aem-xf"},"experience_fragment_2":{"id":"experiencefragment-d3805f9711","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/navigation-promo-card-2/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-1820ef666f","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-39532a2b30","openInNewWindow":true,"layout":"horizontal","headline":"The ROI of Gen AI and Agents 2026","description":"Discover how 92% of early adopters are achieving positive ROI with gen AI.","linkTitle":"Learn More","linkUrl":"/en/lp/radical-roi-generative-ai/","image":{"id":"image","height":"540","src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--0c15edae-1a97-4739-8b16-c7f3941a6d9e/web-roi-of-gen-ai-and-agents-2026-r02-960x540.png?quality=85&preferwebp=true","alt":"roi of gen ai and agents","lazyEnabled":true,"width":"960",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-promo-card"}},":itemsOrder":["nav_promo_card"]},"cq:metadata":{":type":"nt:unstructured"}},":itemsOrder":["root","cq:metadata"],"classNames":"aem-xf"},"experience_fragment_3":{"id":"experiencefragment-092c690648","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/navigation-promo-card-3/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-7846d5d325","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-c5e2889524","openInNewWindow":true,"layout":"horizontal","headline":"Startup 2026: AI Agents Mean Business","description":"Venture leaders weigh in on agentic AI. ","linkTitle":"Learn more","linkUrl":"/en/lp/building-startup-ai-age/","image":{"id":"image","height":"540","src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--a320b404-dca1-4477-b033-c79708538657/web-startup-2026-960x540.png?quality=85&preferwebp=true","alt":"alt","lazyEnabled":true,"width":"960",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-promo-card"}},":itemsOrder":["nav_promo_card"]},"cq:metadata":{":type":"nt:unstructured"}},":itemsOrder":["root","cq:metadata"],"classNames":"aem-xf"},":type":"snowflake-site/components/nav/nav-promo-section"},":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Resources"},"item_1719963657751":{"id":"nav-dropdown-menu-37d722850e","enableDropdown":true,"nav_column_container":{"id":"container-55e19ba897","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column_copy_copy":{"navColumnTitle":"Build","numberOfSubColumns":"one-column","id":"container-3927bbc9a6","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-02082f5f78","propertiesId":"testID","linkDescription":"Overview of the dev resources you need to build and scale","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/developers/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Snowflake for Developers"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy/nav_item/icon.coreimg.svg/1731362494574/nav-icon--devs.svg","alt":"Developers icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1855651246":{"id":"nav-item-fa6b74d077","linkDescription":"Reference architectures, use cases and best practices","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/developers/guides/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Developer Guides"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy/nav_item_copy_1855651246/icon.coreimg.svg/1761677891705/nav-icon--solution-center.svg","alt":"Solution Center icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-41214fe936","additionalClasses":"is-light-gray-icon","linkDescription":"The latest software versions, drivers, libraries and relevant docs","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/developers/downloads/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Downloads"},"icon":{"id":"icon","height":"28","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy/nav_item_copy/icon.coreimg.svg/1731362660050/nav-icon-download.svg","alt":"Download icon","lazyEnabled":true,"width":"28",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_copy_1855651246","nav_item_copy"]},"nav_column_copy_copy_1367930678":{"navColumnTitle":"Learn","numberOfSubColumns":"one-column","id":"container-b489878c15","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-31a2982994","propertiesId":"testID","linkDescription":"Reference docs, guides, tutorials and announcements","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://docs.snowflake.com/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Documentation"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy_1367930678/nav_item/icon.coreimg.svg/1731361950527/nav-icon--docs.svg","alt":"Docs icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-a1f9009a93","additionalClasses":"is-light-gray-icon","linkDescription":"Key projects Snowflake engineers maintain and support","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/developers/open-source/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Open Source"},"icon":{"id":"icon","height":"32","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy_1367930678/nav_item_copy/icon.coreimg.svg/1731365437016/nav-icon-open-source.svg","alt":"Open Source icon","lazyEnabled":true,"width":"32",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy":{"id":"nav-item-0dd1d9b9b7","additionalClasses":"is-light-gray-icon","linkDescription":"Online and in-person classes and workshops to upskill on Snowflake","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/developers/northstar/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_INTERNAL","text":"Builder Education"},"icon":{"id":"icon","height":"32","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy_1367930678/nav_item_copy_copy/icon.coreimg.svg/1731362475640/nav-icon--northstar.svg","alt":"Northstar logo","lazyEnabled":true,"width":"32",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_copy","nav_item_copy_copy"]},"nav_column_copy_copy_1101894776":{"navColumnTitle":"Connect","numberOfSubColumns":"one-column","id":"container-91568c018c","layout":"SIMPLE",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-97372575cd","propertiesId":"testID","linkDescription":"Snowflake’s technical leaders on what, why and how they build features","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/engineering-blog/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Engineering Blog"},"icon":{"id":"icon","height":"32","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy_1101894776/nav_item/icon.coreimg.svg/1757101368571/nav-icon--developer-center.svg","alt":"Developers icon","lazyEnabled":true,"width":"32",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1855651246":{"id":"nav-item-dabe464d54","linkDescription":"Tips, tricks and discussion with fellow Snowflake developers","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://community.snowflake.com/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Community"},"icon":{"id":"icon","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/mega-nav-header/master/_jcr_content/root/mega_header/nav_mega/item_1719963657751/nav_column_container/nav_column_copy_copy_1101894776/nav_item_copy_1855651246/icon.coreimg.svg/1731362644348/nav-icon--partner-network.svg","alt":"Partner Network icon","lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"}},":itemsOrder":["nav_item","nav_item_copy_1855651246"]}},":itemsOrder":["nav_column_copy_copy","nav_column_copy_copy_1367930678","nav_column_copy_copy_1101894776"]},"nav_promo_section":{"id":"nav-promo-section-735285e5d3","experience_fragment_1":{"id":"experiencefragment-25e4386d0f","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/nav-promo-5/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-d51f4122a3","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-790656e898","openInNewWindow":false,"layout":"horizontal","headline":"Get started with your first Snowflake Notebook","description":"Write and execute code, visualize results, and tell the story of your analysis all in one place.","linkTitle":"Learn More","linkUrl":"/en/developers/solutions-center/getting-started-with-your-first-snowflake-notebook-project/","image":{"id":"image","height":"210","src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--dc7e334a-c38b-4283-b1de-fcf829952eef/nav-promo-first-notebook.jpg?quality=85&preferwebp=true","alt":"alt","lazyEnabled":true,"width":"415",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-promo-card"}},":itemsOrder":["nav_promo_card"]},"cq:LiveSyncConfig":{"cq:isDeep":true,"cq:rolloutConfigs":[],"cq:master":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/nav-promo-card-4",":type":"cq:LiveCopy"}},":itemsOrder":["root","cq:LiveSyncConfig"],"classNames":"aem-xf"},"experience_fragment_2":{"id":"experiencefragment-f23beef1ba","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/nav-promo-card-4/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"nav_promo_card":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-8b23d79bd1","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-2560169b92","openInNewWindow":true,"layout":"horizontal","headline":"Northstar Builder Workshops","description":"Join other developers as you roll up your sleeves and explore the possibilities of Snowflake.","linkTitle":"Learn More","linkUrl":"/en/nav-promos/northstar-builders-workshop/","image":{"id":"image","height":"700","src":"https://www.snowflake.com/adobe/dynamicmedia/deliver/dm-aid--14341ced-bc5e-4a29-9762-b7857f6cadfc/nav-promo-northstar.jpg?quality=85&preferwebp=true","alt":"Snowflake Northstar logo","lazyEnabled":true,"width":"1440",":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-promo-card"}},":itemsOrder":["nav_promo_card"]},"cq:LiveSyncConfig":{"cq:isDeep":true,"cq:rolloutConfigs":[],"cq:master":"/content/experience-fragments/snowflake-site/language-masters/en/site/nav-promo-card/master",":type":"cq:LiveCopy"}},":itemsOrder":["root","cq:LiveSyncConfig"],"classNames":"aem-xf"},":type":"snowflake-site/components/nav/nav-promo-section"},":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Developers"},"item_1718247180324":{"id":"nav-dropdown-menu-74e1955b38","enableDropdown":false,"link_url":"/en/pricing-options/",":type":"snowflake-site/components/nav/nav-dropdown-menu","cq:panelTitle":"Pricing"}},":itemsOrder":["item_1719963657751_c_663444255","nav_dropdown_menu_2","item_1719963657751_c","item_1719961362824","item_1719963657751","item_1718247180324"]},"languagenavigation":{"id":"language-navigation-dec98bab2c","languageNavItems":[{"title":"English","path":"/en/developers/guides/streamsets-transformer-for-snowflake-hol/","locale":"en","active":true},{"title":"日本語","path":"/ja/","locale":"ja","active":false},{"title":"한국어","path":"/ko/","locale":"ko","active":false},{"title":"中文（简体）","path":"/zh_cn/","locale":"zh-cn","active":false},{"title":"Português","path":"/pt_br/","locale":"pt-br","active":false},{"title":"Deutsch","path":"/de/","locale":"de","active":false},{"title":"Français","path":"/fr/","locale":"fr","active":false},{"title":"Español","path":"/es/","locale":"es","active":false},{"title":"Italiano","path":"/it/","locale":"it","active":false}],":type":"snowflake-site/components/nav/language-navigation"},"button_1177328691":{"id":"button-5a44793842","heapButtonClasses":["mega-nav__sign-in"],"showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://app.snowflake.com/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","appliedCssClassNames":"snowflake-button-link snowflake-button-black snowflake-button-compact","linkType":"SNOWFLAKE_EXTERNAL","text":"Sign in"},"button":{"id":"button-3768bc092b","heapButtonClasses":["contact_nav","heap-nav-contact"],"showOutboundIcon":true,"buttonLink":{"valid":true,"url":"/en/contact-sales/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","appliedCssClassNames":"snowflake-button-secondary snowflake-button-blue snowflake-button-compact","linkType":"SNOWFLAKE_INTERNAL","text":"CONTACT SALES"},"button_288358396":{"id":"button-97f6464724","heapButtonClasses":["start_for_free_nav","heap-nav-start-for-free"],"showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://signup.snowflake.com/"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","appliedCssClassNames":"snowflake-button-primary snowflake-button-blue snowflake-button-compact","linkType":"SNOWFLAKE_EXTERNAL","text":"start for free"}},":itemsOrder":["nav_mega","languagenavigation","button_1177328691","button","button_288358396"],"appliedCssClassNames":"snowflake-header-container white"}},":itemsOrder":["markup_editor","mega_header"]},"image":{":type":"nt:unstructured"},"cq:targetMetadata":{"cq:targetStatus":"OUT_OF_SYNC","cq:exportTime":1781280015540,"cq:targetOfferId":860250,":type":"nt:unstructured"}},":itemsOrder":["root","image","cq:targetMetadata"],"classNames":"aem-xf"},"markup_editor_1950346551":{"id":"markup-editor-0809f60553","title":" ","cssContent":".snowflake-markdown-table code[class*=language-],.snowflake-markdown-table code[class*=language-],.snowflake-markdown .snowflake-text code[class*=language-],.snowflake-markdown .snowflake-text pre[class*=language-]{background-color:rgba(var(--ui-12-rgb),.5);color:var(--text-01);text-shadow:none;padding:var(--spacing-00);border-radius:var(--spacing-00);font-size:smaller}",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false},"responsivegrid":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"quickstart_hero":"aem-GridColumn aem-GridColumn--default--12","flexible_column_cont":"aem-GridColumn aem-GridColumn--default--12","markup_editor":"aem-GridColumn aem-GridColumn--default--12"},"columnCount":12,":items":{"quickstart_hero":{"id":"quickstart-hero-338a0e033a","fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/streamsets-transformer-for-snowflake-hol",":type":"snowflake-site/components/quickstart/quickstart-hero","isDeveloperGuidesPage":false,"quickstartHeroFirstCertifiedTag":{"tagText":"Quickstart","tagColor":"#29B5E8","tagPath":"/content/cq:tags/snowflake-site/taxonomy/solution-center/certification/quickstart","tagIcon":""},"quickstartHeroBreadcrumbs":[{"title":"StreamSets' Transformer for Snowflake: Hands on Lab","url":"https://www.snowflake.com/content/snowflake-site/global/en/developers/guides/streamsets-transformer-for-snowflake-hol","currentPage":true},{"title":"Guides","url":"https://www.snowflake.com/content/snowflake-site/global/en/developers/guides","currentPage":false},{"title":"Snowflake for Developers","url":"https://www.snowflake.com/content/snowflake-site/global/en/developers","currentPage":false}],"quickstartHeroTitle":{"lines":["StreamSets' Transformer for Snowflake: Hands on Lab"],"type":"heading2",":type":"snowflake-site/components/title-v2"},"quickstartHeroAuthor":"Kate Guttridge, StreamSets","quickstartHeroForkRepoLink":{"id":"button-f1ed32a572","showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://github.com/Snowflake-Labs/sfquickstarts/tree/master/site/sfguides/src/streamsets-transformer-for-snowflake-hol"},"linkTargetContentType":"GENERIC",":type":"snowflake-site/components/button","linkType":"SNOWFLAKE_EXTERNAL","text":"Fork Repo"}},"flexible_column_cont":{"id":"flexible-column-container-d780326e28","propertiesId":"quickstart-template-main-flexible-container","type":"2-column-75-25","alignColumns":"top","containerMaxWidth":"extra-large","topPadding":"none","bottomPadding":"none","spaceBetween":"small","reverseOnMobile":false,"carouselOnMobile":false,"backgroundImageOption":"none","flexible_column_content_container_1":{"id":"container-b4a576fc79","layout":"SIMPLE",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"contentfragment":{"id":"contentfragment-dee61a35a5","paragraphs":["&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EOverview\u003C/h2\u003E\n","\u003Cp\u003EStreamSets is a data integration platform for the modern data ecosystem, empowering data engineers to build, run, monitor, and manage smart data pipelines in one place. \u003Cstrong\u003ETransformer for Snowflake\u003C/strong\u003E is a fully hosted service embedded within the StreamSets DataOps Platform. It uses the Snowpark Client Libraries to generate SnowSQL queries that are executed natively in Snowflake, allowing your data to remain in your Snowflake Data Cloud.\u003C/p\u003E\n","\u003Cp\u003ETransformer for Snowflake is just one part of the StreamSets DataOps Platform, which consists of:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003EControl Hub\u003C/strong\u003E - to manage and monitor smart data pipelines at scale, providing real time visibility into operations.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EData Collector\u003C/strong\u003E -  designed for streaming, CDC and batch ingest.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ETransformer\u003C/strong\u003E - a family of engines to do heavy duty transformation ETL, ELT and ML work, executing natively on modern data platforms such as Snowflake and Spark.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EData Collector and Transformer (for Spark) engines can be deployed on-premises (VM or containers), in a customer&rsquo;s VPC, and/or in the customer&rsquo;s namespace in a public cloud. The engines, and therefore the data accessed by the engines, remains in the customer&rsquo;s environments across all of their on-prem, hybrid, &amp; multi-cloud environments.\u003C/p\u003E\n","\u003Cp\u003EThis lab shows you how to get started using \u003Cstrong\u003ETransformer for Snowflake\u003C/strong\u003E as a part of the DataOps Platform. You can read more about pipelines in Transformer for Snowflake \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/GettingStarted/WhatIsSnowflake.html#concept_srx_qxm_4rb\"\u003Ehere\u003C/a\u003E.\u003C/p\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EPrerequisites\u003C/strong\u003E\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003EA trial \u003Ca href=\"https://trial.snowflake.com/?owner=SPN-PID-26749\"\u003ESnowflake\u003C/a\u003E account with \u003Ccode\u003EACCOUNTADMIN\u003C/code\u003E privileges.\n\u003Cul\u003E\u003Cli\u003EIt is recommended to create a new trial account for this lab, using an email address that is not tied to an existing a StreamSets organization.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E[optional] \u003Ca href=\"https://github.com/streamsets/Pipeline-Examples/blob/359a57b4e5f486ba5c094a3380e4a618662a1657/tx4snowflake_hol/SNOWFLAKE_WORKSHEET.sql\"\u003EDownload\u003C/a\u003E the sql used in this lab \u003Ca href=\"https://github.com/streamsets/Pipeline-Examples/blob/359a57b4e5f486ba5c094a3380e4a618662a1657/tx4snowflake_hol/SNOWFLAKE_WORKSHEET.sql\"\u003Ehere\u003C/a\u003E. Individual SQL statements are provided to copy/paste throughout the lab.\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EWhat You&rsquo;ll Learn\u003C/strong\u003E\u003C/h3\u003E\n","\u003Cp\u003EYou will learn how to build pipelines using Transformer for Snowflake that are executed natively in your Snowflake Data Cloud, including:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EHow to use Partner Connect to create a StreamSets Organization.\u003C/li\u003E\u003Cli\u003EHow to create pipelines that dynamically generate your SQL queries at pipeline runtime.\u003C/li\u003E\u003Cli\u003EHow to leverage User Defined Functions within your pipelines.\u003C/li\u003E\u003Cli\u003EHow to use Fragments to share logic across multiple pipelines.\u003C/li\u003E\u003Cli\u003EHow to create and run Jobs to control pipeline execution.\u003C/li\u003E\u003Cli\u003EHow to use the Slowly Changing Dimension processor.\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EWhat You&rsquo;ll Build\u003C/strong\u003E\u003C/h3\u003E\n","\u003Cp\u003EThe lab uses the \u003Cstrong\u003ETPCH_SF1\u003C/strong\u003E dataset pre-populated in your Snowflake account to transform raw retail data into consumable orders information that can support business analytics, including:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EA pipeline that renames columns, joins data, performs calculations, resuses portions of existing pipelines, and reshapes the data to populate multiple tables with raw data, summary data, and pivoted data.\u003C/li\u003E\u003Cli\u003EA pipeline to process a Slowly Changing Dimension.\u003C/li\u003E\u003C/ul\u003E\n&lt;!-- You can import the final products to compare against [placeholder for pipeline export(s)](https://github.com/streamsets/Pipeline-Examples/blob/fb4240adc106ba5fd14a680b6eb82ab8b2c27555/tx4snowflake_hol/). --&gt;\n","\u003Ch2\u003E\u003Cstrong\u003ETransformer for Snowflake\u003C/strong\u003E\u003C/h2\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EWhat does it do?\u003C/strong\u003E\u003C/h3\u003E\n","\u003Cp\u003ETransformer for Snowflake accelerates the development of data pipelines by going beyond the construction of basic SQL with a drag and drop UI. Snowpark enables StreamSets to construct the SnowSQL queries at the pipeline runtime, allowing pipeline definitions to be more flexible than static SnowSQL queries. StreamSets also provides processors that combine the logic for common use cases into a single element to drop on your canvas.\u003C/p\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EHow does it work?\u003C/strong\u003E\u003C/h3\u003E\n","\u003Cp\u003ETransformer for Snowflake is a hosted service embedded within the StreamSets DataOps Platform. It uses the Snowpark Client Libraries to generate SnowSQL queries that are executed in Snowflake. How does that happen?\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EYou build pipelines in the StreamSets design canvas.\u003C/li\u003E\u003Cli\u003EUpon pipeilne execution, StreamSets builds a Directed Acyclic Graph\n(\u003Ca href=\"https://en.wikipedia.org/wiki/Directed_acyclic_graph\"\u003EDAG\u003C/a\u003E).\u003C/li\u003E\u003Cli\u003EStreamSets uses the DAG and the Snowpark Client Libraries to generate SnowSQL.\u003C/li\u003E\u003Cli\u003EStreamSets sends the SnowSQL to Snowflake.\u003C/li\u003E\u003Cli\u003ESnowflake executes the SnowSQL in the Warehouse of your choice.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/how_does_it_work.png\" alt=\"How_Does_It_Work\"\u003E\u003C/p\u003E\n","\u003Ch2\u003E\u003Cstrong\u003EGetting Started with Snowflake\u003C/strong\u003E\u003C/h2\u003E\n","\u003Ch3\u003E\u003Cstrong\u003ECreate Snowflake Trial Account\u003C/strong\u003E\u003C/h3\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003EIf you haven't already, create a Snowflake trial Account using this \u003Ca href=\"https://trial.snowflake.com/?owner=SPN-PID-26749\"\u003Elink\u003C/a\u003E.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EFill out the form and click \u003Cstrong\u003EContinue\u003C/strong\u003E.\u003C/li\u003E\u003Cli\u003EChoose a Snowflake edition, cloud provider, and region for that provider. For the purposes of this lab, any of the providers or editions are fine to select.\u003C/li\u003E\u003Cli\u003EAfter checking the box to agree to the terms, click \u003Cstrong\u003EGet Started\u003C/strong\u003E.\u003C/li\u003E\u003Cli\u003ECheck your email inbox for a message from Snowflake that contains the link to \u003Cstrong\u003EActivate\u003C/strong\u003E your trial. Click that link.\u003C/li\u003E\u003Cli\u003ESpecify your username and password, and be sure to save these somewhere secure.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EYou can find a detailed walk through of the Snowflake UI \u003Ca href=\"https://docs.snowflake.com/en/user-guide/ui-snowsight-gs.html#getting-started-with-snowsight\"\u003Ehere\u003C/a\u003E. This lab will use the Snowsight UI (new Snowflake UI) exclusively and all instructions for the following steps in Snowflake are for that UI. You can use the Classic UI, but the Snowflake resources will be located in different places.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EConfirm Existence of Sample Data\u003C/strong\u003E\u003C/h3\u003E\n\u003Col start=\"3\"\u003E\u003Cli\u003EThis lab utilizes the \u003Ccode\u003ESNOWFLAKE_SAMPLE_DATABASE\u003C/code\u003E that is included by default as a part of Snowflake accounts.\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003ESelect the \u003Cstrong\u003EWorksheet\u003C/strong\u003E tab on the left-hand menu, and then click the blue \u003Ccode\u003E+ Worksheet\u003C/code\u003E button in the top right of the screen.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_worksheet.png\" alt=\"Snowflake Worksheet\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EWith the new worksheet open:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EClick on the \u003Cstrong\u003EDatabases\u003C/strong\u003E tab on the left-hand menu.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EYou should see the \u003Cstrong\u003ESNOWFLAKE_SAMPLE_DATA\u003C/strong\u003E database in the list of objects.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_sample_database.png\" alt=\"Snowflake Sample DB\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EIf  \u003Cstrong\u003ESNOWFLAKE_SAMPLE_DATA\u003C/strong\u003E is present, proceed on to the next section, \u003Cstrong\u003EUse Partner Connect to Create a StreamSets Organization\u003C/strong\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003EIf \u003Cstrong\u003ESNOWFLAKE_SAMPLE_DATA\u003C/strong\u003E is not present:\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EYou may have removed it from your account. Run the following command in your worksheet to restore it:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E  CREATE OR REPLACE DATABASE SNOWFLAKE_SAMPLE_DATA \n    FROM SHARE SFC_SAMPLES.SAMPLE_DATA;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EYou should now see the database as one of the objects. Click on  \u003Cstrong\u003ESNOWFLAKE_SAMPLE_DATABASE\u003C/strong\u003E to reveal the schemas it contains, including \u003Ccode\u003ETPCH_SF1\u003C/code\u003E, which will be used in this lab. You can click on \u003Cstrong\u003ETPCH_SF1\u003C/strong\u003E and then \u003Cstrong\u003ETables\u003C/strong\u003E to see the included tables.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EIn your worksheet, run the following query:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E  CREATE  WAREHOUSE  IF NOT EXISTS TRIAL_WH; \n  USE WAREHOUSE TRIAL_WH;\n\n  SELECT *\n  FROM SNOWFLAKE_SAMPLE_DATA.TPCH_SF1.ORDERS\n  LIMIT 10;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ESnowflake requires a warehouse to execute most queries, which is why the SQL contains the command to create a warehouse (size \u003Ccode\u003EXSMALL\u003C/code\u003E by default). You can find out more about Snowflake warehouses in their \u003Ca href=\"https://docs.snowflake.com/en/user-guide/warehouses-overview.html\"\u003Edocumentation\u003C/a\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EIf the query returns results, you are ready to proceed! If not, check your query syntax to confirm it is correct.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ENow it's time to set up your StreamSets account!\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch2\u003E\u003Cstrong\u003EUse Partner Connect to Create a StreamSets Organization\u003C/strong\u003E\u003C/h2\u003E\n","\u003Cp\u003EWe&rsquo;ll use \u003Ca href=\"https://docs.snowflake.com/en/user-guide/ecosystem-partner-connect.html\"\u003ESnowflake Partner Connect\u003C/a\u003E to set up a StreamSets organization that will  auto-populate \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/GettingStarted/MyAccount.html#concept_d2k_yld_gsb\"\u003ESnowflake Credentials\u003C/a\u003E and \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/GettingStarted/MyAccount.html#concept_ofy_mld_gsb\"\u003ESnowflake Pipeline Default Settings\u003C/a\u003E so you can start building pipelines right away.\u003C/p\u003E\n","\u003Cp\u003ENote: All steps assume you are using the SnowSight UI.\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EAfter logging into your Snowflake Trial instance, look in the top left corner of the UI to confirm that your active role is \u003Cstrong\u003EACCOUNTADMIN\u003C/strong\u003E . If it is not:\n\u003Cul\u003E\u003Cli\u003Eselect the drop down next to your user name\u003C/li\u003E\u003Cli\u003Eclick on \u003Cstrong\u003ESwitch Role\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003Eselect \u003Cstrong\u003EACCOUNTADMIN\u003C/strong\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_set_role.png\" alt=\"Set your Role to AccountAdmin\"\u003E\u003C/p\u003E\n\u003Col start=\"2\"\u003E\u003Cli\u003EOn the left menu, expand the \u003Cstrong\u003EAdmin\u003C/strong\u003E section and select \u003Cstrong\u003EPartner Connect\u003C/strong\u003E.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/partner_connect_admin.png\" alt=\"Partner Connect\"\u003E\u003C/p\u003E\n\u003Col start=\"3\"\u003E\u003Cli\u003EEnter \u003Ccode\u003EStreamSets\u003C/code\u003E in the search bar and click on the StreamSets tile.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/partner_connect_search.png\" alt=\"Partner Connect TileSearch\"\u003E\u003C/p\u003E\n\u003Col start=\"4\"\u003E\u003Cli\u003EAfter selecting the StreamSets tile, the following window will appear.  It contains information about the Database, Warehouse, User, Password and Role that will be created in Snowflake. Select \u003Cstrong\u003EConnect\u003C/strong\u003E.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/partner_connect_grants.png\" alt=\"Partner Connect Grants\"\u003E\u003C/p\u003E\n\u003Col start=\"5\"\u003E\u003Cli\u003EA message will appear to indicate that the StreamSets account was created. Select \u003Cstrong\u003EActivate\u003C/strong\u003E.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/partner_connect_account_created.png\" alt=\"Activate Account\"\u003E\u003C/p\u003E\n\u003Col start=\"6\"\u003E\u003Cli\u003ENow you will be taken to StreamSets to finish setting up your StreamSets Organization. You can create a password for your Streamsets acccount or use Single Sign On through Google or Microsoft.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_create_password.png\" alt=\"Create User\"\u003E\u003C/p\u003E\n\u003Col start=\"7\"\u003E\u003Cli\u003EFinish creating your StreamSets organization by choosing the region that is closest to you and updating the name, if you prefer. The default name uses the same prefix as your Snowflake Trial instance. Check the boxes to agree to the Terms of Service and acknowledge the Privacy Policy. Click on \u003Cstrong\u003EAgree &amp; Continue\u003C/strong\u003E.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_org_name_and_location.png\" alt=\"Name Org and Choose Location\"\u003E\u003C/p\u003E\n\u003Col start=\"8\"\u003E\u003Cli\u003E\n","\u003Cp\u003EIf the updated privacy policy message appears, go ahead and dismiss it.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ENow the dialog should appear asking about ingesting data into Snowflake. We do not need to do that because we are going to use data already loaded in the Snowflake Sample Database. Select \u003Cstrong\u003ECreate Transformer for Snowflake Pipeline\u003C/strong\u003E to be taken to the Pipeline Design Canvas.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_create_first_pipeline.png\" alt=\"Create first pipeline\"\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003ECongratulations!\u003C/strong\u003E You now have your very own StreamSets Organization!\u003C/p\u003E\n","\u003Ch4\u003EIf you were not able to finish setting up your organization and navigated away, you can either:\u003C/h4\u003E\n\u003Cul\u003E\u003Cli\u003EGo back and select StreamSets' partner connect tile in Snowflake, then select \u003Cstrong\u003ELaunch\u003C/strong\u003E.\u003C/li\u003E\u003Cli\u003EUse the link that was sent to the email address for your Snowflake account. Be sure to check your Spam folder if you don&rsquo;t see it.\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch2\u003E\u003Cstrong\u003EOverview of the DataOps Platform UI\u003C/strong\u003E\u003C/h2\u003E\n","\u003Cp\u003EBefore we get started building a pipeline, let's look at how to navigate Control Hub, a web-based user interface (UI) for building, managing, and monitoring all of your pipelines. (Note: Control Hub displays timestamps using the browser time zone determined by your local operating system.)\u003C/p\u003E\n","\u003Cp\u003EThe Control Hub UI includes the following general areas and icons. You can find more details in the \u003Ca href=\"https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/GettingStarted/ControlHubUI_Next.html#concept_ywv_x3d_lpb\"\u003Edocumentation\u003C/a\u003E:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ControlHubUI.png\" alt=\"Control Hub UI\"\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003ENavigation panel\u003C/strong\u003E: lists the areas that you can manage within Control Hub. Displays one of the following views based on your selection in the navigation panel:\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ELearn\u003C/strong\u003E: access tutorial steps and videos to help you get started with StreamSets.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESet Up\u003C/strong\u003E: create and manage environments, deployments, engines, and connections (\u003Cem\u003ENot applicable to Transformer for Snowflake\u003C/em\u003E)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EBuild\u003C/strong\u003E: design and manage \u003Cstrong\u003Efragments\u003C/strong\u003E and \u003Cstrong\u003Epipelines\u003C/strong\u003E.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ERun\u003C/strong\u003E: create and manage job templates and instances, schedule tasks, and view draft runs.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EMonitor\u003C/strong\u003E: access the operations and topologies dashboards and much more.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EManage\u003C/strong\u003E: administer your organizatio,  create and manage users/groups, view audit entries to monitor logins and actions, and generate and manage credentials for use with the Control Hub REST API.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EView\u003C/strong\u003E: displays one of the areas listed above based on your selection in the navigation panel.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EGlobal search\u003C/strong\u003E: search for Control Hub objects by name, such as pipelines, fragments, and jobs.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EFilter\u003C/strong\u003E: filter the information displayed in the selected view.\u003C/li\u003E\u003C/ol\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/icon_ToggleNavigation.png\" alt=\"Toggle Nav\"\u003E Navigation panel icon - Toggles the display of the navigation panel.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/icon_MyAccount_Next.png\" alt=\"My Account\"\u003E My Account icon - Displays your account and browser settings. Allows you to invite other users to your organization or to sign out.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/icon_Help.png\" alt=\"help\"\u003E Help icon - Provides access to the online help and shows help tips. Also provides documentation for the Control Hub REST API.\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch2\u003E\u003Cstrong\u003ECreate and Run a Simple Pipeline\u003C/strong\u003E\u003C/h2\u003E\n","\u003Cp\u003EThe pipeline we build in this portion of the lab is based on the sample Sales data in the \u003Ccode\u003ESNOWFLAKE_SAMPLE_DATA\u003C/code\u003E database. It contains tables with Orders and Order Line Items. We would like to be able to report from one table with a combination of the data from both tables. We are going to step through the pipeline build, noting some of the StreamSets features that make pipeline and development easier.\u003C/p\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EStart Building\u003C/strong\u003E\u003C/h3\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003EUsing the tabs on the left, select \u003Cstrong\u003EBuild &gt; Pipelines\u003C/strong\u003E. If there is already a \u003Cstrong\u003EMy First Pipeline\u003C/strong\u003E in the pipeline list, click on it and go ahead to the next step.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_build_pipeline_menu.png\" alt=\"Build Pipeline Menu\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EIf there is no pipeline listed:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EClick the plus (\u003Cstrong\u003E+\u003C/strong\u003E) symbol to create a new pipeline.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EOn the pop-up that appears, select \u003Cstrong\u003EUse Transformer for Snowflake\u003C/strong\u003E. If you were creating a pipeline that used one of our other engines, you would need to \u003Cstrong\u003ECreate a Deployment\u003C/strong\u003E to set up those engines, but since we are using serverless Transformer for Snowflake, that is unnecessary.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_tx4snowflake_pipeline.png\" alt=\"Tx 4 Snowflake Pipeline\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EA new window will appear to create your pipeline.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EGive your pipeline a name and add a description (optional).\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EEngine Type\u003C/strong\u003E: \u003Ccode\u003ETransformer for Snowflake\u003C/code\u003E is pre-selected\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ESelect \u003Cstrong\u003ENext\u003C/strong\u003E.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_tx4snowflake_pipeline_settings.png\" alt=\"Pipeline Settings\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EIf you wanted to share your pipeline with other users or groups in your Organization, this is where you would do that. For now, select \u003Cstrong\u003ESave &amp; Open in Canvas\u003C/strong\u003E.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_share_pipeline_settings.png\" alt=\"Pipeline Share Settings\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003Col start=\"2\"\u003E\u003Cli\u003E\n","\u003Cp\u003ENow you will see the empty design canvas, with key items on the canvas explained in more detail below. Additional details about the pipeline canvas can be found \u003Ca href=\"https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Pipelines/PipelineCanvas.html#concept_zj5_nj4_mpb\"\u003Ehere\u003C/a\u003E in the StreamSets documentation.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_canvas_guide.png\" alt=\"Canvas Guide\"\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E1 - \u003Cstrong\u003EPipeline Canvas\u003C/strong\u003E: Displays the pipeline and used to configure the pipeline data flow.\u003C/li\u003E\u003Cli\u003E2 -  \u003Cstrong\u003EPipeline Creation Help Bar\u003C/strong\u003E- Offers lists of stages to help complete the pipeline and can be used to connect a stage to an open node. You can also add a stage between linked stages by clicking the link between the two.\u003C/li\u003E\u003Cli\u003E3 - \u003Cstrong\u003EProperties Panel\u003C/strong\u003E: Displays the properties of the pipeline or selected stage when you configure a pipeline. Click on empty canvas   space to see the properties of the entire pipeline.\u003C/li\u003E\u003Cli\u003E4 - \u003Cstrong\u003ESelected stage pop-up menu\u003C/strong\u003E - Displays the icons for commands that you can apply to the selected stages.\u003C/li\u003E\u003Cli\u003E5 - \u003Cstrong\u003EStage library panel\u003C/strong\u003E - Used to add stages to the pipeline. You can drag a stage to a location on the canvas or click a stage to add it to the end of the pipeline.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClick on any blank space in the canvas to view the pipeline properties in the panel below.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EOn the \u003Cstrong\u003EGeneral\u003C/strong\u003E tab, there are 5 properties directly related to Snowflake. These are the \u003Cstrong\u003ESnowflake Account URL, Warehouse, Database, Schema\u003C/strong\u003E, and \u003Cstrong\u003ERole\u003C/strong\u003E. When your pipeline is executed, these properties are sent to Snowflake to determine what resources the pipeline uses to execute. As shown below, each of these is pre-populated with a StreamSets pipeline parameter. Those are written with the \u003Ccode\u003E${parameter_name}\u003C/code\u003E syntax.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_canvas_general_properties.png\" alt=\"General Pipeline Properties\"\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003ENow select the \u003Cstrong\u003EParameters\u003C/strong\u003E tab. This is where you can see the values that each of these parameters are given. By default, the Database, Warehouse, and Role that your pipelines point to are the ones generated by the Partner Connect Integration. The pipeline settings also points to the \u003Ccode\u003EPUBLIC\u003C/code\u003E schema.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_canvas_pipeline_parameters.png\" alt=\"Pipeline Parameters\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003E\u003Cstrong\u003ECreate a Source\u003C/strong\u003E\u003C/h3\u003E\n","\u003Cp\u003EThis pipeline will use data prepopulated in the \u003Ccode\u003ESNOWFLAKE_SAMPLE_DATA\u003C/code\u003E database, in schema \u003Ccode\u003ETPCH_SF1\u003C/code\u003E. It will use data from the \u003Ccode\u003EORDERS\u003C/code\u003E and \u003Ccode\u003ELINEITEM\u003C/code\u003E tables.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_tables_used.png\" alt=\"Tables Used\"\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EUsing the \u003Cstrong\u003EPipeline Creation Help Bar\u003C/strong\u003E, add a \u003Cstrong\u003ESnowflake Table Origin\u003C/strong\u003E to the canvas. Next to Origin Missing, select \u003Ccode\u003ESnowflake Table\u003C/code\u003E from the drop-down menu.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_add_origin_1.png\" alt=\"Add Origin\"\u003E\u003C/p\u003E\n\u003Col start=\"2\"\u003E\u003Cli\u003EClick on the new Origin if it is not already selected, and give it a meaningful name. Since this Origin will read the data from the \u003Ccode\u003EORDERS\u003C/code\u003E table, name it \u003Ccode\u003EOrders\u003C/code\u003E.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_name_origin_1.png\" alt=\"Name Origin\"\u003E\u003C/p\u003E\n\u003Col start=\"3\"\u003E\u003Cli\u003E\n","\u003Cp\u003EOn the \u003Cstrong\u003ETable\u003C/strong\u003E tab of the properties panel, we will tell the pipeline where this table is located. Since the data we are reading is in a Read-Only database, that database cannot be the pipeline&rsquo;s default. In this case we need to override the database and schema. To do this, select \u003Cstrong\u003ESpecify Database\u003C/strong\u003E, which makes the options for the Database and Schema appear. Use the following values to configure this origin, and see the finished configuration in the image below:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EDatabase\u003C/strong\u003E: \u003Ccode\u003ESNOWFLAKE_SAMPLE_DATA\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESchema\u003C/strong\u003E: \u003Ccode\u003ETPCH_SF1\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ETable\u003C/strong\u003E: \u003Ccode\u003EORDERS\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_specify_database_table.png\" alt=\"Override DB and Specify Table\"\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EThe origin is created and configured, but note that there are some additional options further down on the \u003Cstrong\u003ETable\u003C/strong\u003E tab. There is an option to limit the number of columns read from the table, add a where clause to filter down to a subset of the data read from the table, and the unique StreamSets feature to add a Preview clause.  We&rsquo;ll talk more about this later.\u003C/li\u003E\u003Cli\u003ENow the canvas has one origin, which is showing the validation error \u003Cstrong\u003EVALIDATION 0011 Stage has open output streams\u003C/strong\u003E, indicated by the yellow triangle.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_validation_error.png\" alt=\"Validation Error\"\u003E\u003C/p\u003E\n\u003Col start=\"4\"\u003E\u003Cli\u003E\n","\u003Cp\u003ETransformer for Snowflake pipelines need to have a final destination, so as a temporary fix, add a \u003Cstrong\u003ETrash\u003C/strong\u003E Destination.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EWhat is a \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/OriginsDestinations/Trash.html#concept_ddd_dl1_yrb\"\u003ETrash\u003C/a\u003E destination? It is  a placeholder destination so you can \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Preview/DataPreview.html#concept_slb_bjb_dsb\"\u003Epreview pipeline processing\u003C/a\u003E as you develop the pipeline. No tables will be permanently written to Snowflake when this pipeline is executed or previewed.\u003C/li\u003E\u003Cli\u003EAs when adding an origin, there are multiple ways to do this, but this time we are going to use the \u003Cstrong\u003EStage Library Panel\u003C/strong\u003E.\u003C/li\u003E\u003Cli\u003EIf the library panel is not already expanded, click on the hamburger icon \u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_hamburger_stage_menu.png\" alt=\"Stage Menu\"\u003E in the upper right corner of the canvas.\u003C/li\u003E\u003Cli\u003EEnter \u003Ccode\u003ETrash\u003C/code\u003E in the search bar, and click on the stage.\u003C/li\u003E\u003Cli\u003ENow a Trash destination stage should appear on the canvas.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThe canvas might be a little messy now, with stages not placed very logically, so let&rsquo;s Auto-Arrange it to clean it up. Above the canvas, on the right side is the \u003Cstrong\u003EAuto-Arrange\u003C/strong\u003E icon. Click on it to rearrange the processors as shown below.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_autoarrange.png\" alt=\"Auto-Arrange\"\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_2_unconnected_stages.png\" alt=\"Unconnected Stages\"\u003E\u003C/p\u003E\n\u003Col start=\"6\"\u003E\u003Cli\u003ENow we need to connect the source and destination to complete this first iteration of the pipeline. Select the \u003Cstrong\u003EOrders\u003C/strong\u003E Origin and click on the output node icon. Draw a line to the input node icon on the Trash stage as shown below.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_connect_stages.png\" alt=\"Connect 2 Stages\"\u003E\u003C/p\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EPreview the Pipeline\u003C/strong\u003E\u003C/h3\u003E\n","\u003Cp\u003ENow preview the pipeline results for the first time. Data Preview shows the input and output of each origin, processor, and destination. Find out more about Preview in the \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Preview/DataPreview.html?hl=preview\"\u003Edocumentation\u003C/a\u003E.\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EIn order to preview the pipeline results, select the Preview icon (eye) located above the canvas on the right.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_preview_button.png\" alt=\"Preview Icon\"\u003E\u003C/p\u003E\n\u003Col start=\"2\"\u003E\u003Cli\u003EA pop-up will now appear to configure previews. More details about preview configuration settings can be found \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Preview/DataPreview.html#task_szc_z5l_nsb\"\u003Ehere\u003C/a\u003E, but the important things to note are:\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EPreview Batch Size\u003C/strong\u003E: the number of records shown at each origin, processor, or destination.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EWrite to Destinations\u003C/strong\u003E: if a Snowflake table is the destination, selecting this option means that the pipeline would actually write only the previewed data to the target table(s).\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_preview_config.png\" alt=\"Preview config\"\u003E\u003C/p\u003E\n\u003Col start=\"3\"\u003E\u003Cli\u003E\n","\u003Cp\u003EClick \u003Cstrong\u003ERun Preview\u003C/strong\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EAt this time, Transformer for Snowflake is using Snowpark to generate the queries for this pipeline, and sending them over to Snowflake. Keep in mind that if the specified warehouse is currently suspended, it may take an extra moment to generate the preview results while it is resumed.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThere may be updates about the status of the pipeline preview in the properties panel as shown below.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_preview_status.png\" alt=\"preview status\"\u003E\u003C/p\u003E\n\u003Col start=\"6\"\u003E\u003Cli\u003EWhen the preview is ready, a screen appears that looks similar to this:\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_preview_contents.png\" alt=\"Preview Contents\"\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EBy default, the Orders origin stage is selected, and the properties window on the bottom shows 10 records from the ORDERS table, including the column name, data type, and value for every column in the record.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ETo make it easier to read, switch the records to a table view by selecting the table icon above the records\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_preview_table.png\" alt=\"Table Icon\"\u003E\u003C/p\u003E\n\u003Col start=\"7\"\u003E\u003Cli\u003ETo close the preview and return back to the design mode, select \u003Cstrong\u003EClose Preview\u003C/strong\u003E in the top right of the canvas.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_close_preview.png\" alt=\"Close Preview\"\u003E\u003C/p\u003E\n","\u003Cp\u003ENow let's start transforming the data. The immediate goal is create a table in Snowflake that joins the Order and Line Item data.\u003C/p\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EBegin Data Transformation by Renaming Columns\u003C/strong\u003E\u003C/h3\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003EThe first step is to rename the columns read from the \u003Ccode\u003EORDERS\u003C/code\u003E table.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThe data preview showed that the Order column names all begin with O_. Let's clean the names up by removing that prefix.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EMake sure the preview is closed, and click on the arrow connecting the \u003Cstrong\u003EOrders\u003C/strong\u003E origin and \u003Cstrong\u003ETrash\u003C/strong\u003E destination.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_add_renamer.png\" alt=\"Add Renamer\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EThe \u003Cstrong\u003EPipeline Creation Help Bar\u003C/strong\u003E should appear after selecting the line connecting the two stages.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EOn the drop-down menu, choose the Field Renamer processor.\u003C/li\u003E\u003Cli\u003E\u003Cem\u003EIf the Pipeline Creation Help Bar does \u003Cstrong\u003Enot\u003C/strong\u003E appear\u003C/em\u003E:\n\u003Cul\u003E\u003Cli\u003Euse the \u003Cstrong\u003EStage Library Panel\u003C/strong\u003E on the right, search for \u003Ccode\u003EField Renamer\u003C/code\u003E, and click on it. This should add a \u003Cstrong\u003EField Renamer\u003C/strong\u003E processor to the canvas.\u003C/li\u003E\u003Cli\u003Edelete the connection between \u003Cstrong\u003EOrders\u003C/strong\u003E and \u003Cstrong\u003ETrash\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003Econnect \u003Cstrong\u003EOrders\u003C/strong\u003E to the \u003Cstrong\u003EField Renamer\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003Econnect \u003Cstrong\u003EField Renamer\u003C/strong\u003E to \u003Cstrong\u003ETrash\u003C/strong\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ENow the pipeline should look like this:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_orders_renamer_trash.png\" alt=\"Orders Renamer Trash\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003Col start=\"4\"\u003E\u003Cli\u003EOpen the \u003Cstrong\u003EField Renamer\u003C/strong\u003E processor by clicking on it. Its properties should appear below the canvas:\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_field_renamer_properties_1.png\" alt=\"Field Renamer Properties\"\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EName the stage \u003Ccode\u003ERemove Column Name Prefixes\u003C/code\u003E on the General tab.\u003C/li\u003E\u003Cli\u003ESelect the \u003Cstrong\u003ERename\u003C/strong\u003E tab.\n\u003Cul\u003E\u003Cli\u003ESelect the \u003Cstrong\u003ERename Type\u003C/strong\u003E drop down menu.\u003C/li\u003E\u003Cli\u003EThere are multiple options here, and since we know that we want to remove the \u003Ccode\u003EO_\u003C/code\u003E prefix from all fields, select \u003Ccode\u003ERemove prefix from all fields\u003C/code\u003E.\u003C/li\u003E\u003Cli\u003ELeave the \u003Cstrong\u003ECase Insensitive\u003C/strong\u003E setting selected, so we can remove both upper and lower cased column names, and enter \u003Ccode\u003EO_\u003C/code\u003E for Remove String.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_renamer_rename_options.png\" alt=\"Renamer Options\"\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_renamer_final_config.png\" alt=\"Renamer Final Config\"\u003E\u003C/p\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EWrite to a Snowflake Table\u003C/strong\u003E\u003C/h3\u003E\n","\u003Cp\u003ENow replace the Trash stage with a real destination in Snowflake.\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EClick on the Trash stage and delete it using the trash can icon on the pop up menu.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_delete.png\" alt=\"Delete Trash\"\u003E\u003C/p\u003E\n\u003Col start=\"2\"\u003E\u003Cli\u003ESelect the \u003Cstrong\u003EField Renamer [Remove Column Name Prefixes]\u003C/strong\u003E processor, and the \u003Cstrong\u003EPipeline Creation Help Bar\u003C/strong\u003E should appear. Choose the \u003Ccode\u003ESelect New Destination to connect&hellip;\u003C/code\u003E menu and choose \u003Ccode\u003ESnowflake Table\u003C/code\u003E.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_add_destination.png\" alt=\"Add Snowflake Destination\"\u003E\u003C/p\u003E\n\u003Col start=\"3\"\u003E\u003Cli\u003E\n","\u003Cp\u003EWith the new Snowflake Table destination selected update the following settings:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EGeneral\u003C/strong\u003E tab &gt; \u003Cstrong\u003EName\u003C/strong\u003E: \u003Ccode\u003EOrder Line Items\u003C/code\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETable\u003C/strong\u003E tab &gt;\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ETable\u003C/strong\u003E:  \u003Ccode\u003EORDER_LINE_ITEMS\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EWrite Mode\u003C/strong\u003E: \u003Ccode\u003EOverwrite Table\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EOverwrite Mode\u003C/strong\u003E*: \u003Ccode\u003EDrop Table\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ECreate Table\u003C/strong\u003E: \u003Cstrong\u003E✓\u003C/strong\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E*\u003Cstrong\u003ENote\u003C/strong\u003E:Table destinations have 4 different write modes which are explained \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/OriginsDestinations/SnowflakeTable-D.html#concept_wdr_fzy_prb\"\u003Ehere\u003C/a\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EPreview the pipeline again by clicking on the preview icon above the canvas. When the Preview Configuration Window appears, change the \u003Cstrong\u003EPreview Batch Size\u003C/strong\u003E to \u003Ccode\u003E1\u003C/code\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EWhen the preview finishes processing, select the \u003Cstrong\u003EField Renamer [Remove Column Name Prefixes]\u003C/strong\u003E to see the results. All of the \u003Cem\u003E&ldquo;O\u003C/em\u003E&rdquo;_ prefixes were removed from the column names. This is just one example of how Transformer for Snowflake pipelines dynamically generate SQL at pipeline runtime. The \u003Cstrong\u003EApply Functions\u003C/strong\u003E, \u003Cstrong\u003EField Remover\u003C/strong\u003E, \u003Cstrong\u003EField Renamer\u003C/strong\u003E, and \u003Cstrong\u003EField Type Converter\u003C/strong\u003E processors all allow you to dynamically specify column names based on patterns. This means that even as the data evolves over time, your pipelines won't break if a new column appears. For example, if a pipeline has an \u003Cstrong\u003EApply Functions\u003C/strong\u003E processor configured to trim all strings to remove extra characters, and specifies the columns to operate using the pattern \u003Ccode\u003E.*\u003C/code\u003E, no matter what columns are named, the \u003Ccode\u003ETRIM\u003C/code\u003E function will be applied. This works for a variety of String, Numeric, DateTime, and User Defined functions.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_renamer_preview.png\" alt=\"Preview Renamer\"\u003E\u003C/p\u003E\n\u003Col start=\"6\"\u003E\u003Cli\u003E\n","\u003Cp\u003ESelect the \u003Cstrong\u003ETable Destination [Order Line Items]\u003C/strong\u003E stage to see the new column names passed to the destination.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClose the preview.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003E\u003Cstrong\u003ERun the Pipeline\u003C/strong\u003E\u003C/h3\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003ENow that the pipeline&rsquo;s behavior was verified using preview, run the pipeline on the entire data set.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EIn the toolbar above the canvas, there is a \u003Cstrong\u003EDraft Run\u003C/strong\u003E button on the far right. Choose \u003Cstrong\u003EStart Pipeline\u003C/strong\u003E from the drop down that appears when clicking on it.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EIn StreamSets, a \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/ControlHub/Title.html#concept_snq_pkg_4tb\"\u003EDraft Run\u003C/a\u003E allows you to execute a pipeline that is still in development and not yet published. Running a \u003Cem\u003Epublished\u003C/em\u003E version of a pipeline is considered a StreamSets \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/ControlHub/Title.html#concept_qv1_5sn_hsb\"\u003EJob\u003C/a\u003E. Jobs can be scheduled, run with different parameter values, and made into templates. See the \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/ControlHub/Title.html#concept_qv1_5sn_hsb\"\u003Edocumentation\u003C/a\u003E for more details.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_draft_run.png\" alt=\"Draft Run\"\u003E\u003C/p\u003E\n\u003Col start=\"3\"\u003E\u003Cli\u003EWhen the run completes, the job status in the properties panel will change to \u003Ccode\u003EINACTIVE\u003C/code\u003E, and the \u003Cstrong\u003ERealtime Summary\u003C/strong\u003E tab will display the total number of records read and written. Click on the \u003Cstrong\u003EDraft Run History\u003C/strong\u003E tab to view more details.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_draft_run_complete.png\" alt=\"Draft Run Complete\"\u003E\u003C/p\u003E\n\u003Col start=\"4\"\u003E\u003Cli\u003EOn the \u003Cstrong\u003EDraft Run History\u003C/strong\u003E tab, you can see the history of draft runs for the pipeline. On the most recent run, click on \u003Cstrong\u003EView Summary\u003C/strong\u003E.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_draft_run_history_1.png\" alt=\"Draft Run History\"\u003E\u003C/p\u003E\n\u003Col start=\"5\"\u003E\u003Cli\u003EIn the pop-up window that appears, the Job Metrics Summary appears at the top, and \u003Cstrong\u003EScroll Down\u003C/strong\u003E to view the Snowflake Queries that are generated to populate the target table(s) as well as some logging.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_job_summary_2.png\" alt=\"Job Summary 2\"\u003E\u003C/p\u003E\n\u003Col start=\"6\"\u003E\u003Cli\u003E\n","\u003Cp\u003ENow let's take a look at what is happening in Snowflake. Go back to your Snowflake account, and under the \u003Cstrong\u003EActivity\u003C/strong\u003E menu on the left, select \u003Cstrong\u003EQuery History\u003C/strong\u003E. By default, there will be a filter on your user. Since a new user was created for the Partner Connect integration, you will need to remove the User filter from the top right of the \u003Cstrong\u003EQuery History\u003C/strong\u003E window.\u003C/p\u003E\n","\u003Cp\u003ENow Look for the \u003Ccode\u003ECREATE OR REPLACE TABLE\u003C/code\u003E statement in the query history, and you can click on the SQL text to see the query Snowpark generated to create this table in Snowflake. Since we chose the \u003Ccode\u003EOverwrite Mode\u003C/code\u003E of \u003Ccode\u003EDrop Table\u003C/code\u003E, that is why a \u003Ccode\u003ECREATE OR REPLACE TABLE\u003C/code\u003E statement is used. If we had selected the \u003Ccode\u003ETruncate\u003C/code\u003E option, we would see a \u003Ccode\u003ETRUNCATE\u003C/code\u003E statement followed by an \u003Ccode\u003EINSERT\u003C/code\u003E statement that leverages the same subquery.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_query_history_1.png\" alt=\"Snowflake Query History\"\u003E\u003C/p\u003E\n\u003Col start=\"7\"\u003E\u003Cli\u003E\n","\u003Cp\u003ELastly, go to the \u003Cstrong\u003EWorksheets\u003C/strong\u003E tab in Snowflake. Click on the \u003Cstrong\u003Eplus\u003C/strong\u003E (\u003Cstrong\u003E+\u003C/strong\u003E) icon to create a new worksheet. Use the SQL below to run a couple queries on the table that was just created to see the number of rows in the new table as well as a sample of ten rows. Notice that the new table has the updated column names with the prefix removed.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote\u003C/strong\u003E: If you named your tables differently than suggested, you will need to modify the query.\u003C/p\u003E\n","\u003Ch3\u003ESQL\u003C/h3\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE WAREHOUSE PC_STREAMSETS_WH;\nUSE ROLE PC_STREAMSETS_ROLE;\nUSE DATABASE PC_STREAMSETS_DB;\nUSE SCHEMA PUBLIC;\n\nSELECT COUNT(*) FROM ORDER_LINE_ITEMS;\nSELECT * FROM ORDER_LINE_ITEMS LIMIT 10;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003C/ol\u003E\n\u003Cul\u003E\u003Cli\u003ENow that we successfully created and executed this simple pipeline, go back to StreamSets to continue developing.\u003C/li\u003E\u003Cli\u003EWant to download and import a copy of the pipeline build so far? Download it from \u003Ca href=\"https://github.com/streamsets/Pipeline-Examples/blob/main/tx4snowflake_hol/my_first_pipeline_v1.zip\"\u003Egithub\u003C/a\u003E. Later in the lab, we'll go over the simple task of importing object, but you can find the documentation \u003Ca href=\"https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/ExportImport/Importing.html#task_qr5_szm_qx\"\u003Ehere\u003C/a\u003E.\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch2\u003E\u003Cstrong\u003EMore Advanced Transformation\u003C/strong\u003E\u003C/h2\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EPipeline Publishing &amp; Version Control\u003C/strong\u003E\u003C/h3\u003E\n","\u003Cp\u003ENow we are going to use StreamSets built-in version control to \u003Ca href=\"https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Pipelines/Pipelines-Managing.html#task_x1v_yg2_2sb\"\u003Epublish\u003C/a\u003E the pipeline we just created and start a new draft of the pipeline.\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003EIn StreamSets, go back to the pipeline that was just created. You will still be in edit mode, so you should see the \u003Cstrong\u003ECheck In\u003C/strong\u003E button above the Canvas. Click on this and the \u003Cstrong\u003ECheck In\u003C/strong\u003E wizard will appear.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_checkin.png\" alt=\"Check In\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EIn the \u003Cstrong\u003ECheck In\u003C/strong\u003E wizard, enter a commit message and choose \u003Cstrong\u003EPublish and Close\u003C/strong\u003E.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_check_in_pub_and_close.png\" alt=\"Pub &amp; Close\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EBack in the design canvas, you are now viewing a read-only version of the pipeline.  To create a new draft, click on \u003Cstrong\u003EEdit\u003C/strong\u003E in the toolbar above the canvas.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_edit_version.png\" alt=\"Edit Version\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EJoin Orders with Line Items\u003C/strong\u003E\u003C/h3\u003E\n","\u003Cp\u003ELet's continue on with our pipeline development. Now let's add \u003Ccode\u003ELINEITEMS\u003C/code\u003E to the pipeline so that we can finish our \u003Ccode\u003EORDER_LINE_ITEMS\u003C/code\u003E table.\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EThere are a couple ways to add a new origin , but the quickest is to simply copy the origin we already created. Select the \u003Cstrong\u003EORDERS\u003C/strong\u003E stage, and choose the \u003Cstrong\u003ECopy\u003C/strong\u003E icon from the pop-up menu above. A new origin will appear on the screen, with the default name \u003Cstrong\u003ESnowflake Table 1\u003C/strong\u003E.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_copy_stage.png\" alt=\"Copy Stage\"\u003E\u003C/p\u003E\n\u003Col start=\"2\"\u003E\u003Cli\u003E\n","\u003Cp\u003EUpdate the new origin stage \u003Cstrong\u003ESnowflake Table 1\u003C/strong\u003E with the following configurations:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EOn the \u003Cstrong\u003EGeneral\u003C/strong\u003E properties tab, give it the name \u003Ccode\u003ELINEITEMS\u003C/code\u003E\u003C/li\u003E\u003Cli\u003EOn the \u003Cstrong\u003ETable\u003C/strong\u003E properties tab, we can see that the settings from the \u003Cstrong\u003EOrders\u003C/strong\u003E origin are pre-populated. This means that all we need to do is update the Table name to  \u003Ccode\u003ELINEITEM\u003C/code\u003E, with this resulting configuration:\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_line_items_properties.png\" alt=\"LineItems Properties\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ELet's do the same column name transformations on the Line Items data, since all of the column names in this table begin with \u003Cem\u003EL\u003C/em\u003E_. You can see the column names from the table in Snowflake below.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_lineitem_column.png\" alt=\"LineItem Columns\"\u003E\u003C/p\u003E\n\u003Col start=\"4\"\u003E\u003Cli\u003EAdd another \u003Cstrong\u003EField Renamer\u003C/strong\u003E to the canvas. Eventually, the Orders and Line Item data will be joined, so it would be good to add a meaningful prefix on the Line Item columns to indicate which table each column is from. Instead of the \u003Ccode\u003EL_\u003C/code\u003E prefix, the columns will be prefixed with \u003Ccode\u003ELINEITEM_\u003C/code\u003E.\u003C/li\u003E\u003C/ol\u003E\n\u003Cul\u003E\u003Cli\u003EDo this by clicking on the output node of the \u003Cstrong\u003ELINEITEM\u003C/strong\u003E origin and use the \u003Cstrong\u003EPipeline Creation Help Bar\u003C/strong\u003E above the canvas to select a \u003Cstrong\u003EField Renamer\u003C/strong\u003E processor [or click on the \u003Cstrong\u003EStage Panel Library\u003C/strong\u003E on the right canvas to select a \u003Cstrong\u003EField Renamer\u003C/strong\u003E and connect the \u003Cstrong\u003ELINEITEM\u003C/strong\u003E output to the new processor's input].\n\u003Cul\u003E\u003Cli\u003EClick on the new processor.\u003C/li\u003E\u003Cli\u003EOn the \u003Cstrong\u003EGeneral\u003C/strong\u003E tab, set the \u003Cstrong\u003EName\u003C/strong\u003E to \u003Ccode\u003EUpdate Column Prefixes\u003C/code\u003E\u003C/li\u003E\u003Cli\u003EOn the \u003Cstrong\u003ERename\u003C/strong\u003E tab, update the following properties:\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ERename Type\u003C/strong\u003E: \u003Ccode\u003EFind and replace in all fields by string\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EMatch Pattern\u003C/strong\u003E: \u003Ccode\u003EL_\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EReplacement\u003C/strong\u003E: \u003Ccode\u003ELINEITEM_\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003E\u003Cstrong\u003ECalculate Unit Price, Discounts, and Tax\u003C/strong\u003E\u003C/h3\u003E\n\u003Col start=\"5\"\u003E\u003Cli\u003E\n","\u003Cp\u003ENow that the column names are updated on the \u003Ccode\u003ELINEITEM\u003C/code\u003E table, let's perform a few calculations that we want to see downstream in our analytics. We want to add some columns that calculate the unit base price per item, discounted price per item, total discount amount, and total sales amount.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EWe will use an \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Processors/Expression.html#concept_i1k_wxc_5rb\"\u003E\u003Cstrong\u003EExpression Evaluator\u003C/strong\u003E\u003C/a\u003E to create new columns.\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EAdd an \u003Cstrong\u003EExpression Evaluator\u003C/strong\u003E processor to the canvas after the \u003Cstrong\u003EUpdate Column Prefixes\u003C/strong\u003E processor.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EName the \u003Cstrong\u003EExpression Evaluator\u003C/strong\u003E \u003Ccode\u003ECalculate Unit and Total Amounts\u003C/code\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EGo to the \u003Cstrong\u003EExpressions\u003C/strong\u003E tab.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ENow we want to add the following columns and accompanying calculations. Don't add this just yet!\u003C/p\u003E\n\u003Ctable\u003E\u003Cthead\u003E\u003Ctr\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EColumn name\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EExpression\u003C/th\u003E\u003C/tr\u003E\u003C/thead\u003E\u003Ctbody\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Eunit_base_price\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Elineitem_extendedprice/lineitem_quantity\u003C/code\u003E\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Ediscounted_unit_price\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Eunit_base_price * (1 - lineitem_discount)\u003C/code\u003E\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Etotal_discount_amount\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003E-1 * lineitem_extendedprice * lineitem_discount\u003C/code\u003E\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Etotal_tax_amount\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003E(lineitem_extendedprice + total_discount_amount) * lineitem_tax\u003C/code\u003E\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Enet_total_amount\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Elineitem_extendedprice + total_discount_amount + total_tax_amount\u003C/code\u003E\u003C/td\u003E\u003C/tr\u003E\u003C/tbody\u003E\u003C/table\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EWhen there is a lot of configuration that you want to copy/paste, you can often take advantage of \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Pipelines/SimpleBulkEdit.html?hl=bulk%2Cedit\"\u003E\u003Ccode\u003EBulk Edit Mode\u003C/code\u003E\u003C/a\u003E. This switches the individual configurations to a json blob where you can copy/paste JSON arrays.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_exp_eval_config.png\" alt=\"Bulk Edit Mode\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ECopy the following \u003Ccode\u003Ejson\u003C/code\u003E into the Bulk Edit text box - and be sure to include the brackets:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-json\"\u003E[\n  {&quot;fieldName&quot;: &quot;unit_base_price&quot;, &quot;expression&quot;: &quot;lineitem_extendedprice/lineitem_quantity&quot;},\n  {&quot;fieldName&quot;: &quot;discounted_unit_price&quot;, &quot;expression&quot;: &quot;unit_base_price * (1 - lineitem_discount)&quot;},\n  {&quot;fieldName&quot;: &quot;total_discount_amount&quot;, &quot;expression&quot;: &quot;-1 * lineitem_extendedprice * lineitem_discount&quot;},\n  {&quot;fieldName&quot;: &quot;total_tax_amount&quot;, \n        &quot;expression&quot;: &quot;(lineitem_extendedprice + total_discount_amount) * lineitem_tax&quot;},\n  {&quot;fieldName&quot;: &quot;net_total_amount&quot;, &quot;expression&quot;: &quot;lineitem_extendedprice + total_discount_amount + total_tax_amount&quot;}\n]\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_bulkedit_config.png\" alt=\"Bulk Edit Config\"\u003E\u003C/p\u003E\n","\u003Cp\u003EThe pipeline should now look like this:\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_exp_eval_v2.png\" alt=\"pipeline with expression evaluator\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EJoin\u003C/strong\u003E\u003C/h3\u003E\n\u003Col start=\"6\"\u003E\u003Cli\u003E\n","\u003Cp\u003ENow let's join these two tables together.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EClick on the line connecting the first \u003Cstrong\u003EField Renamer [Remove Column Name Prefixes]\u003C/strong\u003E to the \u003Cstrong\u003ESnowflake Table [ORDER LINE ITEMS]\u003C/strong\u003E destination.\u003C/li\u003E\u003Cli\u003EOn the \u003Cstrong\u003EPipeline Creation Help Bar\u003C/strong\u003E, select \u003Cstrong\u003EJoin\u003C/strong\u003E from the \u003Cem\u003ESelect Processor to add in between the selected stream...\u003C/em\u003E drop-down.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ENow connect the second \u003Cstrong\u003EField Renamer [Update Column Prefixes]\u003C/strong\u003E to the \u003Cstrong\u003EJoin\u003C/strong\u003E stage just added, so that it has two inputs. Your pipeline should now look like this:\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_first_join.png\" alt=\"Joined Pipeline\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClick on the \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Processors/Join.html#concept_edd_sc2_5rb\"\u003EJoin\u003C/a\u003E stage, and name the processor \u003Ccode\u003EOrder and Line Item Join\u003C/code\u003E.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EOn the \u003Cstrong\u003EJoin\u003C/strong\u003E properties tab below the canvas, we describe the join criteria. This is a very flexible processor as described in the \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Processors/Join.html#concept_edd_sc2_5rb\"\u003Edocumentation\u003C/a\u003E, so there are multiple join types to choose from and join conditions can be based on matching column names or the join clause can be written out in SQL.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EIn this case, we will do an inner join on the \u003Ccode\u003EORDERS\u003C/code\u003E and \u003Ccode\u003ELINEITEM\u003C/code\u003E tables based on the \u003Ccode\u003EORDERKEY\u003C/code\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EMake sure that the stage has the settings below:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EJoin Type\u003C/strong\u003E: \u003Ccode\u003EInner\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EJoin Criteria\u003C/strong\u003E: \u003Ccode\u003ECondition\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ECondition\u003C/strong\u003E: \u003Ccode\u003EORDERKEY = LINEITEM_ORDERKEY\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EPreview\u003C/strong\u003E the pipeline to see if the pipeline changes have had the desired effect. Use the preview button (eye icon) on the right side above the canvas.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ELooking at the previews for the \u003Cstrong\u003EField Renamer\u003C/strong\u003E stages, we can see that all of the prefixes were removed or updated accordingly.\u003C/li\u003E\u003Cli\u003EThe preview for the \u003Cstrong\u003EJoin\u003C/strong\u003E stage probably isn't showing any records. Why not?\n\u003Cul\u003E\u003Cli\u003EWhen using preview, the pipeline is randomly pulling the records from each of the sources, so in this case, there is no guarantee that they will have Order Keys that will overlap. That's ok, because we can use the \u003Cstrong\u003EPreview Where Clause\u003C/strong\u003E to filter the records that are used for preview.\u003C/li\u003E\u003Cli\u003EIn this case, we will filter on the Order Id so that we can match the line items to the order.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003EClose the preview\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EUpdate the preview filters on the Snowflake Table origins.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EGo to the \u003Cstrong\u003EORDERS\u003C/strong\u003E origin and open the \u003Cstrong\u003ETable\u003C/strong\u003E properties tab. For the \u003Cstrong\u003EAdditional Preview Where Clause\u003C/strong\u003E, enter \u003Ccode\u003EO_ORDERKEY = 1\u003C/code\u003E\u003C/li\u003E\u003Cli\u003EOn the \u003Cstrong\u003ELINEITEM\u003C/strong\u003E origin, add \u003Ccode\u003EL_ORDERKEY = 1\u003C/code\u003E as the  \u003Cstrong\u003EAdditional Preview Where Clause\u003C/strong\u003E.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EPreview the pipeline again, and select the \u003Cstrong\u003EJoin [Order &amp; Line Item Join]\u003C/strong\u003E processor. Now the processor is showing input and output where the Order and Line Item information have a matching order key.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_join_preview.png\" alt=\"Join Preview\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003E\u003Cstrong\u003ECreate an Order Summary Table\u003C/strong\u003E\u003C/h3\u003E\n\u003Col start=\"12\"\u003E\u003Cli\u003E\n","\u003Cp\u003ENow create a \u003Cstrong\u003EOrder Summary\u003C/strong\u003E table that includes some of the calculations we just added.  We want to get total gross sales amount, total discount amount, total tax amount, and total net sales amount for each order. We'll also create a column, \u003Ccode\u003EORDER_COUNT\u003C/code\u003E, so that subsequent aggregations can use that to total orders.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003ETo do this, add an \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Processors/Aggregate.html#concept_rvw_5rc_5rb\"\u003E\u003Cstrong\u003EAggregate\u003C/strong\u003E\u003C/a\u003E processor to the pipeline.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ECreate a second output from the \u003Cstrong\u003EJoin [Order &amp; Line Item Join]\u003C/strong\u003E processor by drawing a line from its output node to the input node of the \u003Cstrong\u003EAggregate\u003C/strong\u003E processor.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EName the \u003Cstrong\u003EAggregate\u003C/strong\u003E processor \u003Ccode\u003EAggregate Line Items\u003C/code\u003E. On the  \u003Cstrong\u003EAggregate\u003C/strong\u003E properties tab, add the following fields under \u003Cem\u003E\u003Cstrong\u003EAggregations\u003C/strong\u003E\u003C/em\u003E (bulk edit option provided too):\u003C/p\u003E\n\u003Ctable\u003E\u003Cthead\u003E\u003Ctr\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EAggregate Function\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EAggregate Field\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EOutput Field Name\u003C/th\u003E\u003C/tr\u003E\u003C/thead\u003E\u003Ctbody\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ESum\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ELINEITEM_EXTENDEDPRICE\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003EGROSS_SALES_AMOUNT\u003C/code\u003E\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ESum\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ETOTAL_DISCOUNT_AMOUNT\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ETOTAL_DISCOUNT_AMOUNT\u003C/code\u003E\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ESum\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ETOTAL_TAX_AMOUNT\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ETOTAL_TAX_AMOUNT\u003C/code\u003E\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ESum\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ENET_TOTAL_AMOUNT\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ENET_TOTAL_AMOUNT\u003C/code\u003E\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ECount Distinct\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003EORDERKEY\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003EORDER_COUNT\u003C/code\u003E\u003C/td\u003E\u003C/tr\u003E\u003C/tbody\u003E\u003C/table\u003E\n","\u003Cp\u003EJSON to copy/paste in \u003Cstrong\u003EBulk Edit Mode\u003C/strong\u003E:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-json\"\u003E  [\n    { &quot;aggregateTypes&quot;: &quot;SUM&quot;,\n      &quot;aggregateField&quot;: &quot;LINEITEM_EXTENDEDPRICE&quot;,\n      &quot;outputField&quot;: &quot;GROSS_SALES_AMOUNT&quot; },\n    {  &quot;aggregateTypes&quot;: &quot;SUM&quot;,\n      &quot;aggregateField&quot;: &quot;TOTAL_DISCOUNT_AMOUNT&quot;,\n      &quot;outputField&quot;: &quot;TOTAL_DISCOUNT_AMOUNT&quot; },\n    {  &quot;aggregateTypes&quot;: &quot;SUM&quot;,\n      &quot;aggregateField&quot;: &quot;TOTAL_TAX_AMOUNT&quot;,\n      &quot;outputField&quot;: &quot;TOTAL_TAX_AMOUNT&quot; },\n    {  &quot;aggregateTypes&quot;: &quot;SUM&quot;,\n      &quot;aggregateField&quot;: &quot;NET_TOTAL_AMOUNT&quot;,\n      &quot;outputField&quot;: &quot;NET_TOTAL_AMOUNT&quot; },\n    { &quot;aggregateTypes&quot;: &quot;COUNT_DISTINCT&quot;,\n      &quot;aggregateField&quot;: &quot;ORDERKEY&quot;,\n      &quot;outputField&quot;: &quot;ORDER_COUNT&quot; }\n  ]\n\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ESet \u003Cstrong\u003EGroup by Fields\u003C/strong\u003E[1] to \u003Ccode\u003EORDERKEY\u003C/code\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThe final properties should look like this:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_aggregate_settings.png\" alt=\"Aggregate properties\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ENow add another \u003Cstrong\u003ESnowflake Table\u003C/strong\u003E destination to the canvas, feeding it the output of the \u003Cstrong\u003EAggregate\u003C/strong\u003E processor.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EName the destination \u003Ccode\u003EOrder Summary\u003C/code\u003E\u003C/li\u003E\u003Cli\u003EOn the \u003Cstrong\u003ETable\u003C/strong\u003E tab, specify the table name as \u003Ccode\u003EORDER_SUMMARY\u003C/code\u003E\u003C/li\u003E\u003Cli\u003ESelect \u003Cstrong\u003EWrite Mode\u003C/strong\u003E: \u003Ccode\u003EOverwrite Table\u003C/code\u003E\u003C/li\u003E\u003Cli\u003ESelect \u003Cstrong\u003EOverwrite Mode\u003C/strong\u003E: \u003Ccode\u003EDrop Table\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThe completed properties should look like this:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_order_summary_properties.png\" alt=\"Order Summary Properties\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EPreview the Pipeline. Look at the output of the \u003Cstrong\u003EExpression Evaluator\u003C/strong\u003E state to see the calculated columns.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_exp_evaluator_preview.png\" alt=\"Expression Evaluator Preview\"\u003E\u003C/p\u003E\n\u003Col start=\"14\"\u003E\u003Cli\u003ELook at the output of the \u003Cstrong\u003EAggregate\u003C/strong\u003E stage to see the aggregated Order Summary record.\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_aggregate_preview.png\" alt=\"Aggregate Preview\"\u003E\u003C/p\u003E\n","\u003Ch3\u003E\u003Cstrong\u003ECreate Final Order Summary\u003C/strong\u003E\u003C/h3\u003E\n\u003Col start=\"15\"\u003E\u003Cli\u003ENow we want to join the summary data to the original orders data to create a table that has both the Order level details, such as \u003Ccode\u003ECUSTOMERKEY\u003C/code\u003E, and the totals derived from the Line Items.\u003C/li\u003E\u003C/ol\u003E\n\u003Cul\u003E\u003Cli\u003EStart by adding another \u003Cstrong\u003EJoin\u003C/strong\u003E stage to the canvas using the \u003Cstrong\u003EStage Library Panel\u003C/strong\u003E on the right.\u003C/li\u003E\u003Cli\u003EConnect the output from the first \u003Cstrong\u003EField Renamer [Remove Column Name Prefixes]\u003C/strong\u003E processor as the input to the new \u003Cstrong\u003EJoin\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EConnect the output of the \u003Cstrong\u003EAggregate\u003C/strong\u003E processor to the join.\u003C/li\u003E\u003Cli\u003EGo to the processor configuration:\n\u003Cul\u003E\u003Cli\u003EName the join \u003Ccode\u003EOrder and Aggregate Join\u003C/code\u003E\u003C/li\u003E\u003Cli\u003EOn the properties \u003Cstrong\u003EJoin\u003C/strong\u003E tab:\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EJoin Criteria\u003C/strong\u003E: \u003Ccode\u003EMatching Fields\u003C/code\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EMatching Fields\u003C/strong\u003E[1]: \u003Ccode\u003EORDERKEY\u003C/code\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_join2_properties.png\" alt=\"Join Properties\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n&lt;!--\n16. Now we want to limit the columns that will be inserted into the new target table because maybe there are columns that are no longer used or not relevant to the data consumers. This can by done by using a **Field Remover** processor to specify the columns to **keep**. This processor gives you the option to specify either the columns to keep or the columns to remove. This can be done be specifying a list of columns OR using pattern matching to specify which columns to keep/remove.\n\n- Insert a **Field Remover** stage. \n- Connect the output of **Join [Order and Aggregate Join]** to its input.\n- Name the stage ``Curate Columns``\n- On the **Fields** tab of the stage properties, update the following settings:\n- **Action**: ``Keep Listed Fields``\n- **Field Match Criteria**: ``Field Name``\n- **Fields**:  Below the first field, select [``Bulk Edit Mode``](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Pipelines/SimpleBulkEdit.html?hl=bulk%2Cedit) and copy/paste the following JSON array. Be sure to include the brackets.:\n```JSON\n[\n&quot;ORDERKEY&quot;,\n&quot;ORDERDATE&quot;,\n&quot;CUSTOMERKEY&quot;,\n&quot;STATUSCODE&quot;,\n&quot;PRIORITYCODE&quot;,\n&quot;CLERKNAME&quot;,\n&quot;SHIPPRIORITY&quot;,\n&quot;GROSS_SALES_AMOUNT&quot;,\n&quot;TOTAL_DISCOUNT_AMOUNT&quot;,\n&quot;TOTAL_TAX_AMOUNT&quot;,\n&quot;NET_TOTAL_AMOUNT&quot;\n]\n```\n--&gt;\n\u003Col start=\"16\"\u003E\u003Cli\u003ENow we will specify which table this data should be loaded to.\u003C/li\u003E\u003C/ol\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EAdd a new \u003Cstrong\u003ESnowflake Table\u003C/strong\u003E destination to the canvas.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EConnect the output of the \u003Cstrong\u003EField Remover\u003C/strong\u003E to its input.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EOn the \u003Cstrong\u003ETable\u003C/strong\u003E tab in the properties, specify the table name \u003Ccode\u003EORDER_AMOUNTS\u003C/code\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EAt this point, the pipeline should look something like this:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_final_pre_pivot.png\" alt=\"pipeline\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003Col start=\"17\"\u003E\u003Cli\u003E\n","\u003Cp\u003ENow preview the results, looking at each of the stages. If it would be helpful to see some more data in the preview, add another ORDERKEY to the the \u003Cstrong\u003EPreview Where Clause\u003C/strong\u003E by changing them to \u003Ccode\u003EO_ORDERKEY IN (1,2)\u003C/code\u003E for the Orders table and \u003Ccode\u003EL_ORDERKEY IN (1,2)\u003C/code\u003E for the Line Item table.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EOnce the pipeline has been previewed do a \u003Cstrong\u003EDraft Run\u003C/strong\u003E on the unpublished pipeline. Go to your worksheet and run the following queries to see the output of the pipeline.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT * FROM PC_STREAMSETS_DB.PUBLIC.ORDER_LINE_ITEMS LIMIT 10;\nSELECT * FROM PC_STREAMSETS_DB.PUBLIC.ORDER_SUMMARY LIMIT 10;\nSELECT * FROM PC_STREAMSETS_DB.PUBLIC.ORDER_AMOUNTS LIMIT 10;   \n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ECheck in this version of the pipeline and enter a commit message. Choose \u003Ccode\u003ESave &amp; Close\u003C/code\u003E from the \u003Cstrong\u003ECheck In\u003C/strong\u003E window.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EA complete version of this pipeline can be found \u003Ca href=\"https://github.com/streamsets/Pipeline-Examples/blob/359a57b4e5f486ba5c094a3380e4a618662a1657/tx4snowflake_hol/my_first_pipeline_step_3.zip\"\u003Ehere\u003C/a\u003E on github.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch2\u003E\u003Cstrong\u003EUser Defined Functions\u003C/strong\u003E\u003C/h2\u003E\n","\u003Cp\u003EIn the previous step, we added an \u003Cstrong\u003EExpression Evaluator\u003C/strong\u003E to the pipeline to calculate values like unit cost and unit discount amount. What if these calculations were already codified in Snowflake? Snowflake UDFs (User Defined Functions) make this possible. (At the time this lab was written) Snowflake  supports UDFs written in Java, JavaScript, Python, and SQL, and \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Pipelines/UDF.html?hl=udf\"\u003ETransformer for Snowflake supports\u003C/a\u003E the use of \u003Cstrong\u003EALL\u003C/strong\u003E of these. The only thing required is that your role has the \u003Cstrong\u003EUSAGE\u003C/strong\u003E privilege granted the function.\u003C/p\u003E\n","\u003Cp\u003ETo make things even better, StreamSets allows the definition of Java UDFs \u003Cem\u003Ewithin the pipeline\u003C/em\u003E. Defined at the pipeline level, a \u003Ccode\u003ECREATE OR REPLACE FUNCTION\u003C/code\u003E statement will be executed with the provided code at  pipeline runtime. Let's replicate one of the calculations from the \u003Cstrong\u003EExpression Evaluator [Calculate Unit and Total Amounts]\u003C/strong\u003E to see this in action.\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003EClick on \u003Cstrong\u003EEdit\u003C/strong\u003E above the canvas to create a new version of \u003Cstrong\u003EMy First Pipeline\u003C/strong\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClick on a blank area of the canvas to see the pipeline-level configurations in the pane below (\u003Cstrong\u003EGeneral\u003C/strong\u003E | \u003Cstrong\u003EParameters\u003C/strong\u003E | \u003Cstrong\u003EAdvanced\u003C/strong\u003E tabs). Click on the \u003Cstrong\u003EAdvanced\u003C/strong\u003E tab.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_advanced_config.png\" alt=\"Advanced Configs\"\u003E\u003C/p\u003E\n\u003Col start=\"3\"\u003E\u003Cli\u003E\n","\u003Cp\u003ETo add a UDF, click on \u003Cstrong\u003E+ Add\u003C/strong\u003E to the right of \u003Cstrong\u003EUDF Configs\u003C/strong\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EWe are going to create a simple UDF to calculate the discounted unit price, just to show another way that this logic can be applied. Enter the following configurations:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EUDF Name\u003C/strong\u003E: \u003Ccode\u003Ediscounted_unit_price_java\u003C/code\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EJava Handler Function\u003C/strong\u003E: \u003Ccode\u003Ediscounted_unit_price_java\u003C/code\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETarget Path for Jar\u003C/strong\u003E: \u003Ccode\u003E@~/\u003C/code\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EJava UDF Class Definition\u003C/strong\u003E:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-java\"\u003Epublic class sales {\n\n    public static double discounted_unit_price_java(double extended_price, double quantity, double discount_pct) {\n\n        double discounted_unit_price = (extended_price / quantity) * (1 - discount_pct);\n\n        return (discounted_unit_price);\n    }\n\n}      \n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EYour final configuration will look like this:\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_udf_config.png\" alt=\"Inline UDF Config\"\u003E\u003C/p\u003E\n\u003Col start=\"5\"\u003E\u003Cli\u003E\n","\u003Cp\u003ENow click on the \u003Cstrong\u003EExpression Evaluator [Calculate Unit and Total Amounts]\u003C/strong\u003E and add a new column with the following settings:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EOutput Field Name\u003C/strong\u003E: \u003Ccode\u003Ediscounted_unit_price_udf_java\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EExpression\u003C/strong\u003E: \u003Ccode\u003Ediscounted_unit_price_java(lineitem_extendedprice, lineitem_quantity, lineitem_discount)\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EPreview the pipeline to compare the results of \u003Ccode\u003Ediscounted_unit_price\u003C/code\u003E and \u003Ccode\u003Ediscounted_unit_price_udf_java\u003C/code\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_udf_compare_results.png\" alt=\"Compare UDF results\"\u003E\u003C/p\u003E\n\u003Col start=\"7\"\u003E\u003Cli\u003ECheck in your pipeline. You can download a completed copy of this pipeline \u003Ca href=\"https://github.com/streamsets/Pipeline-Examples/blob/main/tx4snowflake_hol/my_first_pipeline_udf.zip\"\u003Ehere\u003C/a\u003E\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EObviously this is a very simple example, but the ability to use \u003Cem\u003Eany\u003C/em\u003E Snowflake UDF from a Transformer for Snowflake pipeline makes your pipelines even more powerful!\u003C/p\u003E\n","\u003Ch2\u003E\u003Cstrong\u003EPipeline Fragments\u003C/strong\u003E\u003C/h2\u003E\n","\u003Cp\u003EIn the next part of the lab, we want to create a \u003Cstrong\u003EPivot Table\u003C/strong\u003E that can be used to support some analytics. Our goal for this portion is the lab is to create a table to support the analysis of monthly net sales by clerk. The desired output has rows for \u003Cem\u003ECLERKs\u003C/em\u003E,  columns as \u003Cem\u003EYear/Month\u003C/em\u003E, and  cell values as \u003Cem\u003ENet Sales Amount\u003C/em\u003E totals.\u003C/p\u003E\n","\u003Cp\u003EInstead of individually adding and configuring processors, we are going to use a \u003Ca href=\"https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Pipeline_Fragments/PipelineFragments_title.html\"\u003E\u003Cstrong\u003Epipeline fragment\u003C/strong\u003E\u003C/a\u003E to create a \u003Cstrong\u003EPivot Table\u003C/strong\u003E to support our analytics.\u003C/p\u003E\n","\u003Cp\u003EA \u003Ca href=\"https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Pipeline_Fragments/PipelineFragments_title.html\"\u003E\u003Cstrong\u003Epipeline fragment\u003C/strong\u003E\u003C/a\u003E is a stage or set of connected stages that you can use in other pipelines. Use them to easily add the same processing logic to multiple pipelines and to ensure that the logic is used as designed.\u003C/p\u003E\n","\u003Cp\u003EDownload the pipeline fragment from github \u003Ca href=\"https://github.com/streamsets/Pipeline-Examples/blob/main/tx4snowflake_hol/pivot_fragment.zip\"\u003Ehere\u003C/a\u003E that was created to implement this logic. This fragment has been fully parameterized, allowing you to fill in parameter values for the date, the date format to pivot on, the field you want to group by, the value to aggregate, and the table to populate. So this fragment could be used multiple times to create and populate different pivot tables by only changing the input parameters when adding it to the pipeline.\u003C/p\u003E\n","\u003Cp\u003EYou can find out more about Pipeline Fragments in \u003Ca href=\"https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Pipeline_Fragments/PipelineFragments_title.html\"\u003EStreamSets Documentation\u003C/a\u003E.\u003C/p\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EImport a Pipeline Fragment\u003C/strong\u003E\u003C/h3\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003EInstead of creating this fragment from scratch,  we will \u003Ca href=\"https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/ExportImport/Importing.html#task_dd4_d5z_rdb\"\u003Eimport\u003C/a\u003E it.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EIf you haven't already, download the pipeline fragment from \u003Ca href=\"https://github.com/streamsets/Pipeline-Examples/blob/main/tx4snowflake_hol/pivot_fragment.zip\"\u003Egithub\u003C/a\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClick \u003Cstrong\u003EBuild\u003C/strong\u003E &gt; \u003Cstrong\u003EFragments\u003C/strong\u003E in the Navigation panel, and then click the \u003Cstrong\u003EImport a Pipeline Fragment\u003C/strong\u003E option at above the fragment list or the \u003Cstrong\u003EImport\u003C/strong\u003E icon.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragments.png\" alt=\"StreamSets Fragment\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EOn the pop-up window, use the following settings:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EImport file type\u003C/strong\u003E: \u003Ccode\u003EArchive File\u003C/code\u003E (default)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ECommit Message\u003C/strong\u003E: \u003Ccode\u003Eimport\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EBrowse File\u003C/strong\u003E: use the download of \u003Cstrong\u003Epivot_fragment.zip\u003C/strong\u003E.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClick on \u003Cstrong\u003EImport\u003C/strong\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClick on \u003Cstrong\u003EClose\u003C/strong\u003E.  Upon import, note that the fragment is already in the \u003Cstrong\u003EPublished\u003C/strong\u003E state, which means that it can be immediately used in pipelines. Just keep in mind that all fragments must be published before they can be added to a pipeline.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ENow you can see the \u003Cstrong\u003EPivot Fragment\u003C/strong\u003E in the Fragment list.\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClick on the \u003Cstrong\u003EPivot Fragment\u003C/strong\u003E to open the canvas. Let's take a closer look what it is doing.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragment_overview.png\" alt=\"Fragment Overview\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EThe purpose of this fragment is to create a pivot table with a summary of net sales by month for each clerk. Since this pivot table could be created for a variety of time increments, metrics, and groupings, it uses parameters to allow users to enter a few column names once instead of having to add and configure the needed processors each time. The fragment versions can then be centrally managed, and when new versions are published, the updates can be pushed to the pipelines with the fragment in use.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EIn the configuration menu below the canvas, the fragment's parameters are visible. When using this fragment in a pipeline, these parameters can be changed for every instance of the fragment that is inserted. To reference a parameter in a processor configuration, use \u003Ccode\u003E${parameter name}\u003C/code\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThe pipeline has 3 processors and 1 Snowflake Table destination.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EParse Date Parts [\u003Cem\u003EExpression Evaluator Processor\u003C/em\u003E]\u003C/strong\u003E - This stage parses the value in the \u003Ccode\u003EDATE_COLUMN\u003C/code\u003E using the date format provided in the \u003Ccode\u003EDATE_FORMAT_PATTERN\u003C/code\u003E string.\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragment_exp_eval.png\" alt=\"Expression Evaluator\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EKeep Only Columns for Pivot [\u003Cem\u003EField Remover Processor\u003C/em\u003E]\u003C/strong\u003E - This processor limits the columns in its output using the \u003Ccode\u003EKeep Listed Fields\u003C/code\u003E option, the \u003Ccode\u003ETIME_PERIOD\u003C/code\u003E field created in the previous processor, and the columns specified as the \u003Ccode\u003EAGGREGATE_COLUMN\u003C/code\u003E and \u003Ccode\u003EGROUP_BY_COLUMN\u003C/code\u003E. The column name given for \u003Ccode\u003EGROUP_BY_COLUMN\u003C/code\u003E here determines which column the pivot table will group the rows by.\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragment_field_remover.png\" alt=\"Field Remover\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EPivot [\u003Cem\u003EPivot Processor\u003C/em\u003E]\u003C/strong\u003E - This stage is where the magic happens!\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragment_pivot.png\" alt=\"Pivot Processor\"\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EThe \u003Cstrong\u003EField to Pivot\u003C/strong\u003E is set to be the \u003Ccode\u003ETIME_PERIOD\u003C/code\u003E value created in the expression evaluator. This means that this is the value that will be turned into columns.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EAutocalculate Pivot Values\u003C/strong\u003E - When selected, StreamSets uses the distinct values from the \u003Cstrong\u003EField to Pivot\u003C/strong\u003E as the column names. When this option is not selected, the column names need to be manually entered, which is also required when writing a SQL query to create a pivot table. So if \u003Cstrong\u003EAutocalculate Pivot Values\u003C/strong\u003E is used, now there is no need to track new values appearing in the \u003Cstrong\u003EField to Pivot\u003C/strong\u003E. StreamSets will automatically take care of making sure the appropriate column names are present.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EField to Aggregate\u003C/strong\u003E - This is the value that will be aggregated by whatever function is chosen in the below \u003Cstrong\u003EAggregation\u003C/strong\u003E setting. In this instance, we are simply doing a sum since we want to generate totals for each row in each time period.\n\u003Cul\u003E\u003Cli\u003ETo put this into context, the SQL query for this pivot is shown below, and with the passage of time, the column names will need to be updated every month. The Pivot Processor, however, does this logic for you so that you can set it and forget it.\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E  SELECT * \n  FROM SOURCE_TABLE\n    PIVOT( \n      SUM(NET_SALES_AMOUNT) FOR TIME_PERIOD \n        IN ('2022-01','2022-02'\n            ,'2022-03','2022-04'\n            ,'2022-05','2022-06'\n            ,'2022-07','2022-08'\n            ,'2022-09','2022-10'\n            ,'2022-11','2022-12')\n    ) AS P;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESnowflake Target Table [\u003Cem\u003ESnowflake Table destination\u003C/em\u003E]\u003C/strong\u003E - One thing to note about this \u003Cstrong\u003ESnowflake Table\u003C/strong\u003E destination is that a parameter is being used to set the table name. This is something that can be done throughout StreamSets and makes it possible to create one pipeline that can use parameters to execute on different sources, targets, and/or using different values in the configurations.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragment_table.png\" alt=\"Target Table\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003Col start=\"2\"\u003E\u003Cli\u003EGo back to \u003Cstrong\u003EBuild\u003C/strong\u003E &gt; \u003Cstrong\u003EPipelines\u003C/strong\u003E and select the pipeline you were working on and open the canvas.\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch3\u003E\u003Cstrong\u003EUse Fragment to create Pivot Table\u003C/strong\u003E\u003C/h3\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003EIn the pipeline canvas for \u003Cstrong\u003EMy First Pipeline\u003C/strong\u003E, use the \u003Cstrong\u003EStage library panel\u003C/strong\u003E on the right. Click on the \u003Ccode\u003EA\u003C/code\u003E in the top left of the panel produce a drop-down menu with the list of object types that can be added to the canvas. Select \u003Ccode\u003EFragments\u003C/code\u003E from the list. Now select the \u003Cstrong\u003EPivot Fragment\u003C/strong\u003E. A pop-up will appear to allow you to alter the prefix that StreamSets adds to the parameters for that fragment. Leave this unchanged and click on \u003Cstrong\u003EDone\u003C/strong\u003E.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_stage_library_panel.png\" alt=\"Stage Library Panel\"\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EThe fragment will now appear on the canvas.\u003C/li\u003E\u003Cli\u003EConnect the output of \u003Cstrong\u003EOrder and Aggregate Join\u003C/strong\u003E to the input of the \u003Cstrong\u003EPivot Fragment\u003C/strong\u003E.\u003C/li\u003E\u003Cli\u003EClick on the \u003Cstrong\u003EPivot Fragment\u003C/strong\u003E. On the \u003Cstrong\u003EGeneral\u003C/strong\u003E tab below, there is a property for the \u003Cstrong\u003EFragment Commit/Tag\u003C/strong\u003E, where the version of the fragment currently in use can be seen and changed with the drop-down menu of its versions.\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_fragment_version.png\" alt=\"Choose Fragment Version\"\u003E\u003C/li\u003E\u003Cli\u003EThe \u003Cstrong\u003EFragment Parameters\u003C/strong\u003E tab contains the parameters with the updated prefixes where the parameters have the default values assigned in the fragment.\u003C/li\u003E\u003Cli\u003ENow look at the pipeline parameters by clicking on an area of blank canvas to have the general pipeline properties appear below the canvas. On the \u003Cstrong\u003EParameters\u003C/strong\u003E tab, the parameters from the fragment were automatically added to this list as well, and pre-populated with the default values. The values for the fragment parameters can be updated in either place, and the new value will automatically be populated on both tabs.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EStart a \u003Cstrong\u003EDraft Run\u003C/strong\u003E of the pipeline.  Verify the creation of the ORDER_AMOUNTS table in Snowflake with the following query (query assumes all default values were used).\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT * FROM PC_STREAMSETS_DB.PUBLIC.PIVOT_SALES_BY_CLERK LIMIT 10;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EAn archive file with the completed pipeline can be found \u003Ca href=\"https://github.com/streamsets/Pipeline-Examples/blob/85acaa98a6af565e4eb8fb2ce5e8f86829e2761f/tx4snowflake_hol/my_first_pipeline_final.zip\"\u003Ehere\u003C/a\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch2\u003E\u003Cstrong\u003ECreate a Job\u003C/strong\u003E\u003C/h2\u003E\n","\u003Ch3\u003ECreate &amp; Run a Job\u003C/h3\u003E\n","\u003Cp\u003EIn this next step, we will create a StreamSets \u003Ca href=\"https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/ControlHub/Title.html#concept_qv1_5sn_hsb\"\u003Ejob instance\u003C/a\u003E, which is the execution of a published pipeline. A job instance can be created from a pipeline or a job template.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ECheck in the pipeline.\u003C/li\u003E\u003Cli\u003EAfter entering the \u003Cstrong\u003ECommit Message\u003C/strong\u003E, click on \u003Ccode\u003EPublish and Next\u003C/code\u003E.\u003C/li\u003E\u003Cli\u003EUnder \u003Cstrong\u003EShare Pipeline\u003C/strong\u003E, select \u003Ccode\u003ESave and Next\u003C/code\u003E .\u003C/li\u003E\u003Cli\u003EThe \u003Cstrong\u003EUpdate Jobs\u003C/strong\u003E section won't have any jobs listed, so click on \u003Ccode\u003ESave and Create New Job\u003C/code\u003E\u003C/li\u003E\u003Cli\u003EA new pop-up window appears titled \u003Cstrong\u003ECreate Job Instances\u003C/strong\u003E.\u003C/li\u003E\u003Cli\u003ELeave the default job \u003Cstrong\u003EName\u003C/strong\u003E: \u003Ccode\u003EJob for My First Pipeline\u003C/code\u003E.\u003C/li\u003E\u003Cli\u003EClick on \u003Ccode\u003ENext\u003C/code\u003E.\u003C/li\u003E\u003Cli\u003EUnder \u003Cstrong\u003ESelect Pipeline\u003C/strong\u003E, the name of the pipeline will appear, in this case \u003Ccode\u003EMy First Pipeline\u003C/code\u003E as well as the pipeline version. Click on \u003Ccode\u003ENext\u003C/code\u003E.\u003C/li\u003E\u003Cli\u003ENow the \u003Cstrong\u003EDefine Runtime Parameters\u003C/strong\u003E section displays. This is where the default parameter values can be overwritten. For this case, the defaults will suffice. Click on \u003Ccode\u003ESave &amp; Next\u003C/code\u003E.\u003C/li\u003E\u003Cli\u003EUnder \u003Cstrong\u003EReview &amp; Start\u003C/strong\u003E, it indicates that the job was successfully created. Click on \u003Ccode\u003EStart &amp; Monitor Job\u003C/code\u003E.\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_create_job.png\" alt=\"Create Job\"\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003EView Running Job\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EThe system will show the pipeline canvas, but this is really a view of the job, as is indicated by the job name in the top left and the green \u003Ccode\u003EACTIVE\u003C/code\u003E indicator.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_job_running.png\" alt=\"Running Job\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThe job will complete shortly, and below the canvas, the \u003Cstrong\u003EJob Status\u003C/strong\u003E tab will show the current job status, which is now \u003Ccode\u003EINACTIVE\u003C/code\u003E. It also shows the parameter values used for that instance of the job.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClick on the \u003Cstrong\u003EHistory\u003C/strong\u003E tab below \u003Cstrong\u003EJob Status\u003C/strong\u003E, and a summary of all the job runs is displayed. Click on \u003Cstrong\u003EView Summary...\u003C/strong\u003E.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_job_history.png\" alt=\"Job History\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThe \u003Cstrong\u003EJob Metrics Summary\u003C/strong\u003E will appear and shows:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EThe number of records read and written\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EScroll down to reveal the queries generated for each destination. The Destination Id shown is not the name given to the destination, but the Instance Name that can be found on the \u003Cstrong\u003EInfo\u003C/strong\u003E tab of every pipeline component.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EScroll all the way to the bottom to see the Log history.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_job_run_summary.png\" alt=\"Job Run Summary\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThe full lists of job instances, job templates, draft runs, can also be found under the \u003Cstrong\u003ERun\u003C/strong\u003E tab on the left.\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EThere is much more that can be done with jobs, such as scheduling them or triggering job runs via the Rest API. You can find more information in the Control Hub documentation \u003Ca href=\"https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Run/Run.html\"\u003Ehere\u003C/a\u003E.\u003C/p\u003E\n&lt;!--\n### Create a Job Template\n--&gt;\n","\u003Ch2\u003E\u003Cstrong\u003ESlowly Changing Dimension\u003C/strong\u003E\u003C/h2\u003E\n","\u003Cp\u003EYou can see that the \u003Ccode\u003ENATION\u003C/code\u003E table in the \u003Ccode\u003ESNOWFLAKE_SAMPLE_DATA\u003C/code\u003E database and \u003Ccode\u003ETPCH_SF1\u003C/code\u003E schema has a region assigned to each country. Over time, the company might add or change regions as they grow. For instance, there is only an \u003Ccode\u003EAmerica\u003C/code\u003E region, but eventually it might make sense to split that into \u003Ccode\u003ENorth America\u003C/code\u003E and \u003Ccode\u003ESouth America\u003C/code\u003E. For our reporting over time, however, we may want to preserve the historical nation to region mappings, so we want to capture this in a \u003Cstrong\u003ESlowly Changing Dimension\u003C/strong\u003E.\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003EGo back to your Snowflake Worksheet and run the following \u003Ccode\u003ESQL\u003C/code\u003E queries to create the tables for this portion of the lab.  When you finish, you should have two new tables in the \u003Ccode\u003EPC_STREAMSETS_DB\u003C/code\u003E database and \u003Ccode\u003EPUBLIC\u003C/code\u003E schema: \u003Ccode\u003ENATION_DIMENSION\u003C/code\u003E and \u003Ccode\u003ENATION_UPDATES\u003C/code\u003E.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- CREATE NATION DIMENSION FOR SCD PIPELINE\nCREATE OR REPLACE TABLE PC_STREAMSETS_DB.PUBLIC.NATION_DIMENSION AS\nSELECT\n    N.N_NATIONKEY AS NATION_KEY,\n    N_NAME AS NATION_NAME,\n    R.R_NAME AS REGION_NAME,\n    '2022-01-01T00:00:00Z'::TIMESTAMP_NTZ(0) AS START_TIMESTAMP,\n    NULL::TIMESTAMP_NTZ(0)  AS END_TIMESTAMP,\n    1::INTEGER AS VERSION,\n    TRUE AS ACTIVE_FLAG\nFROM\n    SNOWFLAKE_SAMPLE_DATA.TPCH_SF1.NATION N\n    JOIN SNOWFLAKE_SAMPLE_DATA.TPCH_SF1.REGION R \n    ON N_REGIONKEY = R.R_REGIONKEY;\n\n-- CREATE A TABLE FOR CHANGE DATA\nCREATE OR REPLACE TABLE PC_STREAMSETS_DB.PUBLIC.NATION_UPDATES\n  (\n    NATION_KEY INTEGER,\n    NATION_NAME VARCHAR,\n    REGION_NAME VARCHAR,\n    EFFECTIVE_DATE TIMESTAMP_NTZ(0) \n    );\n\n-- Insert Records into change data table\nINSERT INTO PC_STREAMSETS_DB.PUBLIC.NATION_UPDATES \n  VALUES \n  (2,'BRAZIL','AMERICA','2022-10-01T00:00:00Z')\n  , (24, 'UNITED STATES','NORTH AMERICA','2022-09-01T00:00:00Z')\n  , (25, 'AUSTRALIA','ANZ','2022-08-01T00:00:00Z') ;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ECreate a new pipeline by going to \u003Cstrong\u003EBuild\u003C/strong\u003E &gt; \u003Cstrong\u003EPipelines\u003C/strong\u003E. Use the ➕ icon to create a new Transformer for Snowflake pipeline.\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_new_pipeline.png\" alt=\"Create New Pipeline 1\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClick on \u003Cstrong\u003EUse Transformer for Snowflake\u003C/strong\u003E! Name your pipeline \u003Ccode\u003EMy SCD Pipeline\u003C/code\u003E and click on \u003Cstrong\u003ENext\u003C/strong\u003E. At the next prompt, chooose \u003Cstrong\u003ESave and Open in Canvas\u003C/strong\u003E.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ECheck on the \u003Cstrong\u003EGeneral\u003C/strong\u003E and \u003Cstrong\u003EParameters\u003C/strong\u003E tabs below the pipeline canvas to make sure that your pipeline default values are populated. If not, enter them.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EAdd a \u003Cstrong\u003ESnowflake Table\u003C/strong\u003E origin to the canvas. Since we are using our default database and schema, all we need to do is add the table name to read from. Name the origin \u003Ccode\u003ENation Dimension\u003C/code\u003E, and go to the \u003Cstrong\u003ETable\u003C/strong\u003E tab to enter the following settings:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ETable\u003C/strong\u003E: \u003Ccode\u003ENATION_DIMENSION\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EAdditional Preview Where Clause\u003C/strong\u003E: \u003Ccode\u003ENATION_KEY IN (2,24,25)\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EWhile this origin is selected, use the \u003Cstrong\u003EPipeline Creation Help Bar\u003C/strong\u003E above the canvas to \u003Cstrong\u003ESelect New Processor to connect..\u003C/strong\u003E and choose \u003Ccode\u003ESlowly Changing Dimension\u003C/code\u003E. If the \u003Cstrong\u003EPipeline Creation Help Bar\u003C/strong\u003E does not appear, you can select the SCD Processor from the \u003Cstrong\u003EStage Library Panel\u003C/strong\u003E, drag it onto the canvas, and connect your origin output as its input.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EAdd a second \u003Cstrong\u003ESnowflake Table\u003C/strong\u003E origin to the canvas. Again, this table is in the default database and schema, so you only need to enter the table name to read from. Name the origin \u003Ccode\u003ENation Updates\u003C/code\u003E, and then go to the \u003Cstrong\u003ETable\u003C/strong\u003E tab to enter the following setting:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ETable\u003C/strong\u003E: \u003Ccode\u003ENATION_UPDATE\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EConnect the output of the \u003Cstrong\u003ENation Update\u003C/strong\u003E origin to the \u003Cstrong\u003ESlowly Changing Dimension\u003C/strong\u003E processor. Your pipeline should now look like the image below. It is important which number each input is assigned to. \u003Cstrong\u003ENation Dimension\u003C/strong\u003E should be input \u003Ccode\u003E1\u003C/code\u003E and \u003Cstrong\u003ENation Update\u003C/strong\u003E should be input \u003Ccode\u003E2\u003C/code\u003E. If the inputs are reversed, you can switch them by selecting the SCD processor and clicking on the button with the up and down arrows.\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_1.png\" alt=\"SCD Pipeline\"\u003E\u003C/p\u003E\n\u003Col start=\"8\"\u003E\u003Cli\u003E\n","\u003Cp\u003ENow it's time to configure the processor. Make sure that the SCD processor is selected, and on the \u003Cstrong\u003EDimension\u003C/strong\u003E configuration below, enter the following settings:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ESCD Type\u003C/strong\u003E: \u003Ccode\u003EType 2\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EKey Fields\u003C/strong\u003E[1]: \u003Ccode\u003Enation_key\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESpecify Version Field\u003C/strong\u003E: \u003Cstrong\u003E✓\u003C/strong\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EVersion Field\u003C/strong\u003E: \u003Ccode\u003Eversion\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EActive Flag Type\u003C/strong\u003E: \u003Cstrong\u003E✓\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESpecify Timestamp Fields\u003C/strong\u003E: selected\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EStart Timestamp Field\u003C/strong\u003E: \u003Ccode\u003Estart_timestamp\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EEnd Timestamp Field\u003C/strong\u003E: \u003Ccode\u003Eend_timestamp\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ECalculated Timestamp Field\u003C/strong\u003E: \u003Ccode\u003Eeffective_date\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EBehavior for New Fields\u003C/strong\u003E: \u003Ccode\u003ERemove from change data\u003C/code\u003E [default]\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ol\u003E\n\u003Cul\u003E\u003Cli\u003ELet's take a closer look at some of these settings:\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ESCD Type\u003C/strong\u003E: Currently Type 1 and Type 2 dimensions are supported.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EKey Fields\u003C/strong\u003E: You can specify the fields that uniquely identify each dimension record. Columns not included as a key or in the settings below will be considered when comparing existing dimension records to new data.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESpecify Timestamp Fields\u003C/strong\u003E:\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ECalculated Timestamp Field\u003C/strong\u003E: This option allows you to use a timestamp from the changed data set as the value for the \u003Cstrong\u003EStart Timestamp\u003C/strong\u003E on the new or updated record and the \u003Cstrong\u003EEnd Timestamp\u003C/strong\u003E on the record to be expired.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EBehavior for New Fields\u003C/strong\u003E - this setting determines what will happen when a column exists in the change data but not the dimension table.\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ERemove from change data\u003C/strong\u003E - The processor will ignore additional column(s) and drop any data from the change data set in a column that does not exist in the dimension.\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EKeep for newest records and set to null for previous records\u003C/strong\u003E - The processor will pass the new column from the change data to the rest of the pipeline. This means that if \u003Cstrong\u003EData Drift Enabled\u003C/strong\u003E is selected in your table destination, the new column will be created in the target table.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003Col start=\"9\"\u003E\u003Cli\u003E\n","\u003Cp\u003ENow we will add a \u003Cstrong\u003ESnowflake Table Destination\u003C/strong\u003E to complete the pipeline.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003EConnect the output of the \u003Cstrong\u003ESlowly Changing Dimension\u003C/strong\u003E processor to a \u003Cstrong\u003ESnowflake Table\u003C/strong\u003E destination (that needs to be added to the canvas).\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EName the destination \u003Ccode\u003ENation Dimension Destination\u003C/code\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EChoose the following settings on the \u003Cstrong\u003ETable\u003C/strong\u003E tab:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ETable\u003C/strong\u003E: \u003Ccode\u003ENATION_DIMENSION\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EWrite Mode\u003C/strong\u003E: \u003Ccode\u003EPropagate updates from Slowly Changing Dimensions\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ECreate Table\u003C/strong\u003E: Unchecked\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EData Drift Enabled\u003C/strong\u003E: \u003Cstrong\u003E✓\u003C/strong\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThe \u003Cstrong\u003ETable\u003C/strong\u003E tab should look like this:\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_destination.png\" alt=\"SCD Table Destination\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EWhat does it mean to \u003Ccode\u003EPropagate updates from Slowly Changing Dimensions\u003C/code\u003E?\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EThe \u003Cstrong\u003ESlowly Changing Dimension\u003C/strong\u003E processor produces a record for every \u003Ccode\u003EINSERT\u003C/code\u003E and \u003Ccode\u003EUPDATE\u003C/code\u003E that is needed. So for example, when a nation's region  changes, the processor generates one output that updates the fields to expire the old record and a second output for the new version of the record. Using this option on StreamSets' \u003Cstrong\u003ESnowflake Table\u003C/strong\u003E destination means that StreamSets will generate the \u003Ccode\u003EMERGE\u003C/code\u003E statement needed to process all of the updates automatically.\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EThe completed pipeline should look like this:\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_pipeline_complete.png\" alt=\"Completed SCD Pipeline.\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ENow \u003Cstrong\u003EPreview\u003C/strong\u003E the pipeline. On the \u003Cstrong\u003EPreview Configuration\u003C/strong\u003E screen, keep the options to \u003Cstrong\u003EShow Record/Field Header\u003C/strong\u003E and  \u003Cstrong\u003EWrite to Destinations\u003C/strong\u003E unselected. Let's step through the output of the preview:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EOn the \u003Ccode\u003ENation Dimension\u003C/code\u003E origin, we can see two records from the existing dimension, the records for \u003Ccode\u003EBrazil\u003C/code\u003E and the \u003Ccode\u003EUnited States\u003C/code\u003E.\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_preview_dim_origin.png\" alt=\"Dimension Origin Preview\"\u003E\u003C/li\u003E\u003Cli\u003EOn the \u003Ccode\u003ENation Update\u003C/code\u003E origin, there are three records from the change data, the records for \u003Ccode\u003EAustralia\u003C/code\u003E, \u003Ccode\u003EBrazil\u003C/code\u003E,  and the \u003Ccode\u003EUnited States\u003C/code\u003E. In this preview, the record for the \u003Ccode\u003EUnited States\u003C/code\u003E has a new region, the \u003Ccode\u003EBrazil\u003C/code\u003E record is unchanged, and there is a new record to add \u003Ccode\u003EAustralia\u003C/code\u003E.\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_preview_updates_origin.png\" alt=\"Update Origin Preview\"\u003E\u003C/li\u003E\u003Cli\u003EOn the \u003Ccode\u003ESlowly Changing Dimension\u003C/code\u003E processor, there are 5 input records and only 3 output records. Let's step through each one.\n\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_preview_scd_processor.png\" alt=\"SCD Processor Preview\"\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENation_Key\u003C/strong\u003E \u003Ccode\u003E2\u003C/code\u003E: \u003Ccode\u003EBrazil\u003C/code\u003E\u003C/p\u003E\n","\u003Cp\u003EThere was no change to this record in the update data, so no action needs to be taken and the record is ignored\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENation_Key\u003C/strong\u003E \u003Ccode\u003E24\u003C/code\u003E: \u003Ccode\u003EUnited States\u003C/code\u003E\u003C/p\u003E\n","\u003Cp\u003EThe update data contains a new region, \u003Ccode\u003ENorth America\u003C/code\u003E, versus the existing dimension record that has \u003Ccode\u003EAmerica\u003C/code\u003E as the region. The processor then generates 2 records.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E1 - Expires old record. The original dimension record is updated to set the \u003Ccode\u003EACTIVE FLAG\u003C/code\u003E to \u003Ccode\u003EFALSE\u003C/code\u003E and set the \u003Ccode\u003EEND_TIMESTAMP\u003C/code\u003E to the \u003Ccode\u003EEFFECTIVE_DATE\u003C/code\u003E of the updated record. The \u003Ccode\u003E__SS_META_OPERATION\u003C/code\u003E and \u003Ccode\u003E__SS_META_KEYS\u003C/code\u003E are columns generated by StreamSets that will NOT appear in the final data, but are metadata that the destination processor uses.\u003C/li\u003E\u003Cli\u003E2 - Generates new record. This record contains the new region value. The version of the record is incremented from the old record, the \u003Ccode\u003EACTIVE_FLAG\u003C/code\u003E is set to \u003Ccode\u003ETRUE\u003C/code\u003E, and the \u003Ccode\u003ESTART_TIMESTAMP\u003C/code\u003E to the value of the \u003Ccode\u003EEFFECTIVE_DATE\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENation_Key\u003C/strong\u003E \u003Ccode\u003E25\u003C/code\u003E: \u003Ccode\u003EAustralia\u003C/code\u003E\nThis record does not exist in the current dimension table, so a new row will be created as Version 1 of the record.\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EClose the preview. Do a \u003Cstrong\u003EDraft Run\u003C/strong\u003E of the pipeline and go back to Snowflake and continue with the previous worksheet and run the following SQL statement:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT *\nFROM  PC_STREAMSETS_DB.PUBLIC.NATION_DIMENSION\nWHERE NATION_KEY IN ('2','24','25')\nORDER BY NATION_KEY, START_TIMESTAMP;\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EThe query results show the active and inactive dimension records for the three example nations that were processed by the pipeline as show below.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_scd_results.png\" alt=\"SCD Query Results\"\u003E\u003C/p\u003E\n\u003Col start=\"13\"\u003E\u003Cli\u003EYou can download a completed version of the pipeline \u003Ca href=\"https://github.com/streamsets/Pipeline-Examples/blob/main/tx4snowflake_hol/scd_pipeline_final.zip\"\u003Ehere\u003C/a\u003E.\u003C/li\u003E\u003C/ol\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EConclusion\u003C/h2\u003E\n","\u003Cp\u003EThank you for participating in this Hands on Lab!\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/Streamie_small.png\" alt=\"Streamie\"\u003E\u003C/p\u003E\n","\u003Ch3\u003EWhat We Covered\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003EHow to create your own StreamSets instance using Snowflake Partner Connect\u003C/li\u003E\u003Cli\u003EHow to create, preview, and run Transformer for Snowflake pipelines\u003C/li\u003E\u003Cli\u003EHow to use fragments to minimize your development efforts\u003C/li\u003E\u003Cli\u003EHow to process data in a Slowly Changing Dimension\u003C/li\u003E\u003Cli\u003EHow to create and execute jobs\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003EReady to learn more?\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"https://streamsets.com/products/schedule-demo/\"\u003ESchedule a live Demo\u003C/a\u003E that includes more on StreamSets including the Data Collector engine!\u003C/li\u003E\u003Cli\u003EDownload the \u003Ca href=\"https://go.streamsets.com/snowflake-data-engineers-handbook.html\"\u003EData Engineers Handbook for Snowflake\u003C/a\u003E\u003C/li\u003E\u003Cli\u003EWatch the webinar \u003Ca href=\"https://go.streamsets.com/snowpark-first-look.html\"\u003EEnd-to-End Data Integration for Snowflake with Snowpark\u003C/a\u003E\u003C/li\u003E\u003Cli\u003EGo to \u003Ca href=\"https://academy.streamsets.com/\"\u003EStreamSets Academy\u003C/a\u003E for \u003Cstrong\u003Efree\u003C/strong\u003E self paced lessons to learn more!\u003C/li\u003E\u003C/ul\u003E"],"description":"","title":"StreamSets' Transformer for Snowflake: Hands on Lab",":type":"snowflake-site/components/contentfragment","isDeveloperGuidesPage":false,":items":{},":itemsOrder":[],"elements":{"quickstartArticleBody":{"dataType":"string","value":"\u003C!-- ------------------------ --\u003E\r\n## Overview \r\n\r\nStreamSets is a data integration platform for the modern data ecosystem, empowering data engineers to build, run, monitor, and manage smart data pipelines in one place. **Transformer for Snowflake** is a fully hosted service embedded within the StreamSets DataOps Platform. It uses the Snowpark Client Libraries to generate SnowSQL queries that are executed natively in Snowflake, allowing your data to remain in your Snowflake Data Cloud.\r\n\r\nTransformer for Snowflake is just one part of the StreamSets DataOps Platform, which consists of:\r\n\r\n  1. **Control Hub** - to manage and monitor smart data pipelines at scale, providing real time visibility into operations.\r\n  2. **Data Collector** -  designed for streaming, CDC and batch ingest.\r\n  3. **Transformer** - a family of engines to do heavy duty transformation ETL, ELT and ML work, executing natively on modern data platforms such as Snowflake and Spark.\r\n        \r\nData Collector and Transformer (for Spark) engines can be deployed on-premises (VM or containers), in a customer’s VPC, and/or in the customer’s namespace in a public cloud. The engines, and therefore the data accessed by the engines, remains in the customer’s environments across all of their on-prem, hybrid, & multi-cloud environments.\r\n\r\nThis lab shows you how to get started using **Transformer for Snowflake** as a part of the DataOps Platform. You can read more about pipelines in Transformer for Snowflake [here](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/GettingStarted/WhatIsSnowflake.html#concept_srx_qxm_4rb).\r\n\r\n### **Prerequisites**\r\n- A trial [Snowflake](https://trial.snowflake.com/?owner=SPN-PID-26749) account with `ACCOUNTADMIN` privileges. \r\n    - It is recommended to create a new trial account for this lab, using an email address that is not tied to an existing a StreamSets organization.\r\n- [optional] [Download](https://github.com/streamsets/Pipeline-Examples/blob/359a57b4e5f486ba5c094a3380e4a618662a1657/tx4snowflake_hol/SNOWFLAKE_WORKSHEET.sql) the sql used in this lab [here](https://github.com/streamsets/Pipeline-Examples/blob/359a57b4e5f486ba5c094a3380e4a618662a1657/tx4snowflake_hol/SNOWFLAKE_WORKSHEET.sql). Individual SQL statements are provided to copy/paste throughout the lab.\r\n\r\n### **What You’ll Learn** \r\nYou will learn how to build pipelines using Transformer for Snowflake that are executed natively in your Snowflake Data Cloud, including:\r\n- How to use Partner Connect to create a StreamSets Organization.\r\n- How to create pipelines that dynamically generate your SQL queries at pipeline runtime.\r\n- How to leverage User Defined Functions within your pipelines.\r\n- How to use Fragments to share logic across multiple pipelines.\r\n- How to create and run Jobs to control pipeline execution. \r\n- How to use the Slowly Changing Dimension processor.\r\n\r\n### **What You’ll Build**\r\n\r\nThe lab uses the **TPCH_SF1** dataset pre-populated in your Snowflake account to transform raw retail data into consumable orders information that can support business analytics, including: \r\n- A pipeline that renames columns, joins data, performs calculations, resuses portions of existing pipelines, and reshapes the data to populate multiple tables with raw data, summary data, and pivoted data.\r\n- A pipeline to process a Slowly Changing Dimension. \r\n\u003C!-- You can import the final products to compare against [placeholder for pipeline export(s)](https://github.com/streamsets/Pipeline-Examples/blob/fb4240adc106ba5fd14a680b6eb82ab8b2c27555/tx4snowflake_hol/). --\u003E\r\n\r\n## **Transformer for Snowflake**\r\n\r\n### **What does it do?**\r\n\r\nTransformer for Snowflake accelerates the development of data pipelines by going beyond the construction of basic SQL with a drag and drop UI. Snowpark enables StreamSets to construct the SnowSQL queries at the pipeline runtime, allowing pipeline definitions to be more flexible than static SnowSQL queries. StreamSets also provides processors that combine the logic for common use cases into a single element to drop on your canvas. \r\n\r\n### **How does it work?**\r\nTransformer for Snowflake is a hosted service embedded within the StreamSets DataOps Platform. It uses the Snowpark Client Libraries to generate SnowSQL queries that are executed in Snowflake. How does that happen?\r\n\r\n  - You build pipelines in the StreamSets design canvas.\r\n  - Upon pipeilne execution, StreamSets builds a Directed Acyclic Graph\r\n([DAG](https://en.wikipedia.org/wiki/Directed_acyclic_graph)).\r\n  - StreamSets uses the DAG and the Snowpark Client Libraries to generate SnowSQL.\r\n  - StreamSets sends the SnowSQL to Snowflake.\r\n  - Snowflake executes the SnowSQL in the Warehouse of your choice. \r\n\r\n  ![How_Does_It_Work](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/how_does_it_work.png)\r\n\r\n## **Getting Started with Snowflake**\r\n\r\n### **Create Snowflake Trial Account**\r\n1. If you haven't already, create a Snowflake trial Account using this [link](https://trial.snowflake.com/?owner=SPN-PID-26749). \r\n    - Fill out the form and click **Continue**.  \r\n    - Choose a Snowflake edition, cloud provider, and region for that provider. For the purposes of this lab, any of the providers or editions are fine to select. \r\n    - After checking the box to agree to the terms, click **Get Started**.\r\n    - Check your email inbox for a message from Snowflake that contains the link to **Activate** your trial. Click that link.\r\n    - Specify your username and password, and be sure to save these somewhere secure.\r\n\r\n2. You can find a detailed walk through of the Snowflake UI [here](https://docs.snowflake.com/en/user-guide/ui-snowsight-gs.html#getting-started-with-snowsight). This lab will use the Snowsight UI (new Snowflake UI) exclusively and all instructions for the following steps in Snowflake are for that UI. You can use the Classic UI, but the Snowflake resources will be located in different places. \r\n\r\n### **Confirm Existence of Sample Data**\r\n3. This lab utilizes the ``SNOWFLAKE_SAMPLE_DATABASE`` that is included by default as a part of Snowflake accounts. \r\n    - Select the **Worksheet** tab on the left-hand menu, and then click the blue ``+ Worksheet`` button in the top right of the screen.\r\n\r\n      ![Snowflake Worksheet](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_worksheet.png) \r\n\r\n    - With the new worksheet open:\r\n        - Click on the **Databases** tab on the left-hand menu.\r\n        - You should see the **SNOWFLAKE_SAMPLE_DATA** database in the list of objects.\r\n        \r\n          ![Snowflake Sample DB](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_sample_database.png)\r\n\r\n    - If  **SNOWFLAKE_SAMPLE_DATA** is present, proceed on to the next section, **Use Partner Connect to Create a StreamSets Organization**.\r\n\r\n### If **SNOWFLAKE_SAMPLE_DATA** is not present: \r\n\r\n  - You may have removed it from your account. Run the following command in your worksheet to restore it:\r\n  \r\n    ```sql\r\n      CREATE OR REPLACE DATABASE SNOWFLAKE_SAMPLE_DATA \r\n        FROM SHARE SFC_SAMPLES.SAMPLE_DATA;\r\n    ```\r\n\r\n  - You should now see the database as one of the objects. Click on  **SNOWFLAKE_SAMPLE_DATABASE** to reveal the schemas it contains, including ``TPCH_SF1``, which will be used in this lab. You can click on **TPCH_SF1** and then **Tables** to see the included tables.  \r\n\r\n  - In your worksheet, run the following query:\r\n    \r\n    ```sql\r\n      CREATE  WAREHOUSE  IF NOT EXISTS TRIAL_WH; \r\n      USE WAREHOUSE TRIAL_WH;\r\n\r\n      SELECT *\r\n      FROM SNOWFLAKE_SAMPLE_DATA.TPCH_SF1.ORDERS\r\n      LIMIT 10;\r\n    ```\r\n    \r\n  - Snowflake requires a warehouse to execute most queries, which is why the SQL contains the command to create a warehouse (size ``XSMALL`` by default). You can find out more about Snowflake warehouses in their [documentation](https://docs.snowflake.com/en/user-guide/warehouses-overview.html).\r\n\r\n  - If the query returns results, you are ready to proceed! If not, check your query syntax to confirm it is correct.  \r\n\r\n  - Now it's time to set up your StreamSets account!\r\n\r\n## **Use Partner Connect to Create a StreamSets Organization**\r\n\r\nWe’ll use [Snowflake Partner Connect](https://docs.snowflake.com/en/user-guide/ecosystem-partner-connect.html) to set up a StreamSets organization that will  auto-populate [Snowflake Credentials](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/GettingStarted/MyAccount.html#concept_d2k_yld_gsb) and [Snowflake Pipeline Default Settings](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/GettingStarted/MyAccount.html#concept_ofy_mld_gsb) so you can start building pipelines right away.\r\n\r\nNote: All steps assume you are using the SnowSight UI.\r\n\r\n1. After logging into your Snowflake Trial instance, look in the top left corner of the UI to confirm that your active role is **ACCOUNTADMIN** . If it is not:\r\n   - select the drop down next to your user name\r\n   - click on **Switch Role**\r\n   - select **ACCOUNTADMIN**\r\n\r\n  ![Set your Role to AccountAdmin](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_set_role.png)\r\n\r\n2. On the left menu, expand the **Admin** section and select **Partner Connect**.\r\n\r\n  ![Partner Connect](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/partner_connect_admin.png)\r\n\r\n3. Enter ``StreamSets`` in the search bar and click on the StreamSets tile.\r\n  \r\n  ![Partner Connect TileSearch](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/partner_connect_search.png)\r\n\r\n4. After selecting the StreamSets tile, the following window will appear.  It contains information about the Database, Warehouse, User, Password and Role that will be created in Snowflake. Select **Connect**.\r\n\r\n  ![Partner Connect Grants](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/partner_connect_grants.png)\r\n\r\n5. A message will appear to indicate that the StreamSets account was created. Select **Activate**.\r\n\r\n  ![Activate Account](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/partner_connect_account_created.png)\r\n\r\n6. Now you will be taken to StreamSets to finish setting up your StreamSets Organization. You can create a password for your Streamsets acccount or use Single Sign On through Google or Microsoft.\r\n\r\n  ![Create User](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_create_password.png)\r\n\r\n7. Finish creating your StreamSets organization by choosing the region that is closest to you and updating the name, if you prefer. The default name uses the same prefix as your Snowflake Trial instance. Check the boxes to agree to the Terms of Service and acknowledge the Privacy Policy. Click on **Agree & Continue**.\r\n\r\n  ![Name Org and Choose Location](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_org_name_and_location.png)\r\n\r\n8. If the updated privacy policy message appears, go ahead and dismiss it.\r\n\r\n9. Now the dialog should appear asking about ingesting data into Snowflake. We do not need to do that because we are going to use data already loaded in the Snowflake Sample Database. Select **Create Transformer for Snowflake Pipeline** to be taken to the Pipeline Design Canvas.\r\n\r\n  ![Create first pipeline](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_create_first_pipeline.png)\r\n\r\n**Congratulations!** You now have your very own StreamSets Organization!\r\n\r\n#### If you were not able to finish setting up your organization and navigated away, you can either:\r\n  - Go back and select StreamSets' partner connect tile in Snowflake, then select **Launch**.\r\n  - Use the link that was sent to the email address for your Snowflake account. Be sure to check your Spam folder if you don’t see it.\r\n \r\n## **Overview of the DataOps Platform UI**\r\n\r\nBefore we get started building a pipeline, let's look at how to navigate Control Hub, a web-based user interface (UI) for building, managing, and monitoring all of your pipelines. (Note: Control Hub displays timestamps using the browser time zone determined by your local operating system.)\r\n\r\nThe Control Hub UI includes the following general areas and icons. You can find more details in the [documentation](https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/GettingStarted/ControlHubUI_Next.html#concept_ywv_x3d_lpb):\r\n\r\n  ![Control Hub UI](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ControlHubUI.png)\r\n\r\n  1. **Navigation panel**: lists the areas that you can manage within Control Hub. Displays one of the following views based on your selection in the navigation panel:\r\n      - **Learn**: access tutorial steps and videos to help you get started with StreamSets.\r\n      - **Set Up**: create and manage environments, deployments, engines, and connections (_Not applicable to Transformer for Snowflake_)\r\n      - **Build**: design and manage **fragments** and **pipelines**.\r\n      - **Run**: create and manage job templates and instances, schedule tasks, and view draft runs.\r\n      - **Monitor**: access the operations and topologies dashboards and much more.\r\n      - **Manage**: administer your organizatio,  create and manage users/groups, view audit entries to monitor logins and actions, and generate and manage credentials for use with the Control Hub REST API.\r\n  2. **View**: displays one of the areas listed above based on your selection in the navigation panel.\r\n  3. **Global search**: search for Control Hub objects by name, such as pipelines, fragments, and jobs.\r\n  4. **Filter**: filter the information displayed in the selected view. \r\n  \r\n  - ![Toggle Nav](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/icon_ToggleNavigation.png) Navigation panel icon - Toggles the display of the navigation panel.\r\n\r\n  - ![My Account](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/icon_MyAccount_Next.png) My Account icon - Displays your account and browser settings. Allows you to invite other users to your organization or to sign out.\r\n\r\n  - ![help](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/icon_Help.png) Help icon - Provides access to the online help and shows help tips. Also provides documentation for the Control Hub REST API.\r\n\r\n## **Create and Run a Simple Pipeline**\r\n\r\nThe pipeline we build in this portion of the lab is based on the sample Sales data in the ``SNOWFLAKE_SAMPLE_DATA`` database. It contains tables with Orders and Order Line Items. We would like to be able to report from one table with a combination of the data from both tables. We are going to step through the pipeline build, noting some of the StreamSets features that make pipeline and development easier.\r\n\r\n\r\n### **Start Building**\r\n\r\n1. Using the tabs on the left, select **Build \u003E Pipelines**. If there is already a **My First Pipeline** in the pipeline list, click on it and go ahead to the next step. \r\n\r\n    ![Build Pipeline Menu](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_build_pipeline_menu.png)\r\n\r\n  - If there is no pipeline listed:\r\n    \r\n    - Click the plus (**+**) symbol to create a new pipeline.\r\n    - On the pop-up that appears, select **Use Transformer for Snowflake**. If you were creating a pipeline that used one of our other engines, you would need to **Create a Deployment** to set up those engines, but since we are using serverless Transformer for Snowflake, that is unnecessary.\r\n    \r\n      ![Tx 4 Snowflake Pipeline](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_tx4snowflake_pipeline.png)\r\n\r\n    - A new window will appear to create your pipeline. \r\n        \r\n        - Give your pipeline a name and add a description (optional).\r\n        - **Engine Type**: ``Transformer for Snowflake`` is pre-selected \r\n        - Select **Next**.\r\n\r\n          ![Pipeline Settings](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_tx4snowflake_pipeline_settings.png)\r\n    \r\n    - If you wanted to share your pipeline with other users or groups in your Organization, this is where you would do that. For now, select **Save & Open in Canvas**.\r\n\r\n      ![Pipeline Share Settings](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_share_pipeline_settings.png)\r\n\r\n2. Now you will see the empty design canvas, with key items on the canvas explained in more detail below. Additional details about the pipeline canvas can be found [here](https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Pipelines/PipelineCanvas.html#concept_zj5_nj4_mpb) in the StreamSets documentation.\r\n\r\n    ![Canvas Guide](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_canvas_guide.png)\r\n   \r\n    - 1 - **Pipeline Canvas**: Displays the pipeline and used to configure the pipeline data flow.\r\n    - 2 -  **Pipeline Creation Help Bar**- Offers lists of stages to help complete the pipeline and can be used to connect a stage to an open node. You can also add a stage between linked stages by clicking the link between the two.\r\n    - 3 - **Properties Panel**: Displays the properties of the pipeline or selected stage when you configure a pipeline. Click on empty canvas   space to see the properties of the entire pipeline.\r\n    - 4 - **Selected stage pop-up menu** - Displays the icons for commands that you can apply to the selected stages. \r\n    - 5 - **Stage library panel** - Used to add stages to the pipeline. You can drag a stage to a location on the canvas or click a stage to add it to the end of the pipeline.\r\n   \r\n3. Click on any blank space in the canvas to view the pipeline properties in the panel below.\r\n  \r\n    - On the **General** tab, there are 5 properties directly related to Snowflake. These are the **Snowflake Account URL, Warehouse, Database, Schema**, and **Role**. When your pipeline is executed, these properties are sent to Snowflake to determine what resources the pipeline uses to execute. As shown below, each of these is pre-populated with a StreamSets pipeline parameter. Those are written with the ``${parameter_name}`` syntax.  \r\n\r\n  ![General Pipeline Properties](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_canvas_general_properties.png)\r\n\r\n  - Now select the **Parameters** tab. This is where you can see the values that each of these parameters are given. By default, the Database, Warehouse, and Role that your pipelines point to are the ones generated by the Partner Connect Integration. The pipeline settings also points to the ``PUBLIC`` schema.  \r\n\r\n    ![Pipeline Parameters](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_canvas_pipeline_parameters.png)\r\n\r\n### **Create a Source**\r\n\r\nThis pipeline will use data prepopulated in the ``SNOWFLAKE_SAMPLE_DATA`` database, in schema ``TPCH_SF1``. It will use data from the ``ORDERS`` and ``LINEITEM`` tables.\r\n\r\n  ![Tables Used](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_tables_used.png)\r\n\r\n1. Using the **Pipeline Creation Help Bar**, add a **Snowflake Table Origin** to the canvas. Next to Origin Missing, select ``Snowflake Table`` from the drop-down menu.\r\n\r\n  ![Add Origin](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_add_origin_1.png)\r\n\r\n2. Click on the new Origin if it is not already selected, and give it a meaningful name. Since this Origin will read the data from the ``ORDERS`` table, name it ``Orders``.\r\n\r\n  ![Name Origin](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_name_origin_1.png)\r\n\r\n3. On the **Table** tab of the properties panel, we will tell the pipeline where this table is located. Since the data we are reading is in a Read-Only database, that database cannot be the pipeline’s default. In this case we need to override the database and schema. To do this, select **Specify Database**, which makes the options for the Database and Schema appear. Use the following values to configure this origin, and see the finished configuration in the image below:\r\n\r\n    - **Database**: ``SNOWFLAKE_SAMPLE_DATA``\r\n    - **Schema**: ``TPCH_SF1``\r\n    - **Table**: ``ORDERS``\r\n\r\n  ![Override DB and Specify Table](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_specify_database_table.png)\r\n  \r\n  - The origin is created and configured, but note that there are some additional options further down on the **Table** tab. There is an option to limit the number of columns read from the table, add a where clause to filter down to a subset of the data read from the table, and the unique StreamSets feature to add a Preview clause.  We’ll talk more about this later.\r\n  - Now the canvas has one origin, which is showing the validation error **VALIDATION 0011 Stage has open output streams**, indicated by the yellow triangle.\r\n      \r\n  ![Validation Error](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_validation_error.png)\r\n    \r\n  4. Transformer for Snowflake pipelines need to have a final destination, so as a temporary fix, add a **Trash** Destination. \r\n      - What is a [Trash](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/OriginsDestinations/Trash.html#concept_ddd_dl1_yrb) destination? It is  a placeholder destination so you can [preview pipeline processing](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Preview/DataPreview.html#concept_slb_bjb_dsb) as you develop the pipeline. No tables will be permanently written to Snowflake when this pipeline is executed or previewed.      \r\n      - As when adding an origin, there are multiple ways to do this, but this time we are going to use the **Stage Library Panel**. \r\n      - If the library panel is not already expanded, click on the hamburger icon ![Stage Menu](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_hamburger_stage_menu.png) in the upper right corner of the canvas.\r\n      - Enter ``Trash`` in the search bar, and click on the stage.\r\n      - Now a Trash destination stage should appear on the canvas. \r\n\r\n6. The canvas might be a little messy now, with stages not placed very logically, so let’s Auto-Arrange it to clean it up. Above the canvas, on the right side is the **Auto-Arrange** icon. Click on it to rearrange the processors as shown below.\r\n  \r\n  ![Auto-Arrange](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_autoarrange.png)\r\n\r\n  ![Unconnected Stages](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_2_unconnected_stages.png)\r\n\r\n6. Now we need to connect the source and destination to complete this first iteration of the pipeline. Select the **Orders** Origin and click on the output node icon. Draw a line to the input node icon on the Trash stage as shown below.\r\n  \r\n  ![Connect 2 Stages](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_connect_stages.png)\r\n\r\n### **Preview the Pipeline**\r\n\r\nNow preview the pipeline results for the first time. Data Preview shows the input and output of each origin, processor, and destination. Find out more about Preview in the [documentation](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Preview/DataPreview.html?hl=preview). \r\n\r\n1. In order to preview the pipeline results, select the Preview icon (eye) located above the canvas on the right.\r\n\r\n  ![Preview Icon](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_preview_button.png)\r\n\r\n2. A pop-up will now appear to configure previews. More details about preview configuration settings can be found [here](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Preview/DataPreview.html#task_szc_z5l_nsb), but the important things to note are: \r\n    - **Preview Batch Size**: the number of records shown at each origin, processor, or destination.\r\n    - **Write to Destinations**: if a Snowflake table is the destination, selecting this option means that the pipeline would actually write only the previewed data to the target table(s).\r\n  \r\n  ![Preview config](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_preview_config.png)\r\n\r\n3. Click **Run Preview**.\r\n\r\n4. At this time, Transformer for Snowflake is using Snowpark to generate the queries for this pipeline, and sending them over to Snowflake. Keep in mind that if the specified warehouse is currently suspended, it may take an extra moment to generate the preview results while it is resumed.\r\n\r\n5. There may be updates about the status of the pipeline preview in the properties panel as shown below.\r\n\r\n  ![preview status](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_preview_status.png)\r\n\r\n6. When the preview is ready, a screen appears that looks similar to this: \r\n\r\n  ![Preview Contents](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_preview_contents.png)\r\n\r\n  - By default, the Orders origin stage is selected, and the properties window on the bottom shows 10 records from the ORDERS table, including the column name, data type, and value for every column in the record. \r\n\r\n  - To make it easier to read, switch the records to a table view by selecting the table icon above the records \r\n\r\n  ![Table Icon](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_preview_table.png)\r\n\r\n7. To close the preview and return back to the design mode, select **Close Preview** in the top right of the canvas. \r\n  \r\n  ![Close Preview](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_close_preview.png)\r\n\r\n\r\nNow let's start transforming the data. The immediate goal is create a table in Snowflake that joins the Order and Line Item data.\r\n\r\n### **Begin Data Transformation by Renaming Columns**\r\n1. The first step is to rename the columns read from the ``ORDERS`` table.\r\n\r\n2. The data preview showed that the Order column names all begin with O_. Let's clean the names up by removing that prefix.\r\n\r\n3. Make sure the preview is closed, and click on the arrow connecting the **Orders** origin and **Trash** destination. \r\n\r\n    ![Add Renamer](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_add_renamer.png)\r\n\r\n  - The **Pipeline Creation Help Bar** should appear after selecting the line connecting the two stages.\r\n    - On the drop-down menu, choose the Field Renamer processor.\r\n    - _If the Pipeline Creation Help Bar does **not** appear_:\r\n      - use the **Stage Library Panel** on the right, search for ``Field Renamer``, and click on it. This should add a **Field Renamer** processor to the canvas. \r\n      - delete the connection between **Orders** and **Trash**\r\n      - connect **Orders** to the **Field Renamer**\r\n      - connect **Field Renamer** to **Trash**\r\n  - Now the pipeline should look like this:\r\n  \r\n    ![Orders Renamer Trash](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_orders_renamer_trash.png)\r\n\r\n4. Open the **Field Renamer** processor by clicking on it. Its properties should appear below the canvas:\r\n\r\n  ![Field Renamer Properties](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_field_renamer_properties_1.png)\r\n\r\n  - Name the stage ``Remove Column Name Prefixes`` on the General tab.\r\n  - Select the **Rename** tab.\r\n    - Select the **Rename Type** drop down menu. \r\n    - There are multiple options here, and since we know that we want to remove the ``O_`` prefix from all fields, select ``Remove prefix from all fields``. \r\n    - Leave the **Case Insensitive** setting selected, so we can remove both upper and lower cased column names, and enter ``O_`` for Remove String. \r\n\r\n  ![Renamer Options](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_renamer_rename_options.png)\r\n \r\n  ![Renamer Final Config](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_renamer_final_config.png)\r\n\r\n### **Write to a Snowflake Table**\r\n\r\nNow replace the Trash stage with a real destination in Snowflake.\r\n\r\n1. Click on the Trash stage and delete it using the trash can icon on the pop up menu.\r\n\r\n  ![Delete Trash](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_delete.png)\r\n\r\n2. Select the **Field Renamer [Remove Column Name Prefixes]** processor, and the **Pipeline Creation Help Bar** should appear. Choose the ``Select New Destination to connect…`` menu and choose ``Snowflake Table``.\r\n\r\n  ![Add Snowflake Destination](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_add_destination.png)\r\n\r\n3. With the new Snowflake Table destination selected update the following settings:\r\n    - **General** tab \u003E **Name**: ``Order Line Items ``\r\n    - **Table** tab \u003E \r\n      - **Table**:  ``ORDER_LINE_ITEMS``\r\n      - **Write Mode**: ``Overwrite Table``\r\n      - **Overwrite Mode***: ``Drop Table``\r\n      - **Create Table**: **✓**\r\n    \r\n      ***Note**:Table destinations have 4 different write modes which are explained [here](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/OriginsDestinations/SnowflakeTable-D.html#concept_wdr_fzy_prb).\r\n\r\n4. Preview the pipeline again by clicking on the preview icon above the canvas. When the Preview Configuration Window appears, change the **Preview Batch Size** to ``1``.\r\n\r\n5. When the preview finishes processing, select the **Field Renamer [Remove Column Name Prefixes]** to see the results. All of the _“O_”_ prefixes were removed from the column names. This is just one example of how Transformer for Snowflake pipelines dynamically generate SQL at pipeline runtime. The **Apply Functions**, **Field Remover**, **Field Renamer**, and **Field Type Converter** processors all allow you to dynamically specify column names based on patterns. This means that even as the data evolves over time, your pipelines won't break if a new column appears. For example, if a pipeline has an **Apply Functions** processor configured to trim all strings to remove extra characters, and specifies the columns to operate using the pattern ``.*``, no matter what columns are named, the ``TRIM`` function will be applied. This works for a variety of String, Numeric, DateTime, and User Defined functions.\r\n\r\n  ![Preview Renamer](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_renamer_preview.png) \r\n\r\n6. Select the **Table Destination [Order Line Items]** stage to see the new column names passed to the destination.\r\n\r\n7. Close the preview.\r\n\r\n### **Run the Pipeline**\r\n1. Now that the pipeline’s behavior was verified using preview, run the pipeline on the entire data set.\r\n2. In the toolbar above the canvas, there is a **Draft Run** button on the far right. Choose **Start Pipeline** from the drop down that appears when clicking on it.\r\n\r\n    - In StreamSets, a [Draft Run](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/ControlHub/Title.html#concept_snq_pkg_4tb) allows you to execute a pipeline that is still in development and not yet published. Running a _published_ version of a pipeline is considered a StreamSets [Job](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/ControlHub/Title.html#concept_qv1_5sn_hsb). Jobs can be scheduled, run with different parameter values, and made into templates. See the [documentation](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/ControlHub/Title.html#concept_qv1_5sn_hsb) for more details.\r\n\r\n  ![Draft Run](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_draft_run.png)\r\n\r\n3. When the run completes, the job status in the properties panel will change to ``INACTIVE``, and the **Realtime Summary** tab will display the total number of records read and written. Click on the **Draft Run History** tab to view more details.\r\n\r\n  ![Draft Run Complete](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_draft_run_complete.png)\r\n\r\n4. On the **Draft Run History** tab, you can see the history of draft runs for the pipeline. On the most recent run, click on **View Summary**.\r\n\r\n  ![Draft Run History](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_draft_run_history_1.png)\r\n\r\n5. In the pop-up window that appears, the Job Metrics Summary appears at the top, and **Scroll Down** to view the Snowflake Queries that are generated to populate the target table(s) as well as some logging.\r\n\r\n  ![Job Summary 2](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_job_summary_2.png)\r\n\r\n6. Now let's take a look at what is happening in Snowflake. Go back to your Snowflake account, and under the **Activity** menu on the left, select **Query History**. By default, there will be a filter on your user. Since a new user was created for the Partner Connect integration, you will need to remove the User filter from the top right of the **Query History** window.  \r\n\r\n    Now Look for the ``CREATE OR REPLACE TABLE`` statement in the query history, and you can click on the SQL text to see the query Snowpark generated to create this table in Snowflake. Since we chose the ``Overwrite Mode`` of ``Drop Table``, that is why a ``CREATE OR REPLACE TABLE`` statement is used. If we had selected the ``Truncate`` option, we would see a ``TRUNCATE`` statement followed by an ``INSERT`` statement that leverages the same subquery.\r\n\r\n  ![Snowflake Query History](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_query_history_1.png)\r\n\r\n7. Lastly, go to the **Worksheets** tab in Snowflake. Click on the **plus** (**+**) icon to create a new worksheet. Use the SQL below to run a couple queries on the table that was just created to see the number of rows in the new table as well as a sample of ten rows. Notice that the new table has the updated column names with the prefix removed. \r\n\r\n    **Note**: If you named your tables differently than suggested, you will need to modify the query.\r\n\r\n    ### SQL\r\n    ```sql\r\n    USE WAREHOUSE PC_STREAMSETS_WH;\r\n    USE ROLE PC_STREAMSETS_ROLE;\r\n    USE DATABASE PC_STREAMSETS_DB;\r\n    USE SCHEMA PUBLIC;\r\n\r\n    SELECT COUNT(*) FROM ORDER_LINE_ITEMS;\r\n    SELECT * FROM ORDER_LINE_ITEMS LIMIT 10;\r\n    ```\r\n\r\n- Now that we successfully created and executed this simple pipeline, go back to StreamSets to continue developing. \r\n- Want to download and import a copy of the pipeline build so far? Download it from [github](https://github.com/streamsets/Pipeline-Examples/blob/main/tx4snowflake_hol/my_first_pipeline_v1.zip). Later in the lab, we'll go over the simple task of importing object, but you can find the documentation [here](https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/ExportImport/Importing.html#task_qr5_szm_qx).\r\n\r\n## **More Advanced Transformation**\r\n\r\n### **Pipeline Publishing & Version Control**\r\n\r\nNow we are going to use StreamSets built-in version control to [publish](https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Pipelines/Pipelines-Managing.html#task_x1v_yg2_2sb) the pipeline we just created and start a new draft of the pipeline. \r\n\r\n1. In StreamSets, go back to the pipeline that was just created. You will still be in edit mode, so you should see the **Check In** button above the Canvas. Click on this and the **Check In** wizard will appear.\r\n    \r\n    ![Check In](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_checkin.png)\r\n\r\n2. In the **Check In** wizard, enter a commit message and choose **Publish and Close**. \r\n\r\n\r\n    ![Pub & Close](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_check_in_pub_and_close.png)\r\n\r\n3. Back in the design canvas, you are now viewing a read-only version of the pipeline.  To create a new draft, click on **Edit** in the toolbar above the canvas. \r\n\r\n    ![Edit Version](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_edit_version.png)\r\n\r\n### **Join Orders with Line Items**\r\n\r\nLet's continue on with our pipeline development. Now let's add ``LINEITEMS`` to the pipeline so that we can finish our ```ORDER_LINE_ITEMS``` table. \r\n\r\n1. There are a couple ways to add a new origin , but the quickest is to simply copy the origin we already created. Select the **ORDERS** stage, and choose the **Copy** icon from the pop-up menu above. A new origin will appear on the screen, with the default name **Snowflake Table 1**.\r\n\r\n  ![Copy Stage](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_copy_stage.png)\r\n\r\n2. Update the new origin stage **Snowflake Table 1** with the following configurations:\r\n    - On the **General** properties tab, give it the name ``LINEITEMS``\r\n    - On the **Table** properties tab, we can see that the settings from the **Orders** origin are pre-populated. This means that all we need to do is update the Table name to  ``LINEITEM``, with this resulting configuration: \r\n\r\n    ![LineItems Properties](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_line_items_properties.png)\r\n\r\n3. Let's do the same column name transformations on the Line Items data, since all of the column names in this table begin with _L__. You can see the column names from the table in Snowflake below.\r\n\r\n  ![LineItem Columns](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_lineitem_column.png)\r\n\r\n4. Add another **Field Renamer** to the canvas. Eventually, the Orders and Line Item data will be joined, so it would be good to add a meaningful prefix on the Line Item columns to indicate which table each column is from. Instead of the ``L_`` prefix, the columns will be prefixed with ``LINEITEM_``. \r\n\r\n  - Do this by clicking on the output node of the **LINEITEM** origin and use the **Pipeline Creation Help Bar** above the canvas to select a **Field Renamer** processor [or click on the **Stage Panel Library** on the right canvas to select a **Field Renamer** and connect the **LINEITEM** output to the new processor's input]. \r\n    - Click on the new processor.\r\n    - On the **General** tab, set the **Name** to ``Update Column Prefixes``\r\n    - On the **Rename** tab, update the following properties:\r\n      - **Rename Type**: ``Find and replace in all fields by string``\r\n      - **Match Pattern**: ``L_``\r\n      - **Replacement**: ``LINEITEM_``\r\n\r\n### **Calculate Unit Price, Discounts, and Tax**\r\n\r\n5. Now that the column names are updated on the ``LINEITEM`` table, let's perform a few calculations that we want to see downstream in our analytics. We want to add some columns that calculate the unit base price per item, discounted price per item, total discount amount, and total sales amount.\r\n\r\n    - We will use an [**Expression Evaluator**](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Processors/Expression.html#concept_i1k_wxc_5rb) to create new columns.\r\n      - Add an **Expression Evaluator** processor to the canvas after the **Update Column Prefixes** processor. \r\n      - Name the **Expression Evaluator** ``Calculate Unit and Total Amounts``.\r\n      - Go to the **Expressions** tab.\r\n      - Now we want to add the following columns and accompanying calculations. Don't add this just yet! \r\n\r\n        | Column name | Expression |\r\n        | --- | --- |\r\n        | ``unit_base_price`` | ``lineitem_extendedprice/lineitem_quantity``|\r\n        | ``discounted_unit_price`` | ``unit_base_price * (1 - lineitem_discount)`` |\r\n        | ``total_discount_amount`` | ``-1 * lineitem_extendedprice * lineitem_discount`` |\r\n        | ``total_tax_amount`` | ``(lineitem_extendedprice + total_discount_amount) * lineitem_tax`` |\r\n        | ``net_total_amount`` | ``lineitem_extendedprice + total_discount_amount + total_tax_amount`` | \r\n      \r\n      \r\n      - When there is a lot of configuration that you want to copy/paste, you can often take advantage of [``Bulk Edit Mode``](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Pipelines/SimpleBulkEdit.html?hl=bulk%2Cedit). This switches the individual configurations to a json blob where you can copy/paste JSON arrays. \r\n      \r\n          ![Bulk Edit Mode](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_exp_eval_config.png)\r\n\r\n      - Copy the following ``json`` into the Bulk Edit text box - and be sure to include the brackets:\r\n\r\n        ```json\r\n        [\r\n          {\"fieldName\": \"unit_base_price\", \"expression\": \"lineitem_extendedprice/lineitem_quantity\"},\r\n          {\"fieldName\": \"discounted_unit_price\", \"expression\": \"unit_base_price * (1 - lineitem_discount)\"},\r\n          {\"fieldName\": \"total_discount_amount\", \"expression\": \"-1 * lineitem_extendedprice * lineitem_discount\"},\r\n          {\"fieldName\": \"total_tax_amount\", \r\n                \"expression\": \"(lineitem_extendedprice + total_discount_amount) * lineitem_tax\"},\r\n          {\"fieldName\": \"net_total_amount\", \"expression\": \"lineitem_extendedprice + total_discount_amount + total_tax_amount\"}\r\n        ]\r\n        ```\r\n        ![Bulk Edit Config](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_bulkedit_config.png)\r\n      \r\n\r\n        The pipeline should now look like this: \r\n          ![pipeline with expression evaluator](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_exp_eval_v2.png) \r\n\r\n\r\n### **Join**\r\n\r\n6. Now let's join these two tables together.\r\n    - Click on the line connecting the first **Field Renamer [Remove Column Name Prefixes]** to the **Snowflake Table [ORDER LINE ITEMS]** destination.\r\n    - On the **Pipeline Creation Help Bar**, select **Join** from the _Select Processor to add in between the selected stream..._ drop-down.\r\n\r\n7. Now connect the second **Field Renamer [Update Column Prefixes]** to the **Join** stage just added, so that it has two inputs. Your pipeline should now look like this:\r\n    ![Joined Pipeline](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_first_join.png)\r\n\r\n8. Click on the [Join](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Processors/Join.html#concept_edd_sc2_5rb) stage, and name the processor ``Order and Line Item Join``.\r\n    - On the **Join** properties tab below the canvas, we describe the join criteria. This is a very flexible processor as described in the [documentation](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Processors/Join.html#concept_edd_sc2_5rb), so there are multiple join types to choose from and join conditions can be based on matching column names or the join clause can be written out in SQL.  \r\n    - In this case, we will do an inner join on the ``ORDERS`` and ``LINEITEM`` tables based on the ``ORDERKEY``.  \r\n    - Make sure that the stage has the settings below:\r\n      \r\n        - **Join Type**: ``Inner``\r\n        - **Join Criteria**: ``Condition``\r\n        - **Condition**: ``ORDERKEY = LINEITEM_ORDERKEY``\r\n\r\n9. **Preview** the pipeline to see if the pipeline changes have had the desired effect. Use the preview button (eye icon) on the right side above the canvas. \r\n    - Looking at the previews for the **Field Renamer** stages, we can see that all of the prefixes were removed or updated accordingly.\r\n    - The preview for the **Join** stage probably isn't showing any records. Why not?\r\n        - When using preview, the pipeline is randomly pulling the records from each of the sources, so in this case, there is no guarantee that they will have Order Keys that will overlap. That's ok, because we can use the **Preview Where Clause** to filter the records that are used for preview.\r\n        - In this case, we will filter on the Order Id so that we can match the line items to the order. \r\n    - Close the preview \r\n\r\n10. Update the preview filters on the Snowflake Table origins.\r\n    - Go to the **ORDERS** origin and open the **Table** properties tab. For the **Additional Preview Where Clause**, enter ``O_ORDERKEY = 1``\r\n    - On the **LINEITEM** origin, add ``L_ORDERKEY = 1`` as the  **Additional Preview Where Clause**.\r\n\r\n11. Preview the pipeline again, and select the **Join [Order & Line Item Join]** processor. Now the processor is showing input and output where the Order and Line Item information have a matching order key. \r\n\r\n    ![Join Preview](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_join_preview.png)\r\n\r\n\r\n### **Create an Order Summary Table**\r\n\r\n12. Now create a **Order Summary** table that includes some of the calculations we just added.  We want to get total gross sales amount, total discount amount, total tax amount, and total net sales amount for each order. We'll also create a column, ``ORDER_COUNT``, so that subsequent aggregations can use that to total orders.\r\n\r\n    - To do this, add an [**Aggregate**](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Processors/Aggregate.html#concept_rvw_5rc_5rb) processor to the pipeline.\r\n    - Create a second output from the **Join [Order & Line Item Join]** processor by drawing a line from its output node to the input node of the **Aggregate** processor. \r\n    - Name the **Aggregate** processor ``Aggregate Line Items``. On the  **Aggregate** properties tab, add the following fields under _**Aggregations**_ (bulk edit option provided too): \r\n        \r\n        | Aggregate Function | Aggregate Field | Output Field Name |\r\n        | --- | --- | --- |\r\n        | ``Sum`` | ``LINEITEM_EXTENDEDPRICE`` | ``GROSS_SALES_AMOUNT`` |\r\n        | ``Sum`` | ``TOTAL_DISCOUNT_AMOUNT`` | ``TOTAL_DISCOUNT_AMOUNT`` |\r\n        | ``Sum`` | ``TOTAL_TAX_AMOUNT`` | ``TOTAL_TAX_AMOUNT`` |\r\n        | ``Sum`` | ``NET_TOTAL_AMOUNT`` | ``NET_TOTAL_AMOUNT`` |\r\n        | ``Count Distinct`` | ``ORDERKEY`` | ``ORDER_COUNT`` |\r\n          \r\n      JSON to copy/paste in **Bulk Edit Mode**:\r\n        \r\n        ```json\r\n          [\r\n            { \"aggregateTypes\": \"SUM\",\r\n              \"aggregateField\": \"LINEITEM_EXTENDEDPRICE\",\r\n              \"outputField\": \"GROSS_SALES_AMOUNT\" },\r\n            {  \"aggregateTypes\": \"SUM\",\r\n              \"aggregateField\": \"TOTAL_DISCOUNT_AMOUNT\",\r\n              \"outputField\": \"TOTAL_DISCOUNT_AMOUNT\" },\r\n            {  \"aggregateTypes\": \"SUM\",\r\n              \"aggregateField\": \"TOTAL_TAX_AMOUNT\",\r\n              \"outputField\": \"TOTAL_TAX_AMOUNT\" },\r\n            {  \"aggregateTypes\": \"SUM\",\r\n              \"aggregateField\": \"NET_TOTAL_AMOUNT\",\r\n              \"outputField\": \"NET_TOTAL_AMOUNT\" },\r\n            { \"aggregateTypes\": \"COUNT_DISTINCT\",\r\n              \"aggregateField\": \"ORDERKEY\",\r\n              \"outputField\": \"ORDER_COUNT\" }\r\n          ]\r\n        \r\n        ```\r\n    - Set **Group by Fields**[1] to ``ORDERKEY``\r\n    - The final properties should look like this: \r\n    \r\n      ![Aggregate properties](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_aggregate_settings.png)\r\n    \r\n    - Now add another **Snowflake Table** destination to the canvas, feeding it the output of the **Aggregate** processor.\r\n      - Name the destination ``Order Summary``\r\n      - On the **Table** tab, specify the table name as ``ORDER_SUMMARY``\r\n      - Select **Write Mode**: ``Overwrite Table``\r\n      - Select **Overwrite Mode**: ``Drop Table``\r\n    - The completed properties should look like this: \r\n\r\n      ![Order Summary Properties](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_order_summary_properties.png)\r\n\r\n13. Preview the Pipeline. Look at the output of the **Expression Evaluator** state to see the calculated columns. \r\n\r\n  ![Expression Evaluator Preview](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_exp_evaluator_preview.png)\r\n\r\n14. Look at the output of the **Aggregate** stage to see the aggregated Order Summary record. \r\n\r\n  ![Aggregate Preview](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_aggregate_preview.png)\r\n\r\n### **Create Final Order Summary**\r\n\r\n15. Now we want to join the summary data to the original orders data to create a table that has both the Order level details, such as ``CUSTOMERKEY``, and the totals derived from the Line Items.\r\n\r\n  - Start by adding another **Join** stage to the canvas using the **Stage Library Panel** on the right.\r\n  - Connect the output from the first **Field Renamer [Remove Column Name Prefixes]** processor as the input to the new **Join**\r\n  - Connect the output of the **Aggregate** processor to the join. \r\n  - Go to the processor configuration:\r\n      - Name the join ``Order and Aggregate Join``\r\n      - On the properties **Join** tab:\r\n        - **Join Criteria**: ``Matching Fields``\r\n        - **Matching Fields**[1]: ``ORDERKEY``  \r\n\r\n          ![Join Properties](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_join2_properties.png)\r\n\r\n\u003C!--\r\n16. Now we want to limit the columns that will be inserted into the new target table because maybe there are columns that are no longer used or not relevant to the data consumers. This can by done by using a **Field Remover** processor to specify the columns to **keep**. This processor gives you the option to specify either the columns to keep or the columns to remove. This can be done be specifying a list of columns OR using pattern matching to specify which columns to keep/remove.\r\n\r\n    - Insert a **Field Remover** stage. \r\n    - Connect the output of **Join [Order and Aggregate Join]** to its input.\r\n    - Name the stage ``Curate Columns``\r\n    - On the **Fields** tab of the stage properties, update the following settings:\r\n      - **Action**: ``Keep Listed Fields``\r\n      - **Field Match Criteria**: ``Field Name``\r\n      - **Fields**:  Below the first field, select [``Bulk Edit Mode``](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Pipelines/SimpleBulkEdit.html?hl=bulk%2Cedit) and copy/paste the following JSON array. Be sure to include the brackets.:\r\n          ```JSON\r\n          [\r\n            \"ORDERKEY\",\r\n            \"ORDERDATE\",\r\n            \"CUSTOMERKEY\",\r\n            \"STATUSCODE\",\r\n            \"PRIORITYCODE\",\r\n            \"CLERKNAME\",\r\n            \"SHIPPRIORITY\",\r\n            \"GROSS_SALES_AMOUNT\",\r\n            \"TOTAL_DISCOUNT_AMOUNT\",\r\n            \"TOTAL_TAX_AMOUNT\",\r\n            \"NET_TOTAL_AMOUNT\"\r\n          ]\r\n          ```\r\n--\u003E\r\n\r\n16. Now we will specify which table this data should be loaded to.\r\n  - Add a new **Snowflake Table** destination to the canvas.\r\n  - Connect the output of the **Field Remover** to its input.\r\n  - On the **Table** tab in the properties, specify the table name ``ORDER_AMOUNTS``\r\n  - At this point, the pipeline should look something like this: \r\n\r\n    ![pipeline](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_final_pre_pivot.png)\r\n\r\n17. Now preview the results, looking at each of the stages. If it would be helpful to see some more data in the preview, add another ORDERKEY to the the **Preview Where Clause** by changing them to ``O_ORDERKEY IN (1,2)`` for the Orders table and ``L_ORDERKEY IN (1,2)`` for the Line Item table. \r\n\r\n18. Once the pipeline has been previewed do a **Draft Run** on the unpublished pipeline. Go to your worksheet and run the following queries to see the output of the pipeline.\r\n    ```sql\r\n    SELECT * FROM PC_STREAMSETS_DB.PUBLIC.ORDER_LINE_ITEMS LIMIT 10;\r\n    SELECT * FROM PC_STREAMSETS_DB.PUBLIC.ORDER_SUMMARY LIMIT 10;\r\n    SELECT * FROM PC_STREAMSETS_DB.PUBLIC.ORDER_AMOUNTS LIMIT 10;   \r\n    ```\r\n\r\n19. Check in this version of the pipeline and enter a commit message. Choose ``Save & Close`` from the **Check In** window.\r\n\r\n20. A complete version of this pipeline can be found [here](https://github.com/streamsets/Pipeline-Examples/blob/359a57b4e5f486ba5c094a3380e4a618662a1657/tx4snowflake_hol/my_first_pipeline_step_3.zip) on github.\r\n\r\n## **User Defined Functions**\r\n\r\nIn the previous step, we added an **Expression Evaluator** to the pipeline to calculate values like unit cost and unit discount amount. What if these calculations were already codified in Snowflake? Snowflake UDFs (User Defined Functions) make this possible. (At the time this lab was written) Snowflake  supports UDFs written in Java, JavaScript, Python, and SQL, and [Transformer for Snowflake supports](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/Pipelines/UDF.html?hl=udf) the use of **ALL** of these. The only thing required is that your role has the **USAGE** privilege granted the function. \r\n\r\nTo make things even better, StreamSets allows the definition of Java UDFs _within the pipeline_. Defined at the pipeline level, a ``CREATE OR REPLACE FUNCTION`` statement will be executed with the provided code at  pipeline runtime. Let's replicate one of the calculations from the **Expression Evaluator [Calculate Unit and Total Amounts]** to see this in action. \r\n\r\n1. Click on **Edit** above the canvas to create a new version of **My First Pipeline**.\r\n\r\n2. Click on a blank area of the canvas to see the pipeline-level configurations in the pane below (**General** | **Parameters** | **Advanced** tabs). Click on the **Advanced** tab.\r\n\r\n  ![Advanced Configs](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_advanced_config.png)\r\n\r\n3. To add a UDF, click on **+ Add** to the right of **UDF Configs**.\r\n\r\n4. We are going to create a simple UDF to calculate the discounted unit price, just to show another way that this logic can be applied. Enter the following configurations:\r\n    - **UDF Name**: ``discounted_unit_price_java``\r\n    - **Java Handler Function**: ``discounted_unit_price_java``\r\n    - **Target Path for Jar**: ``@~/``\r\n    - **Java UDF Class Definition**: \r\n\r\n      ```java\r\n      public class sales {\r\n\r\n          public static double discounted_unit_price_java(double extended_price, double quantity, double discount_pct) {\r\n\r\n              double discounted_unit_price = (extended_price / quantity) * (1 - discount_pct);\r\n\r\n              return (discounted_unit_price);\r\n          }\r\n\r\n      }      \r\n      ```\r\n\r\n    Your final configuration will look like this: \r\n\r\n  ![Inline UDF Config](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_udf_config.png)\r\n\r\n5. Now click on the **Expression Evaluator [Calculate Unit and Total Amounts]** and add a new column with the following settings: \r\n    - **Output Field Name**: ``discounted_unit_price_udf_java``\r\n    - **Expression**: ``discounted_unit_price_java(lineitem_extendedprice, lineitem_quantity, lineitem_discount)``\r\n\r\n6. Preview the pipeline to compare the results of ``discounted_unit_price`` and ``discounted_unit_price_udf_java``. \r\n\r\n  ![Compare UDF results](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_udf_compare_results.png)\r\n\r\n7. Check in your pipeline. You can download a completed copy of this pipeline [here](https://github.com/streamsets/Pipeline-Examples/blob/main/tx4snowflake_hol/my_first_pipeline_udf.zip)\r\n\r\nObviously this is a very simple example, but the ability to use _any_ Snowflake UDF from a Transformer for Snowflake pipeline makes your pipelines even more powerful!\r\n\r\n\r\n## **Pipeline Fragments**\r\n\r\nIn the next part of the lab, we want to create a **Pivot Table** that can be used to support some analytics. Our goal for this portion is the lab is to create a table to support the analysis of monthly net sales by clerk. The desired output has rows for _CLERKs_,  columns as _Year/Month_, and  cell values as _Net Sales Amount_ totals.\r\n\r\nInstead of individually adding and configuring processors, we are going to use a [**pipeline fragment**](https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Pipeline_Fragments/PipelineFragments_title.html) to create a **Pivot Table** to support our analytics. \r\n\r\nA [**pipeline fragment**](https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Pipeline_Fragments/PipelineFragments_title.html) is a stage or set of connected stages that you can use in other pipelines. Use them to easily add the same processing logic to multiple pipelines and to ensure that the logic is used as designed.\r\n\r\nDownload the pipeline fragment from github [here](https://github.com/streamsets/Pipeline-Examples/blob/main/tx4snowflake_hol/pivot_fragment.zip) that was created to implement this logic. This fragment has been fully parameterized, allowing you to fill in parameter values for the date, the date format to pivot on, the field you want to group by, the value to aggregate, and the table to populate. So this fragment could be used multiple times to create and populate different pivot tables by only changing the input parameters when adding it to the pipeline. \r\n\r\nYou can find out more about Pipeline Fragments in [StreamSets Documentation](https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Pipeline_Fragments/PipelineFragments_title.html).\r\n\r\n### **Import a Pipeline Fragment**\r\n\r\n1. Instead of creating this fragment from scratch,  we will [import](https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/ExportImport/Importing.html#task_dd4_d5z_rdb) it. \r\n    - If you haven't already, download the pipeline fragment from [github](https://github.com/streamsets/Pipeline-Examples/blob/main/tx4snowflake_hol/pivot_fragment.zip).\r\n    - Click **Build** \u003E **Fragments** in the Navigation panel, and then click the **Import a Pipeline Fragment** option at above the fragment list or the **Import** icon.\r\n\r\n      ![StreamSets Fragment](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragments.png)\r\n\r\n    - On the pop-up window, use the following settings:\r\n      - **Import file type**: ``Archive File`` (default)\r\n      - **Commit Message**: ``import``\r\n      - **Browse File**: use the download of **pivot_fragment.zip**. \r\n   \r\n    - Click on **Import**.\r\n    - Click on **Close**.  Upon import, note that the fragment is already in the **Published** state, which means that it can be immediately used in pipelines. Just keep in mind that all fragments must be published before they can be added to a pipeline.\r\n\r\n    - Now you can see the **Pivot Fragment** in the Fragment list. \r\n\r\n2. Click on the **Pivot Fragment** to open the canvas. Let's take a closer look what it is doing.\r\n\r\n    ![Fragment Overview](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragment_overview.png)\r\n  \r\n  - The purpose of this fragment is to create a pivot table with a summary of net sales by month for each clerk. Since this pivot table could be created for a variety of time increments, metrics, and groupings, it uses parameters to allow users to enter a few column names once instead of having to add and configure the needed processors each time. The fragment versions can then be centrally managed, and when new versions are published, the updates can be pushed to the pipelines with the fragment in use.\r\n\r\n  - In the configuration menu below the canvas, the fragment's parameters are visible. When using this fragment in a pipeline, these parameters can be changed for every instance of the fragment that is inserted. To reference a parameter in a processor configuration, use ``${parameter name}``.\r\n\r\n  - The pipeline has 3 processors and 1 Snowflake Table destination.\r\n      - **Parse Date Parts [_Expression Evaluator Processor_]** - This stage parses the value in the ``DATE_COLUMN`` using the date format provided in the ``DATE_FORMAT_PATTERN`` string. \r\n        ![Expression Evaluator](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragment_exp_eval.png)\r\n      - **Keep Only Columns for Pivot [_Field Remover Processor_]** - This processor limits the columns in its output using the ``Keep Listed Fields`` option, the ``TIME_PERIOD`` field created in the previous processor, and the columns specified as the ``AGGREGATE_COLUMN`` and ``GROUP_BY_COLUMN``. The column name given for ``GROUP_BY_COLUMN`` here determines which column the pivot table will group the rows by. \r\n        ![Field Remover](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragment_field_remover.png)\r\n      - **Pivot [_Pivot Processor_]** - This stage is where the magic happens! \r\n        ![Pivot Processor](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragment_pivot.png)\r\n        - The **Field to Pivot** is set to be the ``TIME_PERIOD`` value created in the expression evaluator. This means that this is the value that will be turned into columns. \r\n        - **Autocalculate Pivot Values** - When selected, StreamSets uses the distinct values from the **Field to Pivot** as the column names. When this option is not selected, the column names need to be manually entered, which is also required when writing a SQL query to create a pivot table. So if **Autocalculate Pivot Values** is used, now there is no need to track new values appearing in the **Field to Pivot**. StreamSets will automatically take care of making sure the appropriate column names are present.\r\n        - **Field to Aggregate** - This is the value that will be aggregated by whatever function is chosen in the below **Aggregation** setting. In this instance, we are simply doing a sum since we want to generate totals for each row in each time period.\r\n          - To put this into context, the SQL query for this pivot is shown below, and with the passage of time, the column names will need to be updated every month. The Pivot Processor, however, does this logic for you so that you can set it and forget it. \r\n            ```sql\r\n              SELECT * \r\n              FROM SOURCE_TABLE\r\n                PIVOT( \r\n                  SUM(NET_SALES_AMOUNT) FOR TIME_PERIOD \r\n                    IN ('2022-01','2022-02'\r\n                        ,'2022-03','2022-04'\r\n                        ,'2022-05','2022-06'\r\n                        ,'2022-07','2022-08'\r\n                        ,'2022-09','2022-10'\r\n                        ,'2022-11','2022-12')\r\n                ) AS P;\r\n            ```\r\n      - **Snowflake Target Table [_Snowflake Table destination_]** - One thing to note about this **Snowflake Table** destination is that a parameter is being used to set the table name. This is something that can be done throughout StreamSets and makes it possible to create one pipeline that can use parameters to execute on different sources, targets, and/or using different values in the configurations.\r\n\r\n        ![Target Table](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_fragment_table.png)\r\n\r\n2. Go back to **Build** \u003E **Pipelines** and select the pipeline you were working on and open the canvas.\r\n\r\n### **Use Fragment to create Pivot Table**\r\n\r\n1. In the pipeline canvas for **My First Pipeline**, use the **Stage library panel** on the right. Click on the ``A`` in the top left of the panel produce a drop-down menu with the list of object types that can be added to the canvas. Select ``Fragments`` from the list. Now select the **Pivot Fragment**. A pop-up will appear to allow you to alter the prefix that StreamSets adds to the parameters for that fragment. Leave this unchanged and click on **Done**.\r\n\r\n      ![Stage Library Panel](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_stage_library_panel.png)\r\n\r\n    - The fragment will now appear on the canvas.\r\n    - Connect the output of **Order and Aggregate Join** to the input of the **Pivot Fragment**.\r\n    - Click on the **Pivot Fragment**. On the **General** tab below, there is a property for the **Fragment Commit/Tag**, where the version of the fragment currently in use can be seen and changed with the drop-down menu of its versions.\r\n      ![Choose Fragment Version](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_pipeline_fragment_version.png)\r\n    - The **Fragment Parameters** tab contains the parameters with the updated prefixes where the parameters have the default values assigned in the fragment.\r\n    - Now look at the pipeline parameters by clicking on an area of blank canvas to have the general pipeline properties appear below the canvas. On the **Parameters** tab, the parameters from the fragment were automatically added to this list as well, and pre-populated with the default values. The values for the fragment parameters can be updated in either place, and the new value will automatically be populated on both tabs.\r\n\r\n2. Start a **Draft Run** of the pipeline.  Verify the creation of the ORDER_AMOUNTS table in Snowflake with the following query (query assumes all default values were used).\r\n    ```sql\r\n    SELECT * FROM PC_STREAMSETS_DB.PUBLIC.PIVOT_SALES_BY_CLERK LIMIT 10;\r\n    ```\r\n3. An archive file with the completed pipeline can be found [here](https://github.com/streamsets/Pipeline-Examples/blob/85acaa98a6af565e4eb8fb2ce5e8f86829e2761f/tx4snowflake_hol/my_first_pipeline_final.zip).\r\n\r\n## **Create a Job**\r\n\r\n### Create & Run a Job\r\nIn this next step, we will create a StreamSets [job instance](https://docs.streamsets.com/portal/platform-txsnowflake/latest/tx-snowflake/ControlHub/Title.html#concept_qv1_5sn_hsb), which is the execution of a published pipeline. A job instance can be created from a pipeline or a job template.\r\n\r\n  - Check in the pipeline.\r\n  - After entering the **Commit Message**, click on ``Publish and Next``.\r\n  - Under **Share Pipeline**, select ``Save and Next`` .\r\n  - The **Update Jobs** section won't have any jobs listed, so click on ``Save and Create New Job``\r\n  - A new pop-up window appears titled **Create Job Instances**.\r\n  - Leave the default job **Name**: ``Job for My First Pipeline``.\r\n  - Click on ``Next``.\r\n  - Under **Select Pipeline**, the name of the pipeline will appear, in this case ``My First Pipeline`` as well as the pipeline version. Click on ``Next``.\r\n  - Now the **Define Runtime Parameters** section displays. This is where the default parameter values can be overwritten. For this case, the defaults will suffice. Click on ``Save & Next``.\r\n  - Under **Review & Start**, it indicates that the job was successfully created. Click on ``Start & Monitor Job``.\r\n    ![Create Job](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_create_job.png)\r\n\r\n### View Running Job\r\n- The system will show the pipeline canvas, but this is really a view of the job, as is indicated by the job name in the top left and the green ``ACTIVE`` indicator. \r\n  \r\n  ![Running Job](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_job_running.png)\r\n\r\n- The job will complete shortly, and below the canvas, the **Job Status** tab will show the current job status, which is now ``INACTIVE``. It also shows the parameter values used for that instance of the job.\r\n- Click on the **History** tab below **Job Status**, and a summary of all the job runs is displayed. Click on **View Summary...**.\r\n\r\n    ![Job History](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_job_history.png)\r\n\r\n- The **Job Metrics Summary** will appear and shows:\r\n    - The number of records read and written\r\n    - Scroll down to reveal the queries generated for each destination. The Destination Id shown is not the name given to the destination, but the Instance Name that can be found on the **Info** tab of every pipeline component. \r\n    - Scroll all the way to the bottom to see the Log history.\r\n    \r\n      ![Job Run Summary](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_job_run_summary.png)\r\n\r\n- The full lists of job instances, job templates, draft runs, can also be found under the **Run** tab on the left. \r\n\r\nThere is much more that can be done with jobs, such as scheduling them or triggering job runs via the Rest API. You can find more information in the Control Hub documentation [here](https://docs.streamsets.com/portal/platform-controlhub/controlhub/UserGuide/Run/Run.html).\r\n\r\n\r\n\u003C!--\r\n### Create a Job Template\r\n--\u003E\r\n\r\n## **Slowly Changing Dimension**\r\n\r\nYou can see that the ``NATION`` table in the ``SNOWFLAKE_SAMPLE_DATA`` database and ``TPCH_SF1`` schema has a region assigned to each country. Over time, the company might add or change regions as they grow. For instance, there is only an ``America`` region, but eventually it might make sense to split that into ``North America`` and ``South America``. For our reporting over time, however, we may want to preserve the historical nation to region mappings, so we want to capture this in a **Slowly Changing Dimension**. \r\n\r\n1. Go back to your Snowflake Worksheet and run the following ``SQL`` queries to create the tables for this portion of the lab.  When you finish, you should have two new tables in the ``PC_STREAMSETS_DB`` database and ``PUBLIC`` schema: ``NATION_DIMENSION`` and ``NATION_UPDATES``.\r\n\r\n    ```sql\r\n    -- CREATE NATION DIMENSION FOR SCD PIPELINE\r\n    CREATE OR REPLACE TABLE PC_STREAMSETS_DB.PUBLIC.NATION_DIMENSION AS\r\n    SELECT\r\n        N.N_NATIONKEY AS NATION_KEY,\r\n        N_NAME AS NATION_NAME,\r\n        R.R_NAME AS REGION_NAME,\r\n        '2022-01-01T00:00:00Z'::TIMESTAMP_NTZ(0) AS START_TIMESTAMP,\r\n        NULL::TIMESTAMP_NTZ(0)  AS END_TIMESTAMP,\r\n        1::INTEGER AS VERSION,\r\n        TRUE AS ACTIVE_FLAG\r\n    FROM\r\n        SNOWFLAKE_SAMPLE_DATA.TPCH_SF1.NATION N\r\n        JOIN SNOWFLAKE_SAMPLE_DATA.TPCH_SF1.REGION R \r\n        ON N_REGIONKEY = R.R_REGIONKEY;\r\n\r\n    -- CREATE A TABLE FOR CHANGE DATA\r\n    CREATE OR REPLACE TABLE PC_STREAMSETS_DB.PUBLIC.NATION_UPDATES\r\n      (\r\n        NATION_KEY INTEGER,\r\n        NATION_NAME VARCHAR,\r\n        REGION_NAME VARCHAR,\r\n        EFFECTIVE_DATE TIMESTAMP_NTZ(0) \r\n        );\r\n\r\n    -- Insert Records into change data table\r\n    INSERT INTO PC_STREAMSETS_DB.PUBLIC.NATION_UPDATES \r\n      VALUES \r\n      (2,'BRAZIL','AMERICA','2022-10-01T00:00:00Z')\r\n      , (24, 'UNITED STATES','NORTH AMERICA','2022-09-01T00:00:00Z')\r\n      , (25, 'AUSTRALIA','ANZ','2022-08-01T00:00:00Z') ;\r\n    ```\r\n\r\n2. Create a new pipeline by going to **Build** \u003E **Pipelines**. Use the ➕ icon to create a new Transformer for Snowflake pipeline.\r\n  ![Create New Pipeline 1](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_new_pipeline.png)\r\n \r\n3. Click on **Use Transformer for Snowflake**! Name your pipeline ``My SCD Pipeline`` and click on **Next**. At the next prompt, chooose **Save and Open in Canvas**.\r\n\r\n4. Check on the **General** and **Parameters** tabs below the pipeline canvas to make sure that your pipeline default values are populated. If not, enter them. \r\n\r\n5. Add a **Snowflake Table** origin to the canvas. Since we are using our default database and schema, all we need to do is add the table name to read from. Name the origin ``Nation Dimension``, and go to the **Table** tab to enter the following settings: \r\n    - **Table**: ``NATION_DIMENSION``\r\n    - **Additional Preview Where Clause**: ``NATION_KEY IN (2,24,25)``\r\n\r\n6. While this origin is selected, use the **Pipeline Creation Help Bar** above the canvas to **Select New Processor to connect..** and choose ``Slowly Changing Dimension``. If the **Pipeline Creation Help Bar** does not appear, you can select the SCD Processor from the **Stage Library Panel**, drag it onto the canvas, and connect your origin output as its input.\r\n\r\n6. Add a second **Snowflake Table** origin to the canvas. Again, this table is in the default database and schema, so you only need to enter the table name to read from. Name the origin ``Nation Updates``, and then go to the **Table** tab to enter the following setting: \r\n    - **Table**: ``NATION_UPDATE``\r\n\r\n7. Connect the output of the **Nation Update** origin to the **Slowly Changing Dimension** processor. Your pipeline should now look like the image below. It is important which number each input is assigned to. **Nation Dimension** should be input ``1`` and **Nation Update** should be input ``2``. If the inputs are reversed, you can switch them by selecting the SCD processor and clicking on the button with the up and down arrows.\r\n\r\n  ![SCD Pipeline](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_1.png)   \r\n\r\n8. Now it's time to configure the processor. Make sure that the SCD processor is selected, and on the **Dimension** configuration below, enter the following settings:\r\n\r\n    - **SCD Type**: ``Type 2``\r\n    - **Key Fields**[1]: ``nation_key``\r\n    - **Specify Version Field**: **✓**\r\n      - **Version Field**: ``version``\r\n    - **Active Flag Type**: **✓**\r\n    - **Specify Timestamp Fields**: selected\r\n      - **Start Timestamp Field**: ``start_timestamp``\r\n      - **End Timestamp Field**: ``end_timestamp``\r\n      - **Calculated Timestamp Field**: ``effective_date``\r\n    - **Behavior for New Fields**: ``Remove from change data`` [default]\r\n\r\n  - Let's take a closer look at some of these settings: \r\n    - **SCD Type**: Currently Type 1 and Type 2 dimensions are supported.\r\n    - **Key Fields**: You can specify the fields that uniquely identify each dimension record. Columns not included as a key or in the settings below will be considered when comparing existing dimension records to new data.\r\n    - **Specify Timestamp Fields**: \r\n      - **Calculated Timestamp Field**: This option allows you to use a timestamp from the changed data set as the value for the **Start Timestamp** on the new or updated record and the **End Timestamp** on the record to be expired.\r\n    - **Behavior for New Fields** - this setting determines what will happen when a column exists in the change data but not the dimension table. \r\n      - **Remove from change data** - The processor will ignore additional column(s) and drop any data from the change data set in a column that does not exist in the dimension.\r\n      - **Keep for newest records and set to null for previous records** - The processor will pass the new column from the change data to the rest of the pipeline. This means that if **Data Drift Enabled** is selected in your table destination, the new column will be created in the target table. \r\n9. Now we will add a **Snowflake Table Destination** to complete the pipeline. \r\n    - Connect the output of the **Slowly Changing Dimension** processor to a **Snowflake Table** destination (that needs to be added to the canvas). \r\n    - Name the destination ``Nation Dimension Destination``\r\n    - Choose the following settings on the **Table** tab:\r\n      - **Table**: ``NATION_DIMENSION``\r\n      - **Write Mode**: ``Propagate updates from Slowly Changing Dimensions``\r\n      - **Create Table**: Unchecked\r\n      - **Data Drift Enabled**: **✓**\r\n    - The **Table** tab should look like this:\r\n    ![SCD Table Destination](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_destination.png)\r\n\r\n    - What does it mean to ``Propagate updates from Slowly Changing Dimensions``? \r\n        - The **Slowly Changing Dimension** processor produces a record for every ``INSERT`` and ``UPDATE`` that is needed. So for example, when a nation's region  changes, the processor generates one output that updates the fields to expire the old record and a second output for the new version of the record. Using this option on StreamSets' **Snowflake Table** destination means that StreamSets will generate the ``MERGE`` statement needed to process all of the updates automatically. \r\n\r\n10. The completed pipeline should look like this: \r\n    ![Completed SCD Pipeline.](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_pipeline_complete.png)\r\n\r\n11. Now **Preview** the pipeline. On the **Preview Configuration** screen, keep the options to **Show Record/Field Header** and  **Write to Destinations** unselected. Let's step through the output of the preview:\r\n    - On the ``Nation Dimension`` origin, we can see two records from the existing dimension, the records for ``Brazil`` and the ``United States``.\r\n        ![Dimension Origin Preview](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_preview_dim_origin.png)\r\n    - On the ``Nation Update`` origin, there are three records from the change data, the records for ``Australia``, ``Brazil``,  and the ``United States``. In this preview, the record for the ``United States`` has a new region, the ``Brazil`` record is unchanged, and there is a new record to add ``Australia``.\r\n      ![Update Origin Preview](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_preview_updates_origin.png)\r\n    - On the ``Slowly Changing Dimension`` processor, there are 5 input records and only 3 output records. Let's step through each one. \r\n      ![SCD Processor Preview](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/ss_scd_preview_scd_processor.png)\r\n        - **Nation_Key** ``2``: ``Brazil``\r\n          \r\n          There was no change to this record in the update data, so no action needs to be taken and the record is ignored\r\n        - **Nation_Key** ``24``: ``United States``\r\n          \r\n          The update data contains a new region, ``North America``, versus the existing dimension record that has ``America`` as the region. The processor then generates 2 records.\r\n            - 1 - Expires old record. The original dimension record is updated to set the ``ACTIVE FLAG`` to ``FALSE`` and set the ``END_TIMESTAMP`` to the ``EFFECTIVE_DATE`` of the updated record. The ``__SS_META_OPERATION`` and ``__SS_META_KEYS`` are columns generated by StreamSets that will NOT appear in the final data, but are metadata that the destination processor uses.\r\n            - 2 - Generates new record. This record contains the new region value. The version of the record is incremented from the old record, the ``ACTIVE_FLAG`` is set to ``TRUE``, and the ``START_TIMESTAMP`` to the value of the ``EFFECTIVE_DATE``\r\n            \r\n        - **Nation_Key** ``25``: ``Australia``\r\n          This record does not exist in the current dimension table, so a new row will be created as Version 1 of the record.\r\n\r\n12. Close the preview. Do a **Draft Run** of the pipeline and go back to Snowflake and continue with the previous worksheet and run the following SQL statement:\r\n\r\n      ```sql\r\n      SELECT *\r\n      FROM  PC_STREAMSETS_DB.PUBLIC.NATION_DIMENSION\r\n      WHERE NATION_KEY IN ('2','24','25')\r\n      ORDER BY NATION_KEY, START_TIMESTAMP;\r\n      ```\r\n\r\n   The query results show the active and inactive dimension records for the three example nations that were processed by the pipeline as show below.\r\n\r\n  ![SCD Query Results](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/snowflake_scd_results.png)\r\n\r\n13. You can download a completed version of the pipeline [here](https://github.com/streamsets/Pipeline-Examples/blob/main/tx4snowflake_hol/scd_pipeline_final.zip).\r\n\r\n\u003C!-- ------------------------ --\u003E\r\n## Conclusion\r\n\r\nThank you for participating in this Hands on Lab! \r\n\r\n![Streamie](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/streamsets-transformer-for-snowflake-hol/Streamie_small.png)\r\n\r\n### What We Covered\r\n\r\n- How to create your own StreamSets instance using Snowflake Partner Connect\r\n- How to create, preview, and run Transformer for Snowflake pipelines\r\n- How to use fragments to minimize your development efforts\r\n- How to process data in a Slowly Changing Dimension\r\n- How to create and execute jobs\r\n\r\n### Ready to learn more?\r\n- [Schedule a live Demo](https://streamsets.com/products/schedule-demo/) that includes more on StreamSets including the Data Collector engine!\r\n- Download the [Data Engineers Handbook for Snowflake](https://go.streamsets.com/snowflake-data-engineers-handbook.html)\r\n- Watch the webinar [End-to-End Data Integration for Snowflake with Snowpark](https://go.streamsets.com/snowpark-first-look.html)\r\n- Go to [StreamSets Academy](https://academy.streamsets.com/) for **free** self paced lessons to learn more!","title":"Quickstart Article Body","multiValue":false,":type":"text/x-markdown"},"quickstartArticleLogoImage":{"dataType":"string","title":"Quickstart Article Logo Image","multiValue":false,":type":"text/plain"}},"elementsOrder":["quickstartArticleBody","quickstartArticleLogoImage"],"model":"snowflake-site/models/quickstart-article"},"flexible_column_cont":{"id":"flexible-column-container-e957c747b0","type":"2-column-75-25","alignColumns":"top","containerMaxWidth":"extra-large","topPadding":"none","bottomPadding":"none","spaceBetween":"none","reverseOnMobile":false,"carouselOnMobile":false,"backgroundImageOption":"none","flexible_column_content_container_1":{"id":"container-02340380f7","layout":"SIMPLE",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"quickstart_last_modi":{"id":"quickstart-last-modified-6e7d60d7e4","icon":{"id":"icon","icon":"calendar",":type":"snowflake-site/components/icon","appliedCssClassNames":"snowflake-icon-blue"},"lastModifiedDatePrefix":"Updated","lastModifiedDate":"2025-04-21",":type":"snowflake-site/components/quickstart/quickstart-last-modified","appliedCssClassNames":"snowflake-responsive-component-top-padding-small"},"text":{"id":"text-781fd72c09","additionalClasses":"qs-disclaimer-text","text":"\u003Cp\u003E\u003Cspan style=\"color: #666;\"\u003EThis content is provided as is, and is not maintained on an ongoing basis. It may be out of date with current Snowflake instances\u003C/span\u003E\u003C/p\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"snowflake-responsive-component-top-padding-small"}},":itemsOrder":["quickstart_last_modi","text"]},"flexible_column_content_container_2":{"id":"container-06b10c07b5","layout":"SIMPLE",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{},":itemsOrder":[]},":type":"snowflake-site/components/flexible-column-container","isBlogPage":false,"isActiveTOC":false}},":itemsOrder":["contentfragment","flexible_column_cont"]},"flexible_column_content_container_2":{"id":"container-f8ee2b12da","layout":"SIMPLE",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"quickstart_table_of_":{"id":"container-12f0e9565e","layout":"SIMPLE","isDeveloperGuidesPage":false,":type":"snowflake-site/components/quickstart/quickstart-table-of-content/quickstart-table-of-content-container",":items":{"quickstart_table_of_":{"id":"quickstart-table-of-content-97a0fcbbe3","headings":["\u003Ch2\u003EOverview\u003C/h2\u003E","\u003Ch2\u003E\u003Cstrong\u003ETransformer for Snowflake\u003C/strong\u003E\u003C/h2\u003E","\u003Ch2\u003E\u003Cstrong\u003EGetting Started with Snowflake\u003C/strong\u003E\u003C/h2\u003E","\u003Ch2\u003E\u003Cstrong\u003EUse Partner Connect to Create a StreamSets Organization\u003C/strong\u003E\u003C/h2\u003E","\u003Ch2\u003E\u003Cstrong\u003EOverview of the DataOps Platform UI\u003C/strong\u003E\u003C/h2\u003E","\u003Ch2\u003E\u003Cstrong\u003ECreate and Run a Simple Pipeline\u003C/strong\u003E\u003C/h2\u003E","\u003Ch2\u003E\u003Cstrong\u003EMore Advanced Transformation\u003C/strong\u003E\u003C/h2\u003E","\u003Ch2\u003E\u003Cstrong\u003EUser Defined Functions\u003C/strong\u003E\u003C/h2\u003E","\u003Ch2\u003E\u003Cstrong\u003EPipeline Fragments\u003C/strong\u003E\u003C/h2\u003E","\u003Ch2\u003E\u003Cstrong\u003ECreate a Job\u003C/strong\u003E\u003C/h2\u003E","\u003Ch2\u003E\u003Cstrong\u003ESlowly Changing Dimension\u003C/strong\u003E\u003C/h2\u003E","\u003Ch2\u003EConclusion\u003C/h2\u003E"],"fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/streamsets-transformer-for-snowflake-hol",":type":"snowflake-site/components/quickstart/quickstart-table-of-content"},"quickstart_button":{"id":"quickstart-button-ae913fc9c7","fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/streamsets-transformer-for-snowflake-hol",":type":"snowflake-site/components/quickstart/quickstart-button","appliedCssClassNames":"snowflake-responsive-component-top-padding-none"}},":itemsOrder":["quickstart_table_of_","quickstart_button"]}},":itemsOrder":["quickstart_table_of_"]},":type":"snowflake-site/components/flexible-column-container","isBlogPage":false,"isActiveTOC":false},"markup_editor":{"id":"markup-editor-67f2ddabd7","title":"Page CSS","cssContent":"#quickstart-template-main-flexible-container{padding:24px}#quickstart-template-main-flexible-container \u003E .snowflake-flexible-column-container-items{grid-template-columns:1fr 0}.qs-disclaimer-text p \u003E span{font-size:15px !important}@media (min-width:768px){#quickstart-template-main-flexible-container{padding:24px 32px}#quickstart-template-main-flexible-container \u003E .snowflake-flexible-column-container-items{grid-template-columns:7fr 3fr;gap:48px}}@media (max-width:767px){#quickstart-template-main-flexible-container \u003E .snowflake-flexible-column-container-items{gap:0}}@media (min-width:1024px){#quickstart-template-main-flexible-container{padding:0 92px 48px 92px}#quickstart-template-main-flexible-container \u003E .snowflake-flexible-column-container-items{gap:117px}}",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false}},":itemsOrder":["quickstart_hero","flexible_column_cont","markup_editor"],":type":"wcm/foundation/components/responsivegrid"},"modal_container":{"id":"container-678f25935e","layout":"SIMPLE",":type":"snowflake-site/components/modal/modal-container",":items":{},":itemsOrder":[]},"experiencefragment-footer":{"id":"experiencefragment-2fcbf14821","localizedFragmentVariationPath":"/content/experience-fragments/snowflake-site/language-masters/en/site/footer/master/jcr:content","configured":true,":type":"snowflake-site/components/experiencefragment",":items":{"root":{"additionalClasses":"sf-footer","id":"container-c7ebb7138e","layout":"SIMPLE",":type":"snowflake-site/components/container",":items":{"container_copy":{"additionalClasses":"sf-footer__inner","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"flexible_column_cont":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-10e9358e9d","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"flexible_column_cont":{"id":"flexible-column-container-2b44c6fdd8","type":"1-column","alignColumns":"top","containerMaxWidth":"extra-large","topPadding":"medium","bottomPadding":"extra-small","spaceBetween":"small","reverseOnMobile":false,"carouselOnMobile":false,"propertiesCSSClasses":"sf-footer-grid","backgroundImageOption":"none","flexible_column_content_container_1":{"id":"container-a151e1dc6e","layout":"SIMPLE",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"container":{"additionalClasses":"sf-footer-grid__inner","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"container":"aem-GridColumn aem-GridColumn--default--12","container_1622723482":"aem-GridColumn aem-GridColumn--default--12","container_copy_copy_":"aem-GridColumn aem-GridColumn--default--12","container_copy_copy":"aem-GridColumn aem-GridColumn--default--12","container_copy":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-773b0c0f33","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"container_1622723482":{"additionalClasses":"sf-footer__column","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"container":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-a03fb888cd","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"container":{"additionalClasses":"sf-footer__newsletter-group","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12","marketo_v2":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-eab9967579","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"text":{"id":"text-8bc26e42fe","additionalClasses":"sf-footer__newsletter-title","text":"\u003Cp\u003E\u003Cb\u003ESubscribe to our monthly newsletter\u003C/b\u003E\u003C/p\u003E\r\n\u003Cp\u003EStay up to date on Snowflake’s latest products, expert insights and resources—right in your inbox!\u003C/p\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-regular text-color-text-04"},"marketo_v2":{"id":"marketo-v2-774b08af98","marketoForm":{"hidden":null,"formId":"45871","edit":false,"successUrl":null,"script":null,"values":null},"marketoConfigured":true,"formConfigured":true,"serverInstance":"252-RFO-227.mktoweb.com","munchkinId":"252-RFO-227",":type":"snowflake-site/components/form/marketo-v2"}},":itemsOrder":["text","marketo_v2"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"}},":itemsOrder":["container"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"},"container":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"text_copy":"aem-GridColumn aem-GridColumn--default--12","text":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-3cc014db8e","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"text":{"id":"text-dba970e8e0","additionalClasses":"sf-footer__link-group","text":"\u003Cp class=\"sf-footer__column-title\"\u003EProduct\u003C/p\u003E\r\n\u003Cul\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/product/platform/\"\u003EPlatform\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/product/snowflake-cowork/\"\u003ESnowflake CoWork\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/product/data-engineering/\"\u003EData Engineering\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/product/analytics/\"\u003EAnalytics\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/product/ai/\"\u003EAI\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/product/applications-and-collaboration/\"\u003EApplications &amp; Collaboration\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/pricing-options/\"\u003EPricing\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"},"text_copy":{"id":"text-02ecdfeef1","additionalClasses":"sf-footer__link-group","text":"\u003Cp class=\"sf-footer__column-title\"\u003ESupport\u003C/p\u003E\r\n\u003Cul\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/support/\"\u003ESupport\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/legal/addenda/priority-support-services-description/\"\u003EPriority Support\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://status.snowflake.com/\" target=\"_blank\" rel=\"noopener noreferrer\"\u003EStatus\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"}},":itemsOrder":["text","text_copy"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-medium"},"container_copy_copy":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-10badfc3ed","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"text":{"id":"text-50c856333c","additionalClasses":"sf-footer__link-group","text":"\u003Cp class=\"sf-footer__column-title\"\u003E\u003Ca href=\"/en/solutions/industries/\"\u003EIndustries\u003C/a\u003E\u003C/p\u003E\r\n\u003Cul\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/advertising-media-entertainment/\"\u003EAdvertising, Media &amp; Entertainment\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/financial-services/\"\u003EFinancial Services\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/healthcare-and-life-sciences/\"\u003EHealthcare &amp; Life Sciences\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/manufacturing/\"\u003EManufacturing\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/public-sector/\"\u003EPublic Sector\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/retail-consumer-goods/\"\u003ERetail &amp; Consumer Goods\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/solutions/industries/telecom/\"\u003ETelecom\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/solutions/industries/technology/\"\u003ETechnology\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"}},":itemsOrder":["text"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"},"container_copy":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-fecd857a03","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"text":{"id":"text-2154934ee0","additionalClasses":"sf-footer__link-group","text":"\u003Cp class=\"sf-footer__column-title\"\u003ECompany\u003C/p\u003E\r\n\u003Cul\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/company/overview/about-snowflake/\"\u003EAbout Snowflake\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/company/overview/leadership-and-board/\"\u003ELeadership &amp; Board\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://careers.snowflake.com/us/en\" target=\"_blank\" rel=\"noopener noreferrer\"\u003ECareers\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://investors.snowflake.com/overview/default.aspx\" target=\"_blank\" rel=\"noopener noreferrer\"\u003EInvestor Relations\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://trust.snowflake.com/\" target=\"_blank\" rel=\"noopener noreferrer\"\u003ETrust Center\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/brand-guidelines/\" target=\"_blank\" rel=\"noopener noreferrer\"\u003EBrand Guidelines\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/contact/\"\u003EContact\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/news/\"\u003ENewsroom\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/company/overview/esg/\"\u003EEnvironmental, Social &amp; Governance\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/company/overview/snowflake-ventures/\"\u003ESnowflake Ventures\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/company/overview/end-data-disparity/\"\u003EEnd Data Disparity\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/summit/\"\u003ESnowflake Summit 26\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"}},":itemsOrder":["text"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"},"container_copy_copy_":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"text":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-0c61055c0a","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"text":{"id":"text-a0ed37c74b","additionalClasses":"sf-footer__link-group","text":"\u003Cp class=\"sf-footer__column-title\"\u003ELearn\u003C/p\u003E\r\n\u003Cul\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://snowflake.com/en/resources/\"\u003EResource Library\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/webinars/demo/\"\u003ELive Demos\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/fundamentals/\"\u003EFundamentals\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/resources/learn/training/\"\u003ETraining\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/resources/learn/certifications/\"\u003ECertifications\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca rel=\"noopener noreferrer\" target=\"_blank\" href=\"https://learn.snowflake.com/en/\"\u003ESnowflake University\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/developers/guides\"\u003EDeveloper Guides\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca rel=\"noopener noreferrer\" target=\"_blank\" href=\"https://docs.snowflake.com/\"\u003EDocumentation\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"/en/data-governance/\"\u003EData Governance\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"}},":itemsOrder":["text"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"}},":itemsOrder":["container_1622723482","container","container_copy_copy","container_copy","container_copy_copy_"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-small"}},":itemsOrder":["container"]},":type":"snowflake-site/components/flexible-column-container","isBlogPage":false,"isActiveTOC":false}},":itemsOrder":["flexible_column_cont"],"appliedCssClassNames":"snowflake-container snowflake-responsive-container-inner-padding-small"},"container_573483281_":{"additionalClasses":"sf-footer__bottom","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"container_112062425":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-e69c5e7cec","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"container_112062425":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"flexible_column_cont":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-6e61b79455","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"flexible_column_cont":{"id":"flexible-column-container-4988d2ae2a","type":"1-column","alignColumns":"top","containerMaxWidth":"extra-large","topPadding":"none","bottomPadding":"none","spaceBetween":"small","reverseOnMobile":false,"carouselOnMobile":false,"backgroundImageOption":"none","flexible_column_content_container_1":{"id":"container-1b4a3c57d2","layout":"SIMPLE",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"container":{"additionalClasses":"sf-footer__legal-container","gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"container":"aem-GridColumn aem-GridColumn--default--12","text_copy_copy_16360":"aem-GridColumn aem-GridColumn--default--12","markup_editor":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-4a9e5bd5b1","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"container":{"gridClassNames":"aem-Grid aem-Grid--12 aem-Grid--default--12","columnClassNames":{"image":"aem-GridColumn aem-GridColumn--default--12"},"id":"container-bbe2c0a40b","layout":"RESPONSIVE_GRID","columnCount":12,":type":"snowflake-site/components/container",":items":{"image":{"id":"image-b70c80d1e8","additionalClasses":"sf-footer__logo","height":"64","src":"https://www.snowflake.com/content/experience-fragments/snowflake-site/language-masters/en/site/footer/master/_jcr_content/root/container_573483281_/container_112062425/flexible_column_cont/flexible_column_content_container_1/container/container/image.coreimg.svg/1747882370694/nav-icon-snowflake-bug.svg","alt":"Snowflake logo","imageLink":{"valid":true,"url":"/en/"},"lazyEnabled":true,"width":"64",":type":"snowflake-site/components/image"}},":itemsOrder":["image"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-extra-small"},"text_copy_copy_16360":{"id":"text-8c3608d68e","additionalClasses":"sf-footer__legal-links","text":"\u003Cul\u003E\r\n\u003Cli\u003E© 2026 Snowflake Inc. All Rights Reserved\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/legal/privacy/privacy-policy/\"\u003EPrivacy Policy\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://snowflake.com/en/legal/snowflake-site-terms/\"\u003ESite Terms\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://info.snowflake.com/Preference-center.html\"\u003ECommunication Preferences\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Cbutton id=\"ot-sdk-btn\" class=\"ot-sdk-show-settings\"\u003ECookie Settings\u003C/button\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/legal/privacy/privacy-policy/#12\"\u003EDo Not Share My Personal Information\u003C/a\u003E\u003C/li\u003E\r\n\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/legal/\"\u003ELegal\u003C/a\u003E\u003C/li\u003E\r\n\u003C/ul\u003E\r\n","richText":true,":type":"snowflake-site/components/text","appliedCssClassNames":"text-size-small text-color-text-04"},"markup_editor":{"id":"markup-editor-645c68ce43","title":" ","htmlContent":"\u003Cdiv class=\"sf-footer__social\"\u003E\r\n\u003Cdiv data-testid=\"snowflake-footer-twitter\" class=\"snowflake-button-icon snowflake-button-white snowflake-footer-social-item\"\u003E\u003Cdiv class=\"snowflake-button-icon \"\u003E\u003Ca href=\"https://x.com/Snowflake\" data-testid=\"button-external\" aria-label=\"X (Twitter)\" role=\"button\" class=\"snowflake-button-container\" title=\"X (Twitter)\" tabindex=\"0\" target=\"_blank\" rel=\"noreferrer\"\u003E\u003Cdiv data-testid=\"button-icon-wrapper\"\u003E\u003Csvg xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 59 53\" class=\"button-icon\"\u003E\u003Cpath fill=\"currentColor\" d=\"M46.614 0h9.044L35.8 22.49 59 53H40.795L26.54 34.46 10.223 53H1.18l21.036-24.055L0 0h18.657l12.878 16.937zM43.45 47.72h5.013L16.023 5.085h-5.387z\"\u003E\u003C/path\u003E\u003C/svg\u003E\u003C/div\u003E\u003C/a\u003E\u003Cdiv\u003E\u003C/div\u003E\u003C/div\u003E\u003C/div\u003E\u003Cdiv data-testid=\"snowflake-footer-linkedin\" class=\"snowflake-button-icon snowflake-button-white snowflake-footer-social-item\"\u003E\u003Cdiv class=\"snowflake-button-icon \"\u003E\u003Ca href=\"https://www.linkedin.com/company/3653845\" data-testid=\"button-external\" aria-label=\"LinkedIn\" role=\"button\" class=\"snowflake-button-container\" title=\"LinkedIn\" tabindex=\"0\" target=\"_blank\" rel=\"noreferrer\"\u003E\u003Cdiv data-testid=\"button-icon-wrapper\"\u003E\u003Csvg xmlns=\"http://www.w3.org/2000/svg\" fill=\"currentColor\" viewBox=\"0 0 24 24\" class=\"button-icon\"\u003E\u003Cpath d=\"M22.223 0H1.772C.792 0 0 .773 0 1.73v20.536C0 23.222.792 24 1.772 24h20.451c.98 0 1.777-.778 1.777-1.73V1.73C24 .773 23.203 0 22.223 0ZM7.12 20.452H3.558V8.995H7.12v11.457ZM5.34 7.434a2.064 2.064 0 1 1 0-4.125 2.063 2.063 0 0 1 0 4.125Zm15.112 13.018h-3.558v-5.57c0-1.326-.024-3.037-1.852-3.037-1.851 0-2.133 1.449-2.133 2.944v5.663H9.356V8.995h3.413v1.566h.047c.473-.9 1.636-1.852 3.365-1.852 3.605 0 4.27 2.372 4.27 5.457v6.286Z\"\u003E\u003C/path\u003E\u003C/svg\u003E\u003C/div\u003E\u003C/a\u003E\u003Cdiv\u003E\u003C/div\u003E\u003C/div\u003E\u003C/div\u003E\u003Cdiv data-testid=\"snowflake-footer-facebook\" class=\"snowflake-button-icon snowflake-button-white snowflake-footer-social-item\"\u003E\u003Cdiv class=\"snowflake-button-icon \"\u003E\u003Ca href=\"https://www.facebook.com/snowflakedb/\" data-testid=\"button-external\" aria-label=\"Facebook\" role=\"button\" class=\"snowflake-button-container\" title=\"Facebook\" tabindex=\"0\" target=\"_blank\" rel=\"noreferrer\"\u003E\u003Cdiv data-testid=\"button-icon-wrapper\"\u003E\u003Csvg xmlns=\"http://www.w3.org/2000/svg\" fill=\"currentColor\" viewBox=\"0 0 24 24\" class=\"button-icon\"\u003E\u003Cpath d=\"M24 12c0-6.627-5.373-12-12-12S0 5.373 0 12c0 5.99 4.388 10.954 10.125 11.854V15.47H7.078V12h3.047V9.356c0-3.007 1.792-4.668 4.533-4.668 1.312 0 2.686.234 2.686.234v2.953H15.83c-1.491 0-1.956.925-1.956 1.875V12h3.328l-.532 3.469h-2.796v8.385C19.612 22.954 24 17.99 24 12Z\"\u003E\u003C/path\u003E\u003C/svg\u003E\u003C/div\u003E\u003C/a\u003E\u003Cdiv\u003E\u003C/div\u003E\u003C/div\u003E\u003C/div\u003E\u003Cdiv data-testid=\"snowflake-footer-youtube\" class=\"snowflake-button-icon snowflake-button-white snowflake-footer-social-item\"\u003E\u003Cdiv class=\"snowflake-button-icon \"\u003E\u003Ca href=\"https://www.youtube.com/user/snowflakecomputing\" data-testid=\"button-external\" aria-label=\"YouTube\" role=\"button\" class=\"snowflake-button-container\" title=\"YouTube\" tabindex=\"0\" target=\"_blank\" rel=\"noreferrer\"\u003E\u003Cdiv data-testid=\"button-icon-wrapper\"\u003E\u003Csvg xmlns=\"http://www.w3.org/2000/svg\" fill=\"currentColor\" viewBox=\"0 0 24 24\" class=\"button-icon\"\u003E\u003Cpath d=\"M23.76 7.2s-.233-1.655-.955-2.381c-.914-.956-1.936-.961-2.405-1.017-3.356-.244-8.395-.244-8.395-.244h-.01s-5.039 0-8.395.244c-.469.056-1.49.06-2.405 1.017C.473 5.545.244 7.2.244 7.2S0 9.145 0 11.086v1.819c0 1.94.24 3.886.24 3.886s.233 1.654.95 2.38c.915.957 2.115.924 2.65 1.027 1.92.183 8.16.24 8.16.24s5.044-.01 8.4-.249c.469-.056 1.49-.06 2.405-1.017.722-.727.956-2.381.956-2.381S24 14.85 24 12.905v-1.819c0-1.94-.24-3.886-.24-3.886ZM9.52 15.113V8.367l6.483 3.385-6.483 3.36Z\"\u003E\u003C/path\u003E\u003C/svg\u003E\u003C/div\u003E\u003C/a\u003E\u003Cdiv\u003E\u003C/div\u003E\u003C/div\u003E\u003C/div\u003E\r\n\u003C/div\u003E",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false}},":itemsOrder":["container","text_copy_copy_16360","markup_editor"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-none"}},":itemsOrder":["container"]},":type":"snowflake-site/components/flexible-column-container","isBlogPage":false,"isActiveTOC":false}},":itemsOrder":["flexible_column_cont"],"appliedCssClassNames":"snowflake-container snowflake-responsive-container-inner-padding-small"}},":itemsOrder":["container_112062425"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-none"},"markup_editor_copy":{"id":"markup-editor-d64c568b98","title":"New css","cssContent":".snowflake-image-container img{background-color:transparent}div.snowflake-person-chip-avatar{width:80px !important}#snowflake-blog-template-main-container .aem-GridColumn:has(.vertical-video){background-color:#000;border-radius:16px;overflow:hidden}#snowflake-blog-template-main-container .vertical-video{max-width:240px;margin-left:auto;margin-right:auto}@media screen and (min-width:1367px){.dynamic .heading-1-v2 .snowflake-title-v2-line{font-size:72px !important;line-height:60px !important}}.snowflake-flexible-column-container-items-alignment-match-height .download-card,.snowflake-flexible-column-container-items-alignment-match-height .download-card\u003E.container{height:100%}.download-card div.code-toolbar\u003E.toolbar .copy-to-clipboard-button{background-color:white;border:1px solid #a9e1f6;margin-right:4px;top:6px;border-radius:16px;height:26px;width:40px}.download-card .snowflake-code-snippet\u003Ediv.code-toolbar\u003E.toolbar\u003E.toolbar-item\u003Ebutton:before{content:'';background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='9' y='9' width='13' height='13' rx='2' ry='2' style='stroke:%23249EDC;'%3E%3C/rect%3E%3Cpath d='M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1' style='stroke:%23249EDC;'%3E%3C/path%3E%3C/svg%3E\");background-size:auto 65%;background-position:center;background-repeat:no-repeat;top:0;left:0;width:100%;height:100%}.download-card .snowflake-code-snippet\u003Ediv.code-toolbar\u003E.toolbar\u003E.toolbar-item\u003Ebutton:hover:before{background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='9' y='9' width='13' height='13' rx='2' ry='2' style='stroke:%23fff;'%3E%3C/rect%3E%3Cpath d='M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1' style='stroke:%23fff;'%3E%3C/path%3E%3C/svg%3E\")}.download-card\u003Ediv{background-color:#fff;border:1px solid #ccc;border-radius:8px;padding:24px}.download-chip__headline{border-bottom:1px solid #ccc;padding-bottom:16px;margin-bottom:16px}.download-chip{padding:8px 12px !important;border-radius:4px;transition:300ms ease background-color}.download-chip .black-blue-text-color .snowflake-title-v2-line{color:#000 !important;padding-right:24px;font-family:'Lato',sans-serif;font-size:14px !important;font-weight:500 !important}.download-chip .black-blue-text-color .snowflake-title-v2-line:not(:first-child){opacity:.6;font-style:italic !important}.download-chip .snowflake-content-chip-button{display:none}.download-chip.is-external-link{background-size:16px 16px;background-image:url(\"data:image/svg+xml,%3Csvg width='15' height='15' viewBox='0 0 15 15' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.06055 13.0607L11.8605 2.26067M13.0605 10.6607V1.06067H3.46055' stroke='%23249EDC' stroke-width='2.12132' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A\")}.download-chip{background-image:url(\"data:image/svg+xml,%3Csvg width='18' height='18' viewBox='0 0 18 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg clip-path='url(%23clip0_883_7979)'%3E%3Cpath d='M3.375 16.875H14.625' stroke='%23249EDC' stroke-width='1.40625' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M9 1.125V11.25' stroke='%23249EDC' stroke-width='1.40625' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M4.5 7.875L9 12.375L13.5 7.875' stroke='%23249EDC' stroke-width='1.40625' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='clip0_883_7979'%3E%3Crect width='18' height='18' fill='white'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E%0A\");background-size:24px auto;background-repeat:no-repeat;background-position:calc(100% - 12px) center}.download-chip__headline{display:flex;gap:16px;flex-direction:row !important;flex-wrap:nowrap}.download-chip__headline::before{content:'';display:inline-block;width:24px;height:24px;background-position:center;background-image:url(\"data:image/svg+xml,%3Csvg width='21' height='21' viewBox='0 0 21 21' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M7.50005 9.89999C8.13657 9.89999 8.74702 9.64713 9.19711 9.19704C9.64719 8.74696 9.90005 8.13651 9.90005 7.49999V2.69999C9.90005 2.06347 9.64719 1.45302 9.19711 1.00293C8.74702 .552844 8.13657 .299988 7.50005 .299988H2.70005C2.06353 .299988 1.45308 .552844 1.00299 1.00293C.552905 1.45302 .300049 2.06347 .300049 2.69999V7.49999C.300049 8.13651 .552905 8.74696 1.00299 9.19704C1.45308 9.64713 2.06353 9.89999 2.70005 9.89999H7.50005ZM7.50005 7.49999H2.70005V2.69999H7.50005V7.49999Z' fill='%23249EDC' stroke='white' stroke-width='.6'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M7.50005 20.3C8.13657 20.3 8.74702 20.0472 9.19711 19.5971C9.64719 19.147 9.90005 18.5365 9.90005 17.9V13.1C9.90005 12.4635 9.64719 11.853 9.19711 11.403C8.74702 10.9529 8.13657 10.7 7.50005 10.7H2.70005C2.06353 10.7 1.45308 10.9529 1.00299 11.403C.552905 11.853 .300049 12.4635 .300049 13.1V17.9C.300049 18.5365 .552905 19.147 1.00299 19.5971C1.45308 20.0472 2.06353 20.3 2.70005 20.3H7.50005ZM7.50005 17.9H2.70005V13.1H7.50005V17.9Z' fill='%23249EDC' stroke='white' stroke-width='.6'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M17.9001 9.89999C18.5366 9.89999 19.147 9.64713 19.5971 9.19704C20.0472 8.74696 20.3001 8.13651 20.3001 7.49999V2.69999C20.3001 2.06347 20.0472 1.45302 19.5971 1.00293C19.147 .552844 18.5366 .299988 17.9001 .299988H13.1001C12.4636 .299988 11.8531 .552844 11.403 1.00293C10.9529 1.45302 10.7001 2.06347 10.7001 2.69999V7.49999C10.7001 8.13651 10.9529 8.74696 11.403 9.19704C11.8531 9.64713 12.4636 9.89999 13.1001 9.89999H17.9001ZM17.9001 7.49999H13.1001V2.69999H17.9001V7.49999Z' fill='%23249EDC' stroke='white' stroke-width='.6'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M17.9001 20.3C18.5366 20.3 19.147 20.0472 19.5971 19.5971C20.0472 19.147 20.3001 18.5365 20.3001 17.9V13.1C20.3001 12.4635 20.0472 11.853 19.5971 11.403C19.147 10.9529 18.5366 10.7 17.9001 10.7H13.1001C12.4636 10.7 11.8531 10.9529 11.403 11.403C10.9529 11.853 10.7001 12.4635 10.7001 13.1V17.9C10.7001 18.5365 10.9529 19.147 11.403 19.5971C11.8531 20.0472 12.4636 20.3 13.1001 20.3H17.9001ZM17.9001 17.9H13.1001V13.1H17.9001V17.9Z' fill='%23249EDC' stroke='white' stroke-width='.6'/%3E%3C/svg%3E%0A\");background-size:contain;background-repeat:no-repeat}.download-chip__headline.is-cli::before{background-image:url(\"data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 17L10 11L4 5' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M12 19H20' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A\")}.download-card pre[class*=language-]{padding:8px 12px;background-color:var(--ui-background-05);overflow:hidden}.download-chip__headline.is-windows,.download-chip__headline.is-mac{gap:12px}.download-chip__headline.is-windows::before{width:16px;height:20px;background-image:url(\"data:image/svg+xml,%3Csvg width='4875' height='4875' viewBox='0 0 4875 4875' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg clip-path='url(%23clip0_122_201)'%3E%3Cpath d='M0 0H2311V2310H0V0ZM2564 0H4875V2310H2564V0ZM0 2564H2311V4875H0V2564ZM2564 2564H4875V4875H2564' fill='%23000'/%3E%3C/g%3E%3C/svg%3E\")}.download-chip__headline.is-mac::before{width:16px;height:20px;background-image:url(\"data:image/svg+xml,%3Csvg version='1.1' id='Layer_1' xmlns:x='ns_extend;' xmlns:i='ns_ai;' xmlns:graph='ns_graphs;' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' x='0' y='0' viewBox='0 0 41.5 51' style='enable-background:new 0 0 41.5 51;' xml:space='preserve'%3E%3Cmetadata%3E%3Csfw xmlns='ns_sfw;'%3E%3Cslices%3E%3C/slices%3E%3CsliceSourceBounds bottomLeftOrigin='true' height='51' width='41.5' x='166.1' y='-208.1'%3E%3C/sliceSourceBounds%3E%3C/sfw%3E%3C/metadata%3E%3Cg%3E%3Cpath d='M40.2,17.4c-3.4,2.1-5.5,5.7-5.5,9.7c0,4.5,2.7,8.6,6.8,10.3c-.8,2.6-2,5-3.5,7.2c-2.2,3.1-4.5,6.3-7.9,6.3s-4.4-2-8.4-2 c-3.9,0-5.3,2.1-8.5,2.1s-5.4-2.9-7.9-6.5C2,39.5,.1,33.7,0,27.6c0-9.9,6.4-15.2,12.8-15.2c3.4,0,6.2,2.2,8.3,2.2 c2,0,5.2-2.3,9-2.3C34.1,12.2,37.9,14.1,40.2,17.4z M28.3,8.1C30,6.1,30.9,3.6,31,1c0-.3,0-.7-.1-1c-2.9,.3-5.6,1.7-7.5,3.9 c-1.7,1.9-2.7,4.3-2.8,6.9c0,.3,0,.6,.1,.9c.2,0,.5,.1,.7,.1C24.1,11.6,26.6,10.2,28.3,8.1z'%3E%3C/path%3E%3C/g%3E%3C/svg%3E\")}.download-chip__headline.is-desktop::before{background-image:url(\"data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg opacity='.8'%3E%3Cpath d='M1.5 21H22.5V18H1.5V21Z' fill='%23000' stroke='white' stroke-width='.75'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M19.5 15C20.2956 15 21.0587 14.6839 21.6213 14.1213C22.1839 13.5587 22.5 12.7956 22.5 12V6C22.5 5.20435 22.1839 4.44129 21.6213 3.87868C21.0587 3.31607 20.2956 3 19.5 3H4.5C3.70435 3 2.94129 3.31607 2.37868 3.87868C1.81607 4.44129 1.5 5.20435 1.5 6V12C1.5 12.7956 1.81607 13.5587 2.37868 14.1213C2.94129 14.6839 3.70435 15 4.5 15H19.5ZM19.5 12H4.5V6H19.5V12Z' fill='%23000' stroke='white' stroke-width='.75'/%3E%3C/g%3E%3C/svg%3E%0A\")}.download-card .snowflake-code-snippet,.download-card .snowflake-code-snippet code,.download-card .snowflake-code-snippet pre{font-size:14px;color:#000;text-shadow:none !important}.download-chip:hover{background-color:var(--ui-background-05) !important;transition:300ms ease background-color}body:has(.snowflake-skip-to-content[style]) #subNav,.pushdown-banner-dismissed #subNav{top:var(--scroll-padding-top) !important;transition:300ms ease top}body:has(.snowflake-skip-to-content[style*=\"58\"]) #subNav{top:34px !important}body:has(.snowflake-skip-to-content[style*=\"82\"]) #subNav{top:58px !important}body:has(.snowflake-skip-to-content[style*=\"130\"]) #subNav{top:106px !important}body:has(.snowflake-skip-to-content[style*=\"138\"]) #subNav{top:114px !important}body:has(.snowflake-skip-to-content[style*=\"146\"]) #subNav{top:122px !important}.is-hidden .snowflake-person-chip-avatar{display:none}.is-small .snowflake-person-chip-avatar{width:56px;height:56px}.ai-summary ul{margin:16px 0 0 0 !important;padding:0 !important;list-style-type:none}.ai-summary li{margin:0;padding:0 0 0 32px;position:relative}.ai-summary li::before{content:\"\";display:block;border-radius:100%;background:#29b5e8;width:18px;height:18px;position:absolute;top:4px;left:0;border:5px solid #e5f2f7;box-sizing:border-box}.ai-summary li:not(:last-child){margin-bottom:1rem}.snowflake-content-chip-image__image{aspect-ratio:5 / 3 !important}.content-chip-new .snowflake-content-chip-image__image{height:100% !important;aspect-ratio:unset !important}.snapshot-card .snowflake-text p:not(:first-child){margin-top:var(--spacing-01)}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(2) p:has(b){font-family:'Texta',sans-serif;margin-top:24px}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(2) p b{font-weight:700 !important}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(2){border-bottom:1px solid #ccc;padding-bottom:24px}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(3) p:first-child:has(b){font-family:'Texta',sans-serif;font-size:20px !important;margin-bottom:1rem !important}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(3) li{display:inline-block}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(3) li a{display:inline-block;text-decoration:none;padding:4px 16px !important;border:1px solid #ccc;border-radius:24px;color:#666 !important}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(3) ul{list-style-type:none;display:flex;padding:0 !important;margin:0 !important;gap:12px}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container img{width:90%;max-width:240px;margin:0 auto}.snapshot-card\u003E.container\u003E.cmp-container\u003E.aem-container{padding:40px;max-width:450px;margin:0 0 0 auto;background-color:#fff;box-shadow:0 2px 6px 0 rgba(152,162,179,.25),0 10px 20px 0 rgba(152,162,179,.10);border-radius:8px;border-top:4px solid var(--ui-01)}.ai-summary{background-color:#f3fbfe;border-left:2px solid var(--ui-01);padding:40px}.ai-summary\u003Espan p:last-child:has(i){color:#666;font-size:14px !important}.ai-summary\u003Espan p:last-child:has(i) a{color:#666 !important;text-decoration:underline !important}.ai-summary\u003Espan p:last-child:has(i) a:hover{color:var(--ui-01) !Important}.ai-summary\u003Espan p:first-child:has(b)::after{content:'';display:inline-block;width:20px;height:20px;background-image:url(\"data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M9.3158 3.15226C8.6475 6.2258 6.22698 8.64545 3.15232 9.31587C2.94923 9.36072 2.94923 9.63928 3.15232 9.68413C6.22698 10.3522 8.6475 12.7742 9.3158 15.8477C9.36067 16.0508 9.63933 16.0508 9.6842 15.8477C10.3525 12.7742 12.773 10.3545 15.8477 9.68413C16.0508 9.63928 16.0508 9.36072 15.8477 9.31587C12.773 8.64781 10.3525 6.2258 9.6842 3.15226C9.63933 2.94925 9.36067 2.94925 9.3158 3.15226Z' fill='%23249EDC'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M17.3725 11.5461C16.9098 13.6739 15.2341 15.3491 13.1054 15.8132C12.9649 15.8443 12.9649 16.0371 13.1054 16.0681C15.2341 16.5307 16.9098 18.2074 17.3725 20.3353C17.4035 20.4758 17.5965 20.4758 17.6275 20.3353C18.0902 18.2074 19.7659 16.5323 21.8946 16.0681C22.0352 16.0371 22.0352 15.8443 21.8946 15.8132C19.7659 15.3507 18.0902 13.6739 17.6275 11.5461C17.5965 11.4055 17.4035 11.4055 17.3725 11.5461Z' fill='%23249EDC'/%3E%3C/svg%3E%0A\");background-repeat:no-repeat;background-size:contain;background-position:center;vertical-align:middle;margin-left:8px}.ai-summary\u003Espan p:first-child:has(b){color:var(--ui-01) !important;text-transform:uppercase}.border-top{border-top:1px solid rgba(0,0,0,.2)}.border-top\u003Espan{display:block;padding-top:32px}body .snowflake-card-v2-advanced-image__image{aspect-ratio:16 / 9 !important}.content-chip-new .snowflake-content-chip-image__image{border-radius:0;object-fit:cover;height:100%}.sf-footer #ot-sdk-btn.ot-sdk-show-settings,.sf-footer #ot-sdk-btn.optanon-show-settings{color:rgba(255,255,255,.7) !important;text-underline-offset:4px;border-top:none;border-left:none;border-right:none;border-bottom:1px dotted transparent;background-color:transparent !important;background-image:none !important;transition:300ms ease text-decoration-color;padding:0 !important;font-size:12px;font-family:'Lato',sans-serif}.sf-footer #ot-sdk-btn.ot-sdk-show-settings:hover,.sf-footer #ot-sdk-btn.optanon-show-settings:hover{color:rgba(255,255,255,1) !important;border-bottom:1px dotted var(--ui-01);transition:300ms ease text-decoration-color}.sf-footer__legal-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:last-child{flex-shrink:0}.sf-footer__disclaimers{background-color:#042130}.sf-footer__disclaimers .snowflake-simple-stat-disclaimer p a{color:inherit;text-decoration:none !important}.sf-footer__disclaimers .snowflake-simple-stat-disclaimer p sup{margin-right:2px}.sf-footer__disclaimers .snowflake-simple-stat-disclaimer p{text-indent:-5px;padding-left:5px}.sf-footer__disclaimers-inner{border-top:1px solid rgba(255,255,255,.25);padding:40px 0}.sf-footer__disclaimers .snowflake-simple-stat{align-items:flex-start;text-align:left;color:rgba(255,255,255,.7);margin-bottom:10px}.sf-footer__social{display:flex;justify-content:center;gap:12px}.sf-footer .snowflake-footer-social-item{margin:0 !important}.sf-footer .snowflake-footer-social-item a{line-height:0;background-color:rgba(3,24,35,.8);display:inline-block;width:48px !important;height:48px;border-radius:8px;display:inline-flex;justify-content:center;align-items:center;transition:300ms ease background-color}.sf-footer .snowflake-footer-social-item a:hover{background-color:var(--ui-01) !important;transition:300ms ease background-color}.sf-footer__bottom{padding-bottom:40px}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoError .mktoErrorMsg{max-width:100%;color:#fff}.sf-footer .mktoForm .mktoError .mktoErrorMsg .mktoErrorDetail{display:inline-block}.sf-footer .mktoFormRow:has(.mktoHtmlText:empty){display:none}.sf-footer .mktoFormRow .mktoHtmlText span{color:#fff !important}.sf-footer{background-color:#042130}.sf-footer .optanon-toggle-display:hover{text-decoration-color:var(--ui-01) !important;cursor:pointer !important;text-underline-offset:4px;text-decoration-style:dotted !important;text-decoration-color:var(--ui-01);color:#fff !important;transition:300ms ease text-decoration-color;text-decoration:underline;opacity:1}.sf-footer__logo{width:40px}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container{row-gap:32px}.sf-footer__legal-container\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;justify-content:space-between;align-items:center;text-align:center;row-gap:16px}.sf-footer__legal-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:nth-child(2){text-align:center;flex-grow:1}.sf-footer__legal-links li button,.sf-footer__legal-links li a,.sf-footer__legal-links li{margin:0;color:rgba(255,255,255,.7) !important;font-weight:500}.sf-footer__legal-links li a:hover{color:rgba(255,255,255,1) !important}.sf-footer div.sf-footer__copyright p,.sf-footer div.sf-footer__legal-links li,.sf-footer div.sf-footer__legal-links a,.sf-footer div.sf-footer__legal-links p{font-size:12px !important}.sf-footer__legal-links ul{list-style-type:none;margin:0;padding:0;display:flex;gap:20px;row-gap:4px;justify-content:center;flex-wrap:wrap;text-align:center}.sf-footer__legal-links li:last-child{width:100%}.sf-footer .mktoFormRow:has(.mktoPlaceholder),.sf-footer .mktoFormRow:has(input[type=\"hidden\"]){display:none !important}.sf-footer .mktoFormCol{margin-bottom:0 !important}.sf-footer label[for=\"adhoc1\"]{width:auto !important;flex-grow:1;margin-left:16px}.sf-footer .mktoFieldWrap:has(label[for=\"adhoc1\"]){display:flex;flex-direction:row-reverse;margin-top:22px}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoCheckboxList input[type=checkbox]{background-color:transparent !important;border:1px solid rgba(255,255,255,.4) !important;border-radius:4px !important}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoEmailField,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoTelField,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoTextField,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap select{background-color:transparent !important;color:#fff !important;height:auto !important;border:1px solid rgba(255,255,255,.4) !important;border-radius:4px !important;padding:12px 18px !important}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoEmailField:focus,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoTelField:focus,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoTextField:focus,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap select:focus{border-color:var(--ui-01) !important}.sf-footer .mktoForm *{padding:0 !important}.sf-footer .mktoForm,.sf-footer .snowflake-marketo-form-container{padding:0 !important;background:transparent;margin-bottom:0;box-shadow:none}.sf-footer .mktoHtmlText.mktoHasWidth{width:100% !important;margin:24px 0}.sf-footer .mktoFormRow{flex-direction:column}.sf-footer .mktoForm .mktoButtonWrap{margin:0 !important}.sf-footer select{background-image:url(\"data:image/svg+xml,%3Csvg width='14' height='8' viewBox='0 0 14 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M.981445 1.43496L6.90897 7.32496L12.9314 1.33496' stroke='white' stroke-width='1.33333' stroke-miterlimit='10' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A\") !important}.sf-footer .snowflake-marketo-form .mktoButtonWrap.mktoNative{justify-content:flex-start}.sf-footer *::placeholder{color:#fff !important;opacity:.8}.sf-footer .mktoForm .mktoButtonWrap.mktoSimple .mktoButton{background-color:var(--ui-01) !important;color:#fff !important;width:100% !important;padding:12px 16px !important;border:1px solid var(--ui-01) !important;background-image:none !important;border-radius:48px;text-transform:uppercase;font-weight:800 !important;font-family:'Texta',sans-serif !important;font-size:16px !important;line-height:1.2}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoHtmlText\u003Espan,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap .mktoLabel\u003Espan,.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap label.mktoLabel{color:#fff !important}.sf-footer__newsletter-title p:not(:first-child){margin-top:8px !important}.sf-footer__newsletter-title p b{font-weight:800 !important;font-family:'Texta',sans-serif !important;font-size:22px !important;line-height:1.2}.sf-footer__newsletter-title p:last-child{font-size:14px !important;opacity:.8}.sf-footer__link-group li a[target=\"_blank\"]::after{content:'';display:inline-block;width:10px;height:10px;margin-left:5px;background-image:url(\"data:image/svg+xml,%3Csvg width='11' height='11' viewBox='0 0 11 11' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6.72222 1.22222C6.38471 1.22222 6.11111 .948616 6.11111 .611111C6.11111 .273607 6.38471 0 6.72222 0H10.3889C10.551 0 10.7064 .0643867 10.821 .178988C10.9356 .293596 11 .449032 11 .611111V4.27778C11 4.61529 10.7264 4.88889 10.3889 4.88889C10.0514 4.88889 9.77778 4.61529 9.77778 4.27778V2.08647L4.09879 7.76545C3.86013 8.00409 3.4732 8.00409 3.23454 7.76545C2.99589 7.52681 2.99589 7.13986 3.23454 6.90122L8.91355 1.22222H6.72222ZM0 2.44444C0 1.76943 .547207 1.22222 1.22222 1.22222H4.27778C4.61529 1.22222 4.88889 1.49583 4.88889 1.83333C4.88889 2.17084 4.61529 2.44444 4.27778 2.44444H1.22222V9.77778H8.55556V6.72222C8.55556 6.38471 8.82915 6.11111 9.16667 6.11111C9.50418 6.11111 9.77778 6.38471 9.77778 6.72222V9.77778C9.77778 10.4528 9.23059 11 8.55556 11H1.22222C.547207 11 0 10.4528 0 9.77778V2.44444Z' fill='white'/%3E%3C/svg%3E%0A\");background-size:contain;background-repeat:no-repeat;background-position:center}.sf-footer__link-group ul,.sf-footer__link-group li{margin:0;padding:0;list-style-type:none}.sf-footer__link-group ul{margin-top:20px !important}.sf-footer__link-group li{margin-top:15px}.sf-footer div.sf-footer__link-group\u003Espan\u003Ep\u003Ea,.sf-footer div.sf-footer__link-group\u003Espan\u003Ep{color:var(--ui-01) !important;font-weight:800 !important;font-family:'Texta',sans-serif !important;font-size:20px !important;line-height:1.2}.sf-footer__link-group li a{opacity:.9;color:#fff !important;font-weight:500 !important;font-size:15px !important;line-height:1.3}.sf-footer__link-group li a:hover{opacity:1}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container::before,.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container::after{display:none}.sf-footer__column{flex-grow:1}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:not(:first-child){width:50%}@media (min-width:800px){.sf-footer__legal-links ul{justify-content:flex-start;text-align:left}.sf-footer__social{justify-content:flex-end}.sf-footer__legal-links ul{padding-left:24px}.sf-footer__legal-container\u003E.container\u003E.cmp-container\u003E.aem-container{text-align:right;flex-wrap:nowrap}.sf-footer__legal-links.align-left ul{justify-content:flex-start}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;justify-content:space-between;flex-direction:row}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:auto !important;max-width:200px}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{flex-grow:1;order:2;width:100% !important;max-width:none}.sf-footer__legal-container\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:auto}}@media screen and (min-width:1380px){.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container{flex-wrap:nowrap}.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{padding-right:48px;max-width:380px;background-color:rgba(3,24,35,.4);padding:32px;margin-left:48px;border-radius:16px}.sf-footer__link-group li,.sf-footer__link-group li a{font-size:14px !important;line-height:1.3}}@media screen and (max-width:991px){.sf-footer-grid__inner\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv:first-child{order:2;margin-top:24px !important}}@media screen and (max-width:420px){.is-reduced-mobile .heading-1-v2,.is-reduced-mobile .heading-1-v2-sm{font-size:32px;line-height:28px}}.quote-content-chip{background-color:var(--ui-background-05);padding:24px;border-radius:12px;position:relative}.quote-content-chip .black-blue-text-color .snowflake-title-v2-line\u003Espan{color:rgba(0,0,0,.8) !important;font-size:15px !important;line-height:1.5 !important;font-family:'Lato',sans-serif;font-weight:400 !important}.quote-content-chip .black-blue-text-color .snowflake-title-v2-line\u003Espan:not(:first-child){max-width:calc(100% - 200px)}.quote-content-chip .black-blue-text-color .snowflake-title-v2-line\u003Espan:nth-child(2){font-family:'Texta',sans-serif;color:#000 !important;font-size:20px !important;font-weight:800 !important;margin-top:24px}.quote-content-chip .snowflake-content-chip-image{width:140px !important}@media screen and (min-width:992px){.quote-content-chip .snowflake-content-chip-image{position:absolute !important;bottom:24px;right:16px}}@media screen and (max-width:991px){.quote-content-chip .snowflake-content-chip-image{margin-bottom:40px}.quote-content-chip{flex-direction:column}}#spa-root{background-color:#fff}.lowercase .snowflake-title-v2-line{text-transform:none !important}.centered .snowflake-logo-content-container-inner{justify-content:center}div.snowflake-linklist-dropdown-menu{max-height:380px}.first-line-blue .snowflake-typographyv2 .snowflake-title-v2-line:first-child{color:var(--ui-01) !important}.is-front{position:relative;z-index:2}.use-case-body .snowflake-text h1,.use-case-body .snowflake-text h2,.use-case-body .snowflake-text h3,.use-case-body .snowflake-text h4,.use-case-body .snowflake-text h5,.use-case-body .snowflake-text h6{font-family:'Texta',sans-serif;color:#000;margin:.25rem 0 0 0}.pc-hero .button-group\u003E.container\u003E.cmp-container\u003E.aem-container{justify-content:flex-start}.sf-footer .mktoFormRow .mktoHtmlText span{font-family:'Lato',sans-serif !important}.snowflake-button-primary.snowflake-button-blue .snowflake-button-container{justify-content:center}.related-chip-25{background-color:#fff;border:1px solid rgba(204,204,204,.5);border-radius:8px;padding:20px;position:relative}.related-chip-25:hover{box-shadow:rgba(152,162,179,.1) 0 10px 20px 0}.related-chip-25:hover::after{right:24px;transition:300ms ease right}.related-chip-25::after{content:'';display:block;transition:300ms ease right;background-image:url(\"data:image/svg+xml,%3Csvg width='8' height='14' viewBox='0 0 8 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M7.66699 7C7.66699 6.6571 7.53559 6.32825 7.30169 6.08578L2.34446 .947072C1.84529 .429617 1.0164 .429617 .517219 .947072C.0427878 1.43887 .042788 2.21798 .517219 2.70978L4.65591 7L.51722 11.2902C.0427889 11.782 .0427887 12.5611 .51722 13.0529C1.0164 13.5704 1.84529 13.5704 2.34447 13.0529L7.30169 7.91421C7.53559 7.67175 7.66699 7.34289 7.66699 7Z' fill='%2329B5E8'/%3E%3C/svg%3E%0A\");width:8px;height:14px;display:block;position:absolute;right:30px;top:50%;transform:translateY(-50%);background-size:contain;background-position:center;background-repeat:no-repeat}.related-chip-25 .heading-5-v2{font-size:22px;line-height:1.1}.related-chip-25 .snowflake-content-chip-image{width:48px;flex-shrink:0}.related-chip-25 .snowflake-content-chip-image__image{aspect-ratio:1;height:auto;object-fit:contain}.related-chip-25 .snowflake-content-chip-button{display:none}.related-chip-25 .snowflake-content-chip-content-without-tag{flex-grow:1;padding-right:24px}.case-study-25.small-logo .snowflake-case-study-card-logo img{width:60px !important}.swiper-slide .case-study-25{width:95%;margin-left:auto;margin-right:auto}.case-study-25 .snowflake-case-study-card-logo img{width:140px !important;height:auto !important;transform:none !important;margin:24px 0 8px 0}.case-study-25 .snowflake-case-study-card-image__image{object-position:left center}.case-study-25 .snowflake-case-study-card-information-container{padding-right:24px}.case-study-25 ul{list-style-type:none;padding:0;margin:8px 0 0 0}.case-study-25 li{font-size:15px !important;line-height:1.3 !important;display:flex;flex-direction:column;border-left:4px solid var(--ui-01);padding-left:24px;margin-top:24px;color:#535862;gap:4px}.case-study-25 li b{display:block;font-family:'Texta',sans-serif;font-weight:900 !important;font-size:48px !important;line-height:.9 !important;color:var(--ui-01)}.case-study-25 .snowflake-case-study-card-description p{color:#535862}.case-study-25 .snowflake-case-study-card-description p:nth-child(2):not(:has(a)){color:#000;font-family:Texta;font-size:30px !important;line-height:1 !important;font-style:normal;font-weight:700;text-indent:-8px}.case-study-25.is-story .snowflake-case-study-card-description p:nth-child(2):not(:has(a)){text-indent:0}.case-study-25 .snowflake-case-study-card-key-card{background-color:transparent}.case-study-25 .snowflake-case-study-card-button{display:none}.case-study-25{border-radius:24px;overflow:hidden}@media screen and (min-width:1024px){.case-study-25 .snowflake-case-study-card-left-container{position:static;width:60%;min-height:0}.case-study-25 .snowflake-case-study-card-right-container::after{content:'';display:block;width:60%;max-width:340px;padding-bottom:50%;background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 22 16' class='snowflake-pushdown-banner-placeholder-arrow'%3E%3Cpath fill='%2329B5E8' fill-rule='evenodd' d='M17.865 8.756c.088-.274.124-.555.118-.834a2.551 2.551 0 0 0-1.3-2.142L7.887.76C6.645.055 5.063.475 4.35 1.7a2.535 2.535 0 0 0 .947 3.494l4.916 2.809-4.916 2.801a2.543 2.543 0 0 0-.947 3.502c.713 1.222 2.295 1.64 3.537.934l8.796-5.024a2.541 2.541 0 0 0 1.182-1.46Z' clip-rule='evenodd'%3E%3C/path%3E%3C/svg%3E\");background-size:contain;background-repeat:no-repeat;position:absolute;top:-10%;left:-20%}.case-study-25 .snowflake-case-study-card-right-container{max-width:none;width:40%;position:absolute;top:-5%;right:-5%;z-index:0;height:110%}}@media screen and (min-width:768px){.case-study-25 li{max-width:50%}.case-study-25 ul{display:flex;gap:48px}}.snowflake-text.section-eyebrow p{margin-left:auto;margin-right:auto;margin-bottom:16px !important}.snowflake-text.section-eyebrow p,.snowflake-text.eyebrow-text p{text-transform:uppercase;font-family:'Texta',sans-serif !important;font-weight:800 !important;letter-spacing:.025em;margin-bottom:12px;line-height:1.1 !important}.snowflake-title-v2.dynamic .heading-2-v2 span.snowflake-title-v2-line{font-size:clamp(2.5rem,4.5vw,4rem) !important;line-height:.82 !important}.checklist ul{padding:0;margin:0}.checklist ul li{list-style-type:none;padding-left:32px;position:relative}.checklist ul li:not(:last-child){margin-bottom:1em}.checklist ul li::before{content:'';display:inline-block;width:20px;height:20px;background-image:url(\"data:image/svg+xml,%3Csvg width='24' height='25' viewBox='0 0 24 25' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect y='.985352' width='24' height='24' rx='12' fill='%23D4F0FA'/%3E%3Cpath d='M7.28613 13.2967L10.7147 16.7253L17.5718 9.86816' stroke='%2329B5E8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A\");background-size:contain;background-repeat:no-repeat;position:absolute;top:3px;left:0}.last-line-blue .snowflake-typographyv2 .snowflake-title-v2-line:last-child{color:var(--ui-01)}.snowflake-text p sup{line-height:0}.snowflake-title-v2.lowercase .heading-3-v2{font-size:28px;line-height:1;text-transform:none;font-weight:700}.snowflake-title-v2.lowercase .heading-2-v2{font-size:32px;line-height:1;text-transform:none;font-weight:700}.content-chip-new{border:1px solid rgba(204,204,204,.5);border-radius:16px;overflow:hidden}.content-chip-new .snowflake-image-container{border-radius:0;display:none}.content-chip-new .snowflake-content-chip-image{margin-right:0;max-width:180px;flex-shrink:0}.content-chip-new .snowflake-content-chip-content{padding:24px}.content-chip-new .black-blue-text-color .snowflake-title-v2-line:first-child{font-size:24px;line-height:1.1}.content-chip-new .black-blue-text-color .snowflake-title-v2-line:not(:first-child){font-family:'Lato',sans-serif;font-size:17px;color:#535862 !important;font-weight:500;line-height:1.45;margin-top:8px;display:none}div.snowflake-text a{font-weight:normal;color:var(--ui-01);text-decoration:underline;text-underline-offset:4px;text-decoration-style:dotted !important;text-decoration-color:transparent;transition:300ms ease text-decoration-color}div.snowflake-text a:hover{text-decoration-color:var(--ui-01);transition:300ms ease text-decoration-color}.footer-nav__link-group .snowflake-button-container,.subnav__item--button,.snowflake-card-v2-advanced-button .snowflake-button-container{justify-content:flex-start}.button-container\u003E.container\u003E.cmp-container\u003E.aem-container{align-items:center}.button-container\u003E.container\u003E.cmp-container\u003E.aem-container .snowflake-button-primary+.snowflake-button-link{margin-left:12px !important}.snowflake-button-regular.snowflake-button-link .snowflake-button-container{font-size:18px !important;text-align:left;justify-content:flex-start;line-height:1.4 !important}body .snowflake-card-v2-advanced{border:1px solid rgba(204,204,204,.5);border-radius:var(--spacing-02);transition:300ms ease all}body .snowflake-card-v2-advanced:hover{transform:translateY(-10px);box-shadow:rgba(152,162,179,.1) 0 10px 20px 0;transition:300ms ease all}body .snowflake-card-v2-advanced-inner{border-bottom:none}body .snowflake-card-v2-advanced-image{line-height:0}body .snowflake-card-v2-advanced-image__image{aspect-ratio:16 / 9}body .snowflake-card-v2-advanced-content{position:relative}body .snowflake-card-v2-advanced-content::after{content:'';display:block;position:absolute;bottom:0;left:0;transition:300ms ease all;width:20%;height:4px;background-color:var(--ui-01);opacity:0}body .snowflake-card-v2-advanced:hover .snowflake-card-v2-advanced-content::after{width:100%;opacity:1;transition:300ms ease all}body .snowflake-card-v2-advanced .snowflake-button-link.snowflake-button-blue .snowflake-button-container\u003E.link-icon{transition:300ms ease transform}body .snowflake-card-v2-advanced:hover .snowflake-button-link.snowflake-button-blue .snowflake-button-container\u003E.link-icon{transform:translateX(4px);transition:300ms ease transform}.six-columns\u003E.container\u003E.cmp-container\u003E.aem-container,.three-columns\u003E.container\u003E.cmp-container\u003E.aem-container,.four-columns\u003E.container\u003E.cmp-container\u003E.aem-container,.five-columns\u003E.container\u003E.cmp-container\u003E.aem-container{display:flex;flex-wrap:wrap;gap:24px}.six-columns.align-center\u003E.container\u003E.cmp-container\u003E.aem-container,.three-columns.align-center\u003E.container\u003E.cmp-container\u003E.aem-container,.four-columns.align-center\u003E.container\u003E.cmp-container\u003E.aem-container,.five-columns.align-center\u003E.container\u003E.cmp-container\u003E.aem-container{justify-content:center}.three-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:100%;margin:0 !important}.six-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv,.four-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv,.five-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(50% - 12px);margin:0 !important}@media screen and (min-width:768px){.three-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(50% - 12px)}.six-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv,.four-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv,.five-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(33.333% - 16px)}}@media screen and (min-width:1024px){.snowflake-title-v2.lowercase .heading-3-v2{font-size:34px}.snowflake-title-v2.lowercase.larger .heading-2-v2{font-size:44px;line-height:.95}.three-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(33.333% - 16px)}.four-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(25% - 18px)}.five-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(20% - 19.2px)}.six-columns\u003E.container\u003E.cmp-container\u003E.aem-container\u003Ediv{width:calc(16.6666% - 20px)}.snowflake-title-v2.lowercase .heading-3-v2{font-size:28px !important}}@media screen and (min-width:1200px){.snowflake-title-v2.lowercase .heading-2-v2{font-size:40px}.content-chip-new .snowflake-content-chip-content{padding:32px}.content-chip-new .snowflake-image-container,.content-chip-new .black-blue-text-color .snowflake-title-v2-line:not(:first-child){display:block}}.promo-banner-25{border-radius:16px;overflow:hidden}.promo-banner-25 .snowflake-premium-content-banner-image-container{position:relative;max-width:380px}.promo-banner-25 .snowflake-text{color:#535862}.promo-banner-25 .snowflake-premium-content-banner-image__image{transform:translateY(8px);transition:300ms ease transform;border-radius:0;width:85%;margin:0 auto;display:block;position:relative;z-index:1}.promo-banner-25 .snowflake-premium-content-banner-image__link:hover .snowflake-premium-content-banner-image__image{transform:translateY(0);transition:300ms ease transform}.promo-banner-25 .snowflake-premium-content-banner-image__inner{height:auto;padding-top:24px}.promo-banner-25 .snowflake-premium-content-banner-image__link{position:relative;z-index:1;height:auto}.promo-banner-25 .snowflake-premium-content-banner-image__link::after{content:'';display:block;position:absolute;clip-path:polygon(0 0,66% 0,100% 100%,0 100%);bottom:0;left:0;width:100%;height:100%;background:var(--ui-01);transition:300ms ease width}.promo-banner-25 .snowflake-premium-content-banner-image__link:hover::after{width:110%;transition:300ms ease width}.sf-footer .snowflake-marketo-form .mktoFormRow .mktoFieldWrap select{background-position:95% 50%}.sf-footer__disclaimers .text-size-small .snowflake-text p{color:#fff !important;font-size:10px !important;opacity:.8}@media screen and (min-width:768px){.sf-footer__disclaimers .text-size-small .snowflake-text p{font-size:12px !important}}@media screen and (max-width:1023px){.mobile-top-padding{padding-top:64px}}@media (max-width:799px){.sf-footer .snowflake-marketo-form .mktoButtonWrap.mktoNative .mktoButton{width:100% !important}.sf-footer__logo{text-align:center;display:block;margin:0 auto}}.customer-card .snowflake-card-v2-advanced-image{aspect-ratio:4.35 / 1}.customer-card .snowflake-card-v2-advanced-image__image{width:100%;height:100%;padding-left:8px;object-fit:contain;object-position:left center;margin:0 !important;aspect-ratio:initial}.customer-card .snowflake-card-v2-advanced-image__inner{height:110px}.customer-card .snowflake-card-v2-advanced-tag-indicator{display:none}.pc-hero .snowflake-container-arrow-small-gray-image{top:-34% !important;width:18% !important}.pc-hero .snowflake-container-arrow-small-gray-image path{fill:var(--ui-01);opacity:1}@media screen and (max-width:767px){.mobile-padding-top{padding-top:64px}.hide-mobile{display:none !important}.pc-hero{padding-top:52px}.pc-hero .snowflake-text p,.pc-hero .left-alignment .snowflake-title-v2-line,.pc-hero h1 span{text-align:center !important}}div.snowflake-pushdown-banner-button{margin-top:0}.button-group.align-center\u003E.container\u003E.cmp-container\u003E.aem-container{align-items:center;justify-content:center !important}.text-center .snowflake-breadcrumb-swiper .swiper-wrapper{justify-content:center}div.snowflake-breadcrumb a.snowflake-breadcrumb-item,.snowflake-breadcrumb div.snowflake-breadcrumb-item{text-transform:none;font-weight:500}.snowflake-breadcrumb svg{display:none !important}.snowflake-breadcrumb a:has(svg)::after{content:'/';margin:0 12px;color:#666}.hide-filters .snowflake-filterable-and-searchable-grid-top-part{display:none !important}.page-section{padding-left:24px;padding-right:24px}@media screen and (min-width:768px){.page-section{padding-left:48px;padding-right:48px}}.download-card pre[class*=language-]{overflow-x:scroll !important}",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false}},":itemsOrder":["container_copy","container_573483281_","markup_editor_copy"]}},":itemsOrder":["root"],"classNames":"aem-xf"},"markup_editor":{"id":"markup-editor-b725102418","title":"Quickstarts Overrides","cssContent":".snowflake-markdown blockquote{padding:24px 32px;background:#f6f9fa;border:1px solid #29b5e8;border-radius:16px}.snowflake-markdown .snowflake-image-container img{width:auto !important;max-width:100%}.snowflake-markdown .snowflake-text ol{padding-left:20px !important}.snowflake-markdown .snowflake-text li{margin:0 0 12px 0 !important}.snowflake-markdown h3.snowflake-markdown-h3{font-size:20px !important;font-family:Texta,sans-serif !important}@media (min-width:768px){.snowflake-markdown h3.snowflake-markdown-h3{font-size:28px !important}}",":type":"snowflake-site/components/markup-editor","isGSAPEnabled":false}},":itemsOrder":["experiencefragment-banner","experiencefragment-header","markup_editor_1950346551","responsivegrid","modal_container","experiencefragment-footer","markup_editor"],":type":"wcm/foundation/components/responsivegrid"}},":itemsOrder":["root"],":hierarchyType":"page",":path":"/content/snowflake-site/global/en/developers/guides/streamsets-transformer-for-snowflake-hol","locale":"en"}
  