{"clientlibsAsync":false,"dataLayerClientlibIncluded":true,"dataLayerName":"adobeDataLayer","allowedRenditionsWidth":["320","480","640","768","960","1200","1440","1920"],"templateName":"quickstart-page-template","designPath":"/libs/settings/wcm/designs/default","brandSlug":"","componentsResourceTypes":["snowflake-site/components/quickstart/quickstart-button","snowflake-site/components/nav/nav-column/nav-column-container","snowflake-site/components/structure/page","snowflake-site/components/button","snowflake-site/components/quickstart/quickstart-hero","snowflake-site/components/quickstart/quickstart-table-of-content","snowflake-site/components/experiencefragment","snowflake-site/components/mega-header","snowflake-site/components/modal/modal-container","snowflake-site/components/image","snowflake-site/components/nav/nav-dropdown-header","snowflake-site/components/wistia-video/cta","nt:folder","snowflake-site/components/container","snowflake-site/components/nav/nav-dropdown-menu","snowflake-site/components/nav/nav-column","snowflake-site/components/flexible-column-container","snowflake-site/components/quickstart/quickstart-table-of-content/quickstart-table-of-content-container","snowflake-site/components/button/embedded","snowflake-site/components/icon","snowflake-site/components/nav/nav-mega","cq:LiveCopy","snowflake-site/components/quickstart/quickstart-last-modified","snowflake-site/components/nav/nav-promo-section","snowflake-site/components/markup-editor","snowflake-site/components/text","snowflake-site/components/title-v2","snowflake-site/components/nav/nav-dropdown-footer","nt:unstructured","nt:file","snowflake-site/components/contentfragment","snowflake-site/components/nav/nav-item","snowflake-site/components/nav/nav-promo-card","snowflake-site/components/form/marketo-v2","snowflake-site/components/nav/language-navigation","snowflake-site/components/title","wcm/foundation/components/responsivegrid","nt:resource","snowflake-site/components/structure/xfpage","snowflake-site/components/flexible-column-container/flexible-column-content-container","snowflake-site/components/pushdown-banner"],"cssClassNames":"page basicpage summit-page","description":"Getting Started with Openflow PostgreSQL Change Data Capture (CDC)","language":"en","lastModifiedDate":1779218638570,"title":"Getting Started with PostgreSQL CDC","tags":["snowflake-site:taxonomy/solution-center/certification/quickstart","snowflake-site:taxonomy/product/platform","snowflake-site:taxonomy/snowflake-feature/postgres","snowflake-site:taxonomy/snowflake-feature/transformation","snowflake-site:taxonomy/snowflake-feature/openflow","snowflake-site:taxonomy/snowflake-feature/ingestion"],"analyticsPageType":"quickstart-page-template","analyticsCategory":"general","analyticsSubCategory":"","excludeFromAnalytics":false,"analyticsData":{"excludeFromAnalytics":false,"subCategory":"","pageType":"quickstart-page-template","templateName":"quickstart-page-template","siteName":"snowflake","pageUrl":"/content/snowflake-site/global/en/developers/guides/getting-started-with-openflow-postgresql-cdc","language":"en","category":"general","pageName":"Getting Started with PostgreSQL CDC","contentTags":["snowflake-site:taxonomy/solution-center/certification/quickstart","snowflake-site:taxonomy/product/platform","snowflake-site:taxonomy/snowflake-feature/postgres","snowflake-site:taxonomy/snowflake-feature/transformation","snowflake-site:taxonomy/snowflake-feature/openflow","snowflake-site:taxonomy/snowflake-feature/ingestion"]},"coveoConfig":{"organizationId":"snowflakecomputingproduction8neljofn","apiKey":"xx335921a6-2a0a-40f2-a167-e390b4766c3d","pipeline":"snowflake.com","searchHub":"snowflake.com"},":mappedPath":"/en/developers/guides/getting-started-with-openflow-postgresql-cdc/",":type":"snowflake-site/components/structure/page",":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-4ed14af80b","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-598b796574",":type":"snowflake-site/components/container",":items":{"pushdown_banner_copy":{"id":"pushdown-banner-0243a034b8","contentHeadline":"Summit Builder Keynote Debut","contentDescription":"Broadcast live on June 23","contentJustifyContent":"center","linkStyle":"text-white","linkCTA":{"id":"link-cta","heapButtonClasses":["pushdown_banner"],"showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://reg.snowflake.com/flow/snowflake/summit26/digitalreg/page/main"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","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-df70a62240","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-2ef3ff657a",":type":"snowflake-site/components/container",":items":{"markup_editor":{"id":"markup-editor-5fb8a6f350","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}","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"},"mega_header":{"additionalClasses":"heap-nav-header","layout":"SIMPLE","id":"container-e4e4fd2da9",":type":"snowflake-site/components/mega-header",":items":{"nav_mega":{"activeItem":"item_1719963657751_c_663444255","id":"tabs-6ec8551f25",":type":"snowflake-site/components/nav/nav-mega",":items":{"item_1719963657751_c_663444255":{"id":"nav-dropdown-menu-2bbab98ab3","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-920bf10312",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column":{"additionalClasses":"nav-platform-sidebar","numberOfSubColumns":"one-column","minWidth":"230","maxWidth":"350","layout":"SIMPLE","id":"container-74310b9685",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_copy_2_793631646":{"id":"nav-item-73e495ca48","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"The Snowflake Platform"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-34bc762051","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Snowflake CoWork"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy_2_836345186":{"id":"nav-item-8d0cd34cdf","additionalClasses":"blue-icon is-analytics","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/analytics/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Analytics"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy_2":{"id":"nav-item-d44264b236","additionalClasses":"blue-icon is-ai","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/ai/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"AI"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy_2_1314771042":{"id":"nav-item-982f8f1379","additionalClasses":"blue-icon is-data-eng","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/data-engineering/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Data Engineering"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_144634":{"id":"nav-item-dd4b8dfd57","additionalClasses":"blue-icon is-apps-collab","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/applications-and-collaboration/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Applications & Collaboration"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_144634_2013333117":{"id":"nav-item-19ce9abdcb","additionalClasses":"blue-icon is-transactions","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/product/transactions/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","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","layout":"SIMPLE","id":"container-6c3d462e94",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_212715":{"id":"nav-item-1eb5fc1ee3","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Snowflake CoCo"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-cd6b75425e","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Cortex AI"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590635":{"id":"nav-item-41a1d327d4","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Marketplace"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590":{"id":"nav-item-70919ee447","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Snowpark"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590_983061516":{"id":"nav-item-769277e325","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","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","layout":"SIMPLE","id":"container-cef80a34c7",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_660590_1739526127":{"id":"nav-item-536ff11308","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Postgres"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_185565":{"id":"nav-item-d6ef8b346d","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Snowflake ML"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_212715":{"id":"nav-item-9c0665ee82","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Openflow"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590":{"id":"nav-item-634d275edf","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Notebooks"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_258535199":{"id":"nav-item-766c7866cb","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","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","layout":"SIMPLE","id":"container-514bd6cf3a",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy":{"id":"nav-item-8eb3090ce4","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Horizon Catalog"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_660590_1293798742":{"id":"nav-item-73ef6d61e4","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Horizon Context"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_511717659_c":{"id":"nav-item-f171f6c142","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Unistore"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_511717659_c_1443811525":{"id":"nav-item-655e4b61cc","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Observe"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_511717659_c_1006104884":{"id":"nav-item-3e05fa070c","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","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-2467cfc392","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-04b78f9f71",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column":{"navColumnTitle":"INDUSTRIES","numberOfSubColumns":"one-column","minWidth":"280","layout":"SIMPLE","id":"container-17a8ca7b18",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_361384_2056203141":{"id":"nav-item-b72577922e","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"All Industries"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-be2ae8f0f7","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/advertising-media-entertainment/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Advertising, Media & Entertainment"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-5da3c46214","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/financial-services/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Financial Services"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1970515619":{"id":"nav-item-2d815299f3","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/healthcare-and-life-sciences/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Healthcare & Life Sciences"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1533429516":{"id":"nav-item-40d2a02b61","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/manufacturing/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Manufacturing"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1444458226":{"id":"nav-item-77ca2889fa","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/public-sector/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Public Sector"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1149488919":{"id":"nav-item-cbcd5fb935","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/retail-consumer-goods/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Retail & Consumer Goods"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_57417040":{"id":"nav-item-898470cf9a","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/technology/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Technology"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_361384674":{"id":"nav-item-1c0d18a748","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/telecom/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Telecom"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_361384":{"id":"nav-item-8f9a009210","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/solutions/industries/travel-hospitality/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","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","layout":"SIMPLE","id":"container-1ad797c13b",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-20e9d39206","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/solutions/departments/finance/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Finance"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-4419617faf","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/solutions/departments/information-technology/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"IT"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1970515619":{"id":"nav-item-37e181e3fd","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/solutions/departments/marketing/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","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","layout":"SIMPLE","id":"container-a488258ff6",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_107772":{"id":"nav-item-f44257464b","linkDescription":"Confident migration to a unified platform","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/migrate-to-the-cloud/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Migrate to the AI Data Cloud"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy":{"id":"nav-item-c471bf019f","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Services Delivery"},"icon":{"id":"icon","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,":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","layout":"SIMPLE","id":"container-a18f33bff0",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-b462332688","linkDescription":"Programs with product, solutions and cloud partners","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/partners/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Snowflake Partner Network"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-d490c01084","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Partner Finder"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1970515619":{"id":"nav-item-0fc101aebd","linkDescription":"Live and virtual events","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/why-snowflake/partners/event-partnership-opportunities/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Event Partnership Opportunities"},"icon":{"id":"icon","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,":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-d20bdd1536","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-a234d74b3f",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column":{"numberOfSubColumns":"one-column","minWidth":"230","maxWidth":"350","layout":"SIMPLE","id":"container-aef79e28bd",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy_copy_2_793631646":{"id":"nav-item-4968f414dd","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","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","layout":"SIMPLE","id":"container-73e5bc3a4b",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-6f41ced96e","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Customers"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_258535199":{"id":"nav-item-2767a8e2cb","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"The AI Data Cloud Explained"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_185565":{"id":"nav-item-50a8ded919","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Security Hub"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-1d5132c5c2","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Cost and Performance Optimization"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_185565_903555964":{"id":"nav-item-f9019ee0c0","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Snowflake for Startups"},"icon":{"id":"icon","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,":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-4ee6bbab2a","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-d4f3c24990",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column_copy":{"navColumnTitle":"Connect","numberOfSubColumns":"one-column","minWidth":"124","layout":"SIMPLE","id":"container-87c4cc9a8f",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-7ffd125a6e","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/blog/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Blog"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_180298689":{"id":"nav-item-ede94e2e11","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/events/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Events"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_1639361946":{"id":"nav-item-c47532fe70","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/support/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Support"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_680912746":{"id":"nav-item-945f35ae84","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://www.snowflake.com/en/contact/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","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","layout":"SIMPLE","id":"container-bf29edae5b",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item_copy":{"id":"nav-item-b8334b318f","linkDescription":"Ebooks, videos, white papers and more","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/resources/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Resource Library"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item":{"id":"nav-item-a20cc01f8b","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Training"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_144634_1984107859":{"id":"nav-item-cb53012ac3","linkDescription":"Expert-led discussions and demos across industries and use cases","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/webinars/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Webinars"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1438098918":{"id":"nav-item-140959d398","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Certifications"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_143809":{"id":"nav-item-65d2734657","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Live Demos"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890638":{"id":"nav-item-8074419724","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Snowflake University"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_189945":{"id":"nav-item-4b49fc02ea","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Hands-On Labs"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890":{"id":"nav-item-eb7cf3dfa8","linkDescription":"Academic papers written by Snowflake researchers","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/resources/publications/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Snowflake Research Publications"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_333890_930852828":{"id":"nav-item-cb6adf3bc5","linkDescription":"Informative articles about AI and data topics","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/fundamentals/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Fundamentals"},"icon":{"id":"icon","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,":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-2bddd82c44","experience_fragment_1":{"id":"experiencefragment-8078c68303","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-21b3ca4587",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-2caec525e9","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","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,"height":"540","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-6407cb1e71","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-1d68a51bdc",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-ae95141317","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","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,"height":"540","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-aaf24128e6","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-c895cae6c0",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-4721f8fb1c","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","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,"height":"540","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-b2eb0a0695","enableDropdown":true,"nav_column_container":{"layout":"SIMPLE","id":"container-4a85e56ba1",":type":"snowflake-site/components/nav/nav-column/nav-column-container",":items":{"nav_column_copy_copy":{"navColumnTitle":"Build","numberOfSubColumns":"one-column","layout":"SIMPLE","id":"container-c598f17f4e",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-83da83444e","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Snowflake for Developers"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1855651246":{"id":"nav-item-d2e2c0f830","linkDescription":"Reference architectures, use cases and best practices","button":{"id":"button","showOutboundIcon":false,"buttonLink":{"valid":true,"url":"/en/developers/guides/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Developer Guides"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-eed36f4881","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Downloads"},"icon":{"id":"icon","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,":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","layout":"SIMPLE","id":"container-c82c0e12f9",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-9b29971265","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Documentation"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy":{"id":"nav-item-529db7aafa","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Open Source"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_copy":{"id":"nav-item-6dc6ff47ec","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","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","text":"Builder Education"},"icon":{"id":"icon","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,":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","layout":"SIMPLE","id":"container-3121aa4b42",":type":"snowflake-site/components/nav/nav-column",":items":{"nav_item":{"id":"nav-item-b9f2b32ecc","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Engineering Blog"},"icon":{"id":"icon","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,":type":"snowflake-site/components/image"},":type":"snowflake-site/components/nav/nav-item"},"nav_item_copy_1855651246":{"id":"nav-item-88c562b4f7","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","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Community"},"icon":{"id":"icon","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,":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-762996de49","experience_fragment_1":{"id":"experiencefragment-bc77cd6890","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-db2e62370e",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-93e214e778","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","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,"height":"210","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-a3c7563867","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-23cd46d295",":type":"snowflake-site/components/container",":items":{"nav_promo_card":{"id":"nav-promo-card-ec30995a0d","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","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,"height":"700","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-aa344c0ee6","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-9f3cd93dbf","languageNavItems":[{"title":"English","path":"/en/developers/guides/getting-started-with-openflow-postgresql-cdc/","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-9727cb4f90","heapButtonClasses":["mega-nav__sign-in"],"showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://app.snowflake.com/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","appliedCssClassNames":"snowflake-button-link snowflake-button-black snowflake-button-compact","text":"Sign in"},"button":{"id":"button-4276d92818","heapButtonClasses":["contact_nav","heap-nav-contact"],"showOutboundIcon":true,"buttonLink":{"valid":true,"url":"/en/contact-sales/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_INTERNAL",":type":"snowflake-site/components/button","appliedCssClassNames":"snowflake-button-secondary snowflake-button-blue snowflake-button-compact","text":"CONTACT SALES"},"button_288358396":{"id":"button-6d98a45d5b","heapButtonClasses":["start_for_free_nav","heap-nav-start-for-free"],"showOutboundIcon":false,"buttonLink":{"valid":true,"url":"https://signup.snowflake.com/"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","appliedCssClassNames":"snowflake-button-primary snowflake-button-blue snowflake-button-compact","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-6167fee02f","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}","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"},"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-79e8d88665","isDeveloperGuidesPage":false,"quickstartHeroTitle":{"lines":["Getting Started with PostgreSQL CDC"],"type":"heading2",":type":"snowflake-site/components/title-v2"},"quickstartHeroAuthor":"Kamesh Sampath","quickstartHeroFirstSnowflakeFeatureTag":{"tagText":"Ingestion","tagColor":"#29B5E8","tagPath":"/content/cq:tags/snowflake-site/taxonomy/snowflake-feature/ingestion","tagIcon":""},"quickstartHeroBreadcrumbs":[{"title":"Getting Started with PostgreSQL CDC","url":"https://www.snowflake.com/content/snowflake-site/global/en/developers/guides/getting-started-with-openflow-postgresql-cdc","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}],"quickstartHeroForkRepoLink":{"id":"button-fd3a42dea9","showOutboundIcon":false,"buttonLink":{"valid":true,"attributes":{"target":"_blank"},"url":"https://github.com/Snowflake-Labs/sfquickstarts/tree/master/site/sfguides/src/getting-started-with-openflow-postgresql-cdc"},"linkTargetContentType":"GENERIC","linkType":"SNOWFLAKE_EXTERNAL",":type":"snowflake-site/components/button","text":"Fork Repo"},"fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/getting-started-with-openflow-postgresql-cdc",":type":"snowflake-site/components/quickstart/quickstart-hero","quickstartHeroFirstCertifiedTag":{"tagText":"Quickstart","tagColor":"#29B5E8","tagPath":"/content/cq:tags/snowflake-site/taxonomy/solution-center/certification/quickstart","tagIcon":""}},"flexible_column_cont":{"id":"flexible-column-container-1628d99581","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":{"layout":"SIMPLE","id":"container-3eec3767ae",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"contentfragment":{"id":"contentfragment-638d66bc58","paragraphs":["&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EOverview\u003C/h2\u003E\n","\u003Cp\u003EThis quickstart demonstrates how to build a real-time Change Data Capture (CDC) pipeline from PostgreSQL to Snowflake using Openflow. You'll learn how to capture both initial snapshots and incremental changes, enabling real-time analytics on transactional data.\u003C/p\u003E\n","\u003Cp\u003EWe use a healthcare appointment management system as our demo dataset, but the same patterns apply to any database-based application including e-commerce, CRM, ERP, and other transactional systems.\u003C/p\u003E\n","\u003Ch3\u003EHealthcare Appointments Demo Dataset\u003C/h3\u003E\n","\u003Cp\u003EYou'll work with a realistic \u003Cstrong\u003EHealthcare Appointment Management\u003C/strong\u003E system that includes:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003E100 synthetic patients\u003C/strong\u003E with diverse demographics\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E10 doctors\u003C/strong\u003E across 5 medical specializations\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E170 appointments\u003C/strong\u003E (150 historical + 20 upcoming)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E120 visit records\u003C/strong\u003E with diagnoses and charges\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EReal-time CDC events\u003C/strong\u003E demonstrating INSERT, UPDATE operations\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EIMPORTANT - Demo Data Disclaimer:\u003C/strong\u003E All patient data, doctor information, and healthcare records in this demo are \u003Cstrong\u003Eentirely fictitious\u003C/strong\u003E and created for demonstration purposes only. No real PHI (Protected Health Information) is used.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EBy completing this guide, you will build an end-to-end CDC pipeline that captures changes from PostgreSQL in real-time and enables analytics in Snowflake.\u003C/p\u003E\n","\u003Cp\u003EHere is a summary of what you will learn in each step by following this quickstart:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ESetup Environment\u003C/strong\u003E: Configure Snowflake database objects, PostgreSQL instance, and network access\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EOpenflow Configuration\u003C/strong\u003E: Set up \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/about\"\u003EOpenflow\u003C/a\u003E SPCS runtime\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EAdd PostgreSQL Connector\u003C/strong\u003E: Configure the \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/about\"\u003EPostgreSQL CDC connector\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EInitialize PostgreSQL Database\u003C/strong\u003E: Load healthcare schema and synthetic data\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EVerify Snapshot Load\u003C/strong\u003E: Confirm initial data capture in Snowflake\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EGenerate Live CDC Events\u003C/strong\u003E: Simulate real-time appointment operations\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EReal-time Analytics\u003C/strong\u003E: Query live data and analyze CDC metadata\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EMonitor CDC Pipeline\u003C/strong\u003E: Track replication lag and data quality\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003EWhat is Openflow\u003C/h3\u003E\n","\u003Cp\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/about\"\u003ESnowflake Openflow\u003C/a\u003E is an integration service that connects any data source and any destination with hundreds of processors supporting structured and unstructured text, images, audio, video and sensor data. Built on Apache NiFi, Openflow lets you run a fully managed service in your own cloud for complete control.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EKey Features and Benefits\u003C/strong\u003E:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EOpen and Extensible\u003C/strong\u003E: An extensible managed service powered by Apache NiFi, enabling you to build and extend processors from any data source to any destination\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EUnified Data Integration Platform\u003C/strong\u003E: Handle complex, bi-directional data extraction and loading through a fully managed service\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EEnterprise-Ready\u003C/strong\u003E: Out-of-the-box security, compliance, and observability hooks for data integration\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EHigh Speed Ingestion\u003C/strong\u003E: Handle structured and unstructured data in both batch and streaming modes at virtually any scale\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EContinuous Multimodal Data\u003C/strong\u003E: Near real-time unstructured data ingestion from sources like SharePoint, Google Drive, and more\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOpenflow Deployment Models\u003C/strong\u003E:\u003C/p\u003E\n","\u003Cp\u003EOpenflow is available in two deployment options, both supporting the same connectors and features:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ESnowflake Deployment (SPCS)\u003C/strong\u003E: Streamlined and integrated solution using Snowpark Container Services. Native integration with Snowflake's security model for seamless authentication, authorization, and network security. \u003Cem\u003EThis quickstart uses SPCS deployment.\u003C/em\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EBring Your Own Cloud (BYOC)\u003C/strong\u003E: Data processing engine runs within your own cloud environment (AWS, Azure, GCP) while Snowflake manages the overall service and control plane. Ideal for handling sensitive data preprocessing locally within your organization's cloud environment.\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003ELearn more at the \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/about\"\u003EOpenflow documentation\u003C/a\u003E and \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/about-byoc\"\u003EBYOC deployments\u003C/a\u003E.\u003C/p\u003E\n","\u003Ch3\u003EWhat is Change Data Capture (CDC)\u003C/h3\u003E\n","\u003Cp\u003EChange Data Capture (CDC) is a design pattern that identifies and captures changes made to data in a database, then delivers those changes in real-time to a downstream system. Instead of periodically querying the entire database, CDC efficiently tracks only what changed.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EHow PostgreSQL CDC Works\u003C/strong\u003E:\u003C/p\u003E\n","\u003Cp\u003EPostgreSQL CDC uses \u003Cstrong\u003Elogical replication\u003C/strong\u003E, which reads changes from the Write-Ahead Log (WAL). When data is modified in PostgreSQL:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EChanges are written to the WAL (a transaction log)\u003C/li\u003E\u003Cli\u003EA replication slot captures these changes\u003C/li\u003E\u003Cli\u003EA publication defines which tables to track\u003C/li\u003E\u003Cli\u003EOpenflow reads from the replication slot and delivers changes to Snowflake\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cstrong\u003ECDC Benefits\u003C/strong\u003E:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EChanges flow to Snowflake within seconds\u003C/li\u003E\u003Cli\u003EComplete history of all INSERT, UPDATE, DELETE operations\u003C/li\u003E\u003Cli\u003EBuilt-in audit trail with CDC metadata\u003C/li\u003E\u003Cli\u003EMinimal overhead on source database\u003C/li\u003E\u003Cli\u003EOnly changes are transferred after initial snapshot\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003ECDC vs Traditional Batch ETL\u003C/strong\u003E:\u003C/p\u003E\n\u003Ctable\u003E\u003Cthead\u003E\u003Ctr\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EAspect\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003ECDC\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EBatch ETL\u003C/th\u003E\u003C/tr\u003E\u003C/thead\u003E\u003Ctbody\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003ELatency\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ESeconds\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EHours/Days\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EData Freshness\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EReal-time\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EScheduled intervals\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003ENetwork Impact\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EChanges only\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EFull table scans\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EDatabase Load\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EMinimal (log reading)\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EHigh (full queries)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EHistory\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EAll changes tracked\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EPoint-in-time snapshots\u003C/td\u003E\u003C/tr\u003E\u003C/tbody\u003E\u003C/table\u003E\n","\u003Cp\u003ELearn more about \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/about\"\u003EPostgreSQL CDC with Openflow\u003C/a\u003E.\u003C/p\u003E\n","\u003Ch3\u003EWhat You Will Learn\u003C/h3\u003E\n","\u003Cp\u003EYou'll configure PostgreSQL logical replication, set up the Openflow CDC connector, and capture both snapshot and incremental changes. Then you'll use Snowflake CoWork to query your CDC data with natural language.\u003C/p\u003E\n","\u003Ch3\u003EWhat You Will Build\u003C/h3\u003E\n","\u003Cp\u003EA real-time healthcare appointment tracking system with an automated CDC pipeline from PostgreSQL to Snowflake, complete with audit trails for all data changes.\u003C/p\u003E\n","\u003Ch3\u003EPrerequisites\u003C/h3\u003E\n","\u003Cp\u003EBefore starting, ensure you have:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ESnowflake Account\u003C/strong\u003E: Enterprise account with Openflow Snowflake Deployment enabled (AWS or Azure regions)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EAccount Permissions\u003C/strong\u003E: ACCOUNTADMIN role or equivalent for initial setup\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EPostgreSQL Instance\u003C/strong\u003E: PostgreSQL 11+ with logical replication enabled. \u003Cstrong\u003ERecommended\u003C/strong\u003E: \u003Ca href=\"https://www.snowflake.com/en/product/features/postgres/\"\u003ESnowflake Postgres\u003C/a\u003E - see \u003Ca href=\"https://www.snowflake.com/en/developers/guides/getting-started-with-snowflake-postgres/\"\u003EGetting Started with Snowflake Postgres\u003C/a\u003E for setup. Alternatives: AWS RDS, Amazon Aurora, GCP Cloud SQL, Azure Database, or self-hosted\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ENetwork Connectivity\u003C/strong\u003E: Ability to configure network access from Snowflake to PostgreSQL\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOpenflow Deployment\u003C/strong\u003E: This quickstart uses \u003Cstrong\u003EOpenflow Snowflake Deployment\u003C/strong\u003E (Snowflake-managed). If you're using \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/about-byoc\"\u003EOpenflow BYOC deployment\u003C/a\u003E, the connector setup and concepts are the same, but runtime deployment steps will differ.\u003C/p\u003E\n\u003C/blockquote\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EClone the QuickStart Repository\u003C/h2\u003E\n","\u003Cp\u003EFirst, clone the repository to get access to SQL scripts and setup files:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Egit clone https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc.git\ncd sfguide-getting-started-openflow-postgresql-cdc\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003ERepository Contents:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003E\u003Ccode\u003Esql/0.init_healthcare.sql\u003C/code\u003E\u003C/strong\u003E - PostgreSQL schema and synthetic data initialization\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E\u003Ccode\u003Esql/1.snowflake_setup.sql\u003C/code\u003E\u003C/strong\u003E - Snowflake environment setup (role, database, warehouse, network rules)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E\u003Ccode\u003Esql/2.verify_snapshot.sql\u003C/code\u003E\u003C/strong\u003E - Snapshot load verification queries\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E\u003Ccode\u003Esql/3.live_appointments.sql\u003C/code\u003E\u003C/strong\u003E - Live CDC event generation script\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E\u003Ccode\u003Esql/4.analytics_queries.sql\u003C/code\u003E\u003C/strong\u003E - Real-time analytics query examples\u003C/li\u003E\u003C/ul\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003ESetup PostgreSQL Database\u003C/h2\u003E\n","\u003Cp\u003EIn this section, we'll configure PostgreSQL for CDC and load the healthcare demo data.\u003C/p\u003E\n","\u003Ch3\u003EPostgreSQL Requirements\u003C/h3\u003E\n","\u003Cp\u003EThis guide assumes you have a PostgreSQL instance already created and available. Before proceeding, ensure your instance meets these requirements:\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ERequired PostgreSQL Configuration\u003C/strong\u003E:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EPostgreSQL instance available\u003C/strong\u003E: You have a running PostgreSQL instance (Snowflake Postgres, AWS RDS, GCP Cloud SQL, Azure Database, or self-hosted) with network accessibility\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ELogical replication enabled\u003C/strong\u003E: \u003Ccode\u003Ewal_level = logical\u003C/code\u003E (required for CDC) - see configuration instructions below\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EUser with REPLICATION privileges\u003C/strong\u003E: The PostgreSQL user must have replication permissions\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ENetwork access\u003C/strong\u003E: Configure network access from Snowflake SPCS to your PostgreSQL instance\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESupported versions\u003C/strong\u003E: PostgreSQL 11-17\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EThis quickstart was tested with \u003Cstrong\u003ESnowflake Postgres v17\u003C/strong\u003E.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EEnable Logical Replication (If Not Already Enabled)\u003C/h4\u003E\n","\u003Cp\u003EPostgreSQL CDC requires logical replication to be enabled. This allows the connector to capture changes from the Write-Ahead Log (WAL).\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EGrant REPLICATION privileges to your PostgreSQL user:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EALTER USER snowflake_admin WITH REPLICATION;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EEnable logical replication\u003C/strong\u003E via your PostgreSQL service:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ESnowflake Postgres\u003C/strong\u003E: Logical replication is enabled by default. No additional configuration required. See \u003Ca href=\"https://www.snowflake.com/en/developers/guides/getting-started-with-snowflake-postgres/\"\u003EGetting Started with Snowflake Postgres\u003C/a\u003E for setup\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EGCP Cloud SQL\u003C/strong\u003E: Set the \u003Ccode\u003Ecloudsql.logical_decoding\u003C/code\u003E and \u003Ccode\u003Ecloudsql.enable_pglogical\u003C/code\u003E flags to \u003Ccode\u003Eon\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EAWS RDS\u003C/strong\u003E or \u003Cstrong\u003EAWS Aurora\u003C/strong\u003E: Set \u003Ccode\u003Erds.logical_replication = 1\u003C/code\u003E and apply it to your instance\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EAzure Database\u003C/strong\u003E: Set \u003Ccode\u003Ewal_level = logical\u003C/code\u003E via the Azure portal or Azure CLI\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESelf-hosted PostgreSQL\u003C/strong\u003E: Edit \u003Ccode\u003Epostgresql.conf\u003C/code\u003E to set \u003Ccode\u003Ewal_level = logical\u003C/code\u003E (or run \u003Ccode\u003EALTER SYSTEM SET wal_level = logical;\u003C/code\u003E), then restart PostgreSQL\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EImportant\u003C/strong\u003E: For detailed configuration instructions specific to your PostgreSQL service, see \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/setup#configure-wal-level\"\u003ESnowflake's PostgreSQL CDC Setup Guide - Configure wal_level\u003C/a\u003E.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EAfter enabling logical replication and restarting your PostgreSQL instance if needed, you'll verify the \u003Ccode\u003Ewal_level\u003C/code\u003E setting in the next section after setting up your PostgreSQL client.\u003C/p\u003E\n","\u003Ch3\u003ESetup Notes\u003C/h3\u003E\n","\u003Cp\u003EBefore configuring your PostgreSQL environment, note these setup considerations:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EService Compatibility\u003C/strong\u003E: You can use any PostgreSQL service:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ESnowflake Postgres (recommended)\u003C/li\u003E\u003Cli\u003EAWS RDS\u003C/li\u003E\u003Cli\u003EAmazon Aurora\u003C/li\u003E\u003Cli\u003EGCP Cloud SQL\u003C/li\u003E\u003Cli\u003EAzure Database for PostgreSQL\u003C/li\u003E\u003Cli\u003ESelf-hosted PostgreSQL\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EThe SQL scripts are compatible with all variants; configuration steps may vary slightly depending on your service.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EClient Tools\u003C/strong\u003E: You can use any PostgreSQL client you're comfortable with - \u003Ccode\u003Epsql\u003C/code\u003E command-line tool, pgAdmin, DBeaver, DataGrip, TablePlus, or others. This guide shows \u003Ccode\u003Epsql\u003C/code\u003E examples, but the SQL scripts work with any client.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EPostgreSQL User\u003C/strong\u003E: This guide uses the \u003Ccode\u003Esnowflake_admin\u003C/code\u003E user for both CLI connections and Openflow connector configuration. You can use any PostgreSQL user with appropriate privileges (superuser or replication role) - just ensure the user has permissions for logical replication and can create publications and replication slots.\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003ESetup PostgreSQL Client Environment\u003C/h3\u003E\n","\u003Cp\u003EThis section shows how to install and configure the \u003Ccode\u003Epsql\u003C/code\u003E command-line tool, which is used throughout this guide.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EDon't have psql installed?\u003C/strong\u003E The \u003Ccode\u003Epsql\u003C/code\u003E client is part of the PostgreSQL installation:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EmacOS\u003C/strong\u003E: \u003Ccode\u003Ebrew install postgresql\u003C/code\u003E (via Homebrew)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EUbuntu/Debian\u003C/strong\u003E: \u003Ccode\u003Esudo apt-get install postgresql-client\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ERHEL/CentOS\u003C/strong\u003E: \u003Ccode\u003Esudo yum install postgresql\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EWindows\u003C/strong\u003E: Download from \u003Ca href=\"https://www.postgresql.org/download/windows/\"\u003EPostgreSQL Downloads\u003C/a\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EUsing a different client?\u003C/strong\u003E If you prefer pgAdmin, DBeaver, or another GUI client, you can adapt the \u003Ccode\u003Epsql\u003C/code\u003E commands throughout this guide by running the SQL portion in your client's query window.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003ESet Environment Variables\u003C/h4\u003E\n","\u003Cp\u003ESet these environment variables to avoid repeating connection parameters:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Eexport PGHOST='YOUR-POSTGRES-HOST'        # e.g., your Snowflake Postgres endpoint\nexport PGPORT='5432'\nexport PGDATABASE='postgres'\nexport PGUSER='snowflake_admin'\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThese variables will be referenced throughout the guide (e.g., \u003Ccode\u003E$PGHOST\u003C/code\u003E, \u003Ccode\u003E$PGUSER\u003C/code\u003E) for convenience.\u003C/p\u003E\n","\u003Ch4\u003EConfigure Password File\u003C/h4\u003E\n","\u003Cp\u003ECreate a \u003Ccode\u003E.pgpass\u003C/code\u003E file to avoid entering your password repeatedly. This file securely stores your PostgreSQL credentials.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003E# Create .pgpass file (Unix/Linux/macOS)\necho &quot;$PGHOST:$PGPORT:$PGDATABASE:$PGUSER:YOUR-PASSWORD&quot; &gt;&gt; ~/.pgpass\n\n# Set proper permissions (required for security)\nchmod 0600 ~/.pgpass\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EPassword File Format\u003C/strong\u003E: The \u003Ccode\u003E.pgpass\u003C/code\u003E file format is \u003Ccode\u003Ehostname:port:database:username:password\u003C/code\u003E. You can use \u003Ccode\u003E*\u003C/code\u003E as a wildcard for any field. Learn more about \u003Ca href=\"https://www.postgresql.org/docs/current/libpq-pgpass.html\"\u003EPostgreSQL password files\u003C/a\u003E.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003ETest PostgreSQL Connection\u003C/h3\u003E\n","\u003Cp\u003EBefore proceeding with any configuration, verify that your PostgreSQL instance is accessible and that logical replication is enabled.\u003C/p\u003E\n","\u003Ch4\u003ECheck PostgreSQL Accessibility\u003C/h4\u003E\n","\u003Cp\u003EFirst, ensure your PostgreSQL instance allows external connections:\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFor Snowflake Postgres (Recommended):\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EYour Snowflake Postgres instance is accessible via the endpoint provided during setup\u003C/li\u003E\u003Cli\u003ENetwork connectivity between Snowflake SPCS and Snowflake Postgres is automatically configured\u003C/li\u003E\u003Cli\u003ENote the \u003Cstrong\u003EConnection Endpoint\u003C/strong\u003E - you'll need this for both client connection and Openflow connector configuration\u003C/li\u003E\u003Cli\u003ESee \u003Ca href=\"https://www.snowflake.com/en/developers/guides/getting-started-with-snowflake-postgres/\"\u003EGetting Started with Snowflake Postgres\u003C/a\u003E for setup details\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFor GCP Cloud SQL:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ENavigate to Cloud SQL instance &rarr; \u003Cstrong\u003EConnections\u003C/strong\u003E &rarr; \u003Cstrong\u003ENetworking\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EEnsure \u003Cstrong\u003EPublic IP\u003C/strong\u003E is enabled (or VPC peering is configured for private)\u003C/li\u003E\u003Cli\u003EAdd authorized networks if needed (or configure for broad access during demo)\u003C/li\u003E\u003Cli\u003ENote the \u003Cstrong\u003EPublic IP Address\u003C/strong\u003E - you'll need this for both client connection and Snowflake network rule\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFor AWS RDS:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ENavigate to RDS instance &rarr; \u003Cstrong\u003EConnectivity &amp; security\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EEnsure \u003Cstrong\u003EPublicly accessible\u003C/strong\u003E is &quot;Yes&quot; (or VPC peering is configured)\u003C/li\u003E\u003Cli\u003ECheck \u003Cstrong\u003ESecurity group\u003C/strong\u003E allows inbound traffic on port 5432\u003C/li\u003E\u003Cli\u003ENote the \u003Cstrong\u003EEndpoint\u003C/strong\u003E - you'll need this for both client connection and Snowflake network rule\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFor Azure Database for PostgreSQL:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ENavigate to PostgreSQL server &rarr; \u003Cstrong\u003EConnection security\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EEnsure \u003Cstrong\u003EAllow access to Azure services\u003C/strong\u003E is enabled\u003C/li\u003E\u003Cli\u003EAdd firewall rules for your IP address\u003C/li\u003E\u003Cli\u003ENote the \u003Cstrong\u003EServer name\u003C/strong\u003E - you'll need this for both client connection and Snowflake network rule\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFor self-hosted PostgreSQL:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EEnsure \u003Ccode\u003Epg_hba.conf\u003C/code\u003E allows connections from your IP (or use \u003Ccode\u003E0.0.0.0/0\u003C/code\u003E for demo)\u003C/li\u003E\u003Cli\u003EFirewall allows inbound traffic on port 5432\u003C/li\u003E\u003Cli\u003EPostgreSQL is listening on external interfaces (\u003Ccode\u003Elisten_addresses = '*'\u003C/code\u003E in \u003Ccode\u003Epostgresql.conf\u003C/code\u003E)\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch4\u003ETest Basic Connection\u003C/h4\u003E\n","\u003Cp\u003ETest the connection to your PostgreSQL instance using any method you prefer:\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFor Snowflake Postgres:\u003C/strong\u003E Use the \u003Ccode\u003Epsql\u003C/code\u003E connection URL provided during instance creation. The connection string format is typically provided in the Snowflake Postgres setup UI.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOption 1: Using psql:\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003EIf you set up environment variables and \u003Ccode\u003E.pgpass\u003C/code\u003E in the previous section, simply run:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -c &quot;SELECT version();&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EIf you didn't set up environment variables, specify connection parameters explicitly:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -h YOUR-POSTGRES-HOST -p 5432 -U snowflake_admin -d postgres -c &quot;SELECT version();&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOption 2: Using pgAdmin, DBeaver, or other GUI client:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ECreate a new connection with your PostgreSQL host, port, username, and password\u003C/li\u003E\u003Cli\u003ETest the connection\u003C/li\u003E\u003Cli\u003ERun \u003Ccode\u003ESELECT version();\u003C/code\u003E to verify\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EExpected result (version number may vary):\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E                                                 version                                                  \n----------------------------------------------------------------------------------------------------------\n PostgreSQL 17.2 on x86_64-pc-linux-gnu, compiled by gcc (Debian 12.2.0-14) 12.2.0, 64-bit\n(1 row)\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EConnection Failed?\u003C/strong\u003E If you cannot connect to PostgreSQL, resolve this before proceeding. Common fixes:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ECheck firewall\u003C/strong\u003E: Ensure port 5432 is open\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ECheck PostgreSQL config\u003C/strong\u003E: Verify \u003Ccode\u003Elisten_addresses\u003C/code\u003E in \u003Ccode\u003Epostgresql.conf\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ECheck pg_hba.conf\u003C/strong\u003E: Ensure host-based authentication allows your connection\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ECheck cloud provider\u003C/strong\u003E: Verify security groups, firewall rules, authorized networks\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EVerify credentials\u003C/strong\u003E: Ensure username and password are correct\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EAll subsequent steps require a working PostgreSQL connection.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EVerify psql Configuration (Optional)\u003C/h4\u003E\n","\u003Cp\u003EIf you set up environment variables and \u003Ccode\u003E.pgpass\u003C/code\u003E, test that they're working correctly:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -c &quot;SELECT current_database(), current_user;&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E current_database | current_user \n------------------+--------------\n postgres         | snowflake_admin\n(1 row)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EIf the connection succeeds without prompting for a password, your psql environment is configured correctly.\u003C/p\u003E\n","\u003Ch4\u003EVerify Logical Replication\u003C/h4\u003E\n","\u003Cp\u003EConfirm that logical replication is enabled (as required in the PostgreSQL Requirements section):\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESnowflake Postgres Advantage:\u003C/strong\u003E If you're using Snowflake Postgres, logical replication (\u003Ccode\u003Ewal_level = logical\u003C/code\u003E) is \u003Cstrong\u003Eenabled by default\u003C/strong\u003E. You can skip this verification step, but feel free to confirm it works as expected.\u003C/p\u003E\n\u003C/blockquote\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -c &quot;SHOW wal_level;&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E wal_level \n-----------\n logical\n(1 row)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EIf the output shows \u003Ccode\u003Elogical\u003C/code\u003E, you're all set! If not, go back to the &quot;Enable Logical Replication&quot; section in PostgreSQL Requirements and ensure you've enabled \u003Ccode\u003Ewal_level = logical\u003C/code\u003E and restarted your PostgreSQL instance.\u003C/p\u003E\n","\u003Ch3\u003EInitialize Healthcare Database\u003C/h3\u003E\n","\u003Cp\u003ENow we'll initialize the PostgreSQL database with the healthcare schema, synthetic data, and CDC configuration.\u003C/p\u003E\n","\u003Ch4\u003EExecute the Initialization Script\u003C/h4\u003E\n","\u003Cp\u003EThe \u003Ccode\u003Esql/0.init_healthcare.sql\u003C/code\u003E script will:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EGrant replication privileges to the snowflake_admin user\u003C/li\u003E\u003Cli\u003ECreate the \u003Ccode\u003Ehealthcare\u003C/code\u003E schema\u003C/li\u003E\u003Cli\u003ECreate tables: \u003Ccode\u003Epatients\u003C/code\u003E, \u003Ccode\u003Edoctors\u003C/code\u003E, \u003Ccode\u003Eappointments\u003C/code\u003E, \u003Ccode\u003Evisits\u003C/code\u003E\u003C/li\u003E\u003Cli\u003ELoad 100 synthetic patients, 10 doctors, 170 appointments, and 100 visit records\u003C/li\u003E\u003Cli\u003ECreate indexes for performance\u003C/li\u003E\u003Cli\u003EConfigure CDC publication for logical replication\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch4\u003ERun the Script\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -f sql/0.init_healthcare.sql\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EUsing a different PostgreSQL client?\u003C/strong\u003E If you're using pgAdmin, DBeaver, or another GUI client instead of \u003Ccode\u003Epsql\u003C/code\u003E, simply open \u003Ccode\u003Esql/0.init_healthcare.sql\u003C/code\u003E, copy the entire contents, and execute it in your client's query window. The script contains standard PostgreSQL SQL and will work with any client.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EScript Duration\u003C/strong\u003E: Approximately 10-15 seconds to complete.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EVerify PostgreSQL Setup\u003C/h4\u003E\n","\u003Cp\u003EBefore connecting Openflow, let's verify the entire PostgreSQL CDC configuration is correct.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EUsing a different PostgreSQL client?\u003C/strong\u003E All verification queries below use \u003Ccode\u003Epsql\u003C/code\u003E for consistency. If you're using a GUI client (pgAdmin, DBeaver, etc.), simply run the SQL portion of each command. For example, for \u003Ccode\u003Epsql -c &quot;SELECT ...&quot;\u003C/code\u003E, just run \u003Ccode\u003ESELECT ...\u003C/code\u003E in your client.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003ECheck Tables Exist\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -c &quot;\\dt healthcare.*&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E              List of relations\n   Schema   |     Name     | Type  |      Owner      \n------------+--------------+-------+-----------------\n healthcare | appointments | table | snowflake_admin\n healthcare | doctors      | table | snowflake_admin\n healthcare | patients     | table | snowflake_admin\n healthcare | visits       | table | snowflake_admin\n(4 rows)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003ECheck Row Counts\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -c &quot;SELECT \n  (SELECT COUNT(*) FROM healthcare.patients) as patients,\n  (SELECT COUNT(*) FROM healthcare.doctors) as doctors,\n  (SELECT COUNT(*) FROM healthcare.appointments) as appointments,\n  (SELECT COUNT(*) FROM healthcare.visits) as visits;&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E patients | doctors | appointments | visits \n----------+---------+--------------+--------\n      100 |      10 |          170 |    100\n(1 row)\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EWhat's a Publication?\u003C/strong\u003E A PostgreSQL publication defines which tables are tracked for CDC. The Openflow connector subscribes to this publication to receive change events (INSERT, UPDATE, DELETE) in real-time.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EVerify CDC Publication\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -c &quot;SELECT * FROM pg_publication WHERE pubname = 'healthcare_cdc_publication';&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E          pubname           | pubowner | puballtables | pubinsert | pubupdate | pubdelete | pubtruncate \n----------------------------+----------+--------------+-----------+-----------+-----------+-------------\n healthcare_cdc_publication |    16390 | t            | t         | t         | t         | t\n(1 row)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EVerify Published Tables\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -c &quot;SELECT schemaname, tablename FROM pg_publication_tables WHERE pubname = 'healthcare_cdc_publication';&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E schemaname |  tablename   \n------------+--------------\n healthcare | appointments\n healthcare | doctors\n healthcare | patients\n healthcare | visits\n(4 rows)\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003ECheck CDC Configuration\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -c &quot;SELECT\n    current_setting('wal_level') AS wal_level,\n    current_setting('max_replication_slots') AS max_replication_slots,\n    current_setting('max_wal_senders') AS max_wal_senders,\n    (SELECT count(*) FROM pg_publication) AS publication_count,\n    (SELECT count(*) FROM pg_replication_slots) AS active_slots;&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E wal_level | max_replication_slots | max_wal_senders | publication_count | active_slots \n-----------+-----------------------+-----------------+-------------------+--------------\n logical   | 10                    | 10              | 1                 | 0\n(1 row)\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EWhat to check:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003Ewal_level\u003C/code\u003E should be \u003Ccode\u003Elogical\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003Emax_replication_slots\u003C/code\u003E should be at least 1 (typically 10 or more)\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003Emax_wal_senders\u003C/code\u003E should be at least 1 (typically 10 or more)\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003Epublication_count\u003C/code\u003E should be 1 (our healthcare_cdc_publication)\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003Eactive_slots\u003C/code\u003E will be 0 now, and will increase to 1 once Openflow connects\u003C/li\u003E\u003C/ul\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EVerify Replication Privileges\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -c &quot;SELECT rolname, rolsuper, rolreplication FROM pg_roles WHERE rolname = '$PGUSER';&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E rolname         | rolsuper | rolreplication \n-----------------+----------+----------------\n snowflake_admin | f        | t\n(1 row)\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESnowflake Postgres Advantage:\u003C/strong\u003E If you're using Snowflake Postgres, the \u003Ccode\u003Esnowflake_admin\u003C/code\u003E user is \u003Cstrong\u003Epre-configured with replication privileges\u003C/strong\u003E (\u003Ccode\u003Erolreplication = t\u003C/code\u003E) and is not a superuser (\u003Ccode\u003Erolsuper = f\u003C/code\u003E). This is the recommended secure configuration for CDC workloads.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote:\u003C/strong\u003E For other managed services (AWS RDS, Azure), \u003Ccode\u003Erolsuper\u003C/code\u003E is typically \u003Ccode\u003Ef\u003C/code\u003E (false). For self-hosted installations where you're using the superuser account, it may be \u003Ccode\u003Et\u003C/code\u003E (true). The critical column to verify is \u003Ccode\u003Erolreplication\u003C/code\u003E which must be \u003Ccode\u003Et\u003C/code\u003E (true).\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EThe \u003Ccode\u003Erolreplication\u003C/code\u003E column should be \u003Ccode\u003Et\u003C/code\u003E (true). If it's \u003Ccode\u003Ef\u003C/code\u003E (false), grant replication privileges:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -c &quot;ALTER USER $PGUSER WITH REPLICATION;&quot;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESetup Complete!\u003C/strong\u003E Your PostgreSQL database is now fully configured for CDC with:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E✅ Logical replication enabled\u003C/li\u003E\u003Cli\u003E✅ Healthcare schema with 100 patients, 10 doctors, 170 appointments, 100 visits\u003C/li\u003E\u003Cli\u003E✅ CDC publication tracking all healthcare tables\u003C/li\u003E\u003Cli\u003E✅ Replication privileges granted\u003C/li\u003E\u003C/ul\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003ENext, let us setup the Snowflake environment.\u003C/p\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003ESetup Snowflake Environment\u003C/h2\u003E\n","\u003Cp\u003EIn this section, we'll set up the Snowflake objects needed for the CDC pipeline.\u003C/p\u003E\n","\u003Ch3\u003ECreate Snowflake Objects\u003C/h3\u003E\n","\u003Cp\u003ENow we'll set up all required Snowflake objects for the CDC pipeline. This includes creating a dedicated role, database, warehouse, and network access configuration.\u003C/p\u003E\n","\u003Ch4\u003EWhat We're Creating\u003C/h4\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ERole\u003C/strong\u003E: \u003Ccode\u003EQUICKSTART_ROLE\u003C/code\u003E - Dedicated role for Openflow runtime\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EDatabase\u003C/strong\u003E: \u003Ccode\u003EQUICKSTART_PGCDC_DB\u003C/code\u003E - Database for healthcare CDC data\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EWarehouse\u003C/strong\u003E: \u003Ccode\u003EQUICKSTART_PGCDC_WH\u003C/code\u003E - Compute warehouse for data processing\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ENetwork Rule\u003C/strong\u003E: PostgreSQL connection endpoint\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EExternal Access Integration\u003C/strong\u003E: Allows SPCS to connect to PostgreSQL\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESnowflake CoWork Infrastructure\u003C/strong\u003E: \u003Ccode\u003Esnowflake_intelligence\u003C/code\u003E database and \u003Ccode\u003Eagents\u003C/code\u003E schema for AI-powered analytics\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch4\u003EExecute the Setup Script\u003C/h4\u003E\n","\u003Cp\u003EOpen &lt;a href=&quot;https://app.snowflake.com/_deeplink/#/workspaces?utm_source=snowflake-devrel&amp;utm_medium=developer-guides&amp;utm_content=getting-started-with-openflow-postgresql-cdc&amp;utm_cta=developer-guides-deeplink&quot; class=&quot;_deeplink&quot;&gt;Workspaces&lt;/a&gt; in Snowsight (\u003Cstrong\u003EProjects\u003C/strong\u003E &rarr; \u003Cstrong\u003EWorkspaces\u003C/strong\u003E), copy paste the \u003Ccode\u003Esql/1.snowflake_setup.sql\u003C/code\u003E script and execute it.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EIMPORTANT:\u003C/strong\u003E Before running the script, update line 64 with your PostgreSQL endpoint:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EVALUE_LIST = ('YOUR-POSTGRES-HOST:5432');\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EReplace \u003Ccode\u003EYOUR-POSTGRES-HOST\u003C/code\u003E with:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ESnowflake Postgres\u003C/strong\u003E: Your Snowflake Postgres connection endpoint\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EGCP Cloud SQL\u003C/strong\u003E: Your instance's public IP (e.g., \u003Ccode\u003E34.123.45.67\u003C/code\u003E)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EAWS RDS\u003C/strong\u003E: Your RDS endpoint hostname\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EAzure Database\u003C/strong\u003E: Your Azure PostgreSQL server name\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESelf-hosted\u003C/strong\u003E: Your server hostname or IP address\u003C/li\u003E\u003C/ul\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EThe script will:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ECreate the \u003Ccode\u003EQUICKSTART_ROLE\u003C/code\u003E role (or reuse if coming from SPCS quickstart)\u003C/li\u003E\u003Cli\u003ECreate \u003Ccode\u003EQUICKSTART_PGCDC_DB\u003C/code\u003E database with two schemas:\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003EHEALTHCARE\u003C/code\u003E - For CDC data tables\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003ENETWORKS\u003C/code\u003E - For network rule definitions\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003ECreate \u003Ccode\u003EQUICKSTART_PGCDC_WH\u003C/code\u003E warehouse (MEDIUM size, auto-suspend after 5 minutes)\u003C/li\u003E\u003Cli\u003ECreate network rule for PostgreSQL connectivity\u003C/li\u003E\u003Cli\u003ECreate external access integration \u003Ccode\u003Equickstart_pgcdc_access\u003C/code\u003E\u003C/li\u003E\u003Cli\u003ECreate Snowflake CoWork infrastructure (\u003Ccode\u003Esnowflake_intelligence\u003C/code\u003E database and \u003Ccode\u003Eagents\u003C/code\u003E schema)\u003C/li\u003E\u003Cli\u003EGrant appropriate permissions\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch4\u003EVerify Snowflake Setup\u003C/h4\u003E\n","\u003Cp\u003EAfter running the script, verify the setup in a new SQL worksheet in Snowsight.\u003C/p\u003E\n","\u003Cp\u003EOpen a new SQL worksheet and run the following verification queries:\u003C/p\u003E\n","\u003Ch4\u003EVerify Schemas\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE QUICKSTART_ROLE;\nUSE WAREHOUSE QUICKSTART_PGCDC_WH;\nSHOW SCHEMAS IN DATABASE QUICKSTART_PGCDC_DB;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output (note: the \u003Ccode\u003Ehealthcare\u003C/code\u003E schema will be automatically created by Openflow when the connector is added):\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E| created_on          | name                  | is_default | is_current | database_name      | owner            | comment | options | retention_time | owner_role_type |\n|---------------------|-----------------------|------------|------------|--------------------|--------------------|---------|---------|----------------|-----------------|\n| 2025-10-07 10:00:00 | INFORMATION_SCHEMA    | N          | N          | QUICKSTART_PGCDC_DB | ACCOUNTADMIN      |         |         | 1              | ROLE            |\n| 2025-10-07 10:00:00 | NETWORKS              | N          | N          | QUICKSTART_PGCDC_DB | QUICKSTART_ROLE   |         |         | 1              | ROLE            |\n| 2025-10-07 10:00:00 | PUBLIC                | Y          | N          | QUICKSTART_PGCDC_DB | QUICKSTART_ROLE   |         |         | 1              | ROLE            |\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EVerify Integration\u003C/h4\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESHOW INTEGRATIONS LIKE 'quickstart_pgcdc_access';\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E| name                      | type              | category          | enabled | comment                                    | created_on          |\n|---------------------------|-------------------|-------------------|---------|--------------------------------------------|--------------------|\n| quickstart_pgcdc_access   | EXTERNAL_ACCESS   | SECURITY          | true    | OpenFlow SPCS runtime access for PostgreSQL CDC | 2025-10-07 10:00:00 |\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EVerify Network Rule\u003C/h4\u003E\n","\u003Cp\u003EVerify that Snowflake's network rule is correctly configured to allow connections to your PostgreSQL instance.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003E⚠️ IMPORTANT - Snowflake Network Connectivity\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003EFor Openflow to connect to your PostgreSQL instance, two things must be true:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003EPostgreSQL must allow inbound connections from Snowflake\u003C/strong\u003E: Configure your cloud provider's firewall/security groups to allow connections from Snowflake SPCS IP ranges (or use broad access for demo purposes)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESnowflake network rule must match your PostgreSQL host/port\u003C/strong\u003E: The network rule created in \u003Ccode\u003E1.snowflake_setup.sql\u003C/code\u003E must specify the exact host and port of your PostgreSQL instance\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EThis section verifies requirement #2. If you encounter connection errors when starting the Openflow connector later, you'll need to verify both requirements.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003ECheck the network rule configuration:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EDESC NETWORK RULE QUICKSTART_PGCDC_DB.NETWORKS.postgres_network_rule;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output should show your actual PostgreSQL host:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E| name                     | type       | mode   | value_list                     | comment |\n|--------------------------|------------|--------|--------------------------------|---------|\n| postgres_network_rule    | HOST_PORT  | EGRESS | ['your-actual-host.com:5432']  |         |\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003E⚠️ Host Mismatch?\u003C/strong\u003E If the \u003Ccode\u003Evalue_list\u003C/code\u003E doesn't match your PostgreSQL host, you \u003Cstrong\u003Emust\u003C/strong\u003E recreate the network rule and external access integration with the correct host:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Drop existing objects\nUSE ROLE ACCOUNTADMIN;\nDROP INTEGRATION IF EXISTS quickstart_pgcdc_access;\nUSE ROLE QUICKSTART_ROLE;\nDROP NETWORK RULE IF EXISTS QUICKSTART_PGCDC_DB.NETWORKS.postgres_network_rule;\n\n-- Create network rule with CORRECT PostgreSQL host\nUSE DATABASE QUICKSTART_PGCDC_DB;\nUSE SCHEMA NETWORKS;\nCREATE OR REPLACE NETWORK RULE postgres_network_rule\n  MODE = EGRESS\n  TYPE = HOST_PORT\n  VALUE_LIST = ('YOUR-CORRECT-POSTGRES-HOST:5432');  -- ⚠️ Update this!\n\n-- Recreate external access integration\nUSE ROLE ACCOUNTADMIN;\nCREATE OR REPLACE EXTERNAL ACCESS INTEGRATION quickstart_pgcdc_access\n  ALLOWED_NETWORK_RULES = (QUICKSTART_PGCDC_DB.NETWORKS.postgres_network_rule)\n  ENABLED = true\n  COMMENT = 'OpenFlow SPCS runtime access for PostgreSQL CDC';\n\n-- Grant to role\nGRANT USAGE ON INTEGRATION quickstart_pgcdc_access TO ROLE QUICKSTART_ROLE;\n\n-- Verify\nUSE ROLE QUICKSTART_ROLE;\nSHOW INTEGRATIONS LIKE 'quickstart_pgcdc_access';\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003E✅ Network Rule Verification Complete!\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003EYou've verified that the Snowflake network rule matches your PostgreSQL host and port.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote\u003C/strong\u003E: Full end-to-end connectivity (Snowflake &rarr; PostgreSQL) will be tested when the Openflow connector starts. If you encounter connection errors during connector startup, verify:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EPostgreSQL firewall/security groups allow inbound connections from Snowflake SPCS\u003C/li\u003E\u003Cli\u003ENetwork rule configuration is correct (verified above)\u003C/li\u003E\u003Cli\u003EPostgreSQL credentials are correct\u003C/li\u003E\u003Cli\u003EPostgreSQL is running and accessible\u003C/li\u003E\u003C/ol\u003E\n\u003C/blockquote\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EOpenflow Configuration\u003C/h2\u003E\n","\u003Cp\u003EIn this section, you'll set up the Openflow Snowflake Deployments infrastructure needed to run the PostgreSQL connector. Before proceeding, ensure you've completed the Snowflake setup with \u003Ccode\u003EQUICKSTART_ROLE\u003C/code\u003E, \u003Ccode\u003EQUICKSTART_PGCDC_DB\u003C/code\u003E database, and \u003Ccode\u003EQUICKSTART_PGCDC_WH\u003C/code\u003E warehouse.\u003C/p\u003E\n","\u003Ch3\u003EComplete Openflow Snowflake Deployments Setup\u003C/h3\u003E\n","\u003Cp\u003EThis CDC quickstart builds on the foundational Openflow Snowflake Deployments setup. Navigate to the \u003Ca href=\"/en/developers/guides/getting-started-with-openflow-spcs/\"\u003EGetting Started with Openflow Snowflake Deployments\u003C/a\u003E quickstart and complete the following two sections (approximately 15 minutes total):\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESetup Core Snowflake\u003C/strong\u003E: Create \u003Ccode\u003EOPENFLOW_ADMIN\u003C/code\u003E role and enable BCR Bundle 2025_06.\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003ECreate Deployment\u003C/strong\u003E: Set up your Openflow Snowflake Deployment (e.g., \u003Ccode\u003EQUICKSTART_DEPLOYMENT\u003C/code\u003E).\u003C/p\u003E\n\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EOnce your deployment is active, return here to create a runtime. If you already have an Openflow deployment, you can skip the deployment creation and just ensure you select the correct deployment name when creating the runtime.\u003C/p\u003E\n","\u003Cp\u003EAfter completing these prerequisite sections, you'll have:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003EOPENFLOW_ADMIN\u003C/code\u003E role with deployment privileges\u003C/li\u003E\u003Cli\u003EBCR Bundle 2025_06 enabled (required for CDC connectors)\u003C/li\u003E\u003Cli\u003EActive Openflow deployment\u003C/li\u003E\u003Cli\u003ENetwork rules for Snowflake infrastructure\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003ECreate Runtime for PostgreSQL CDC\u003C/h3\u003E\n","\u003Cp\u003ENow that you have an active Openflow deployment, create a runtime environment specifically configured for the PostgreSQL connector.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EResources from Setup Environment\u003C/strong\u003E: You already created the following in the &quot;Setup Environment&quot; section:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003EQUICKSTART_ROLE\u003C/code\u003E - Runtime role\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003EQUICKSTART_PGCDC_DB\u003C/code\u003E - Database with \u003Ccode\u003ENETWORKS\u003C/code\u003E schema\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003EQUICKSTART_PGCDC_WH\u003C/code\u003E - Warehouse\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003Epostgres_network_rule\u003C/code\u003E - Network rule\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003Equickstart_pgcdc_access\u003C/code\u003E - External access integration\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch4\u003EVerify External Access Integration\u003C/h4\u003E\n","\u003Cp\u003EVerify the external access integration created in the &quot;Setup Environment&quot; section:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE QUICKSTART_ROLE;\n\n-- Verify integration exists and is enabled\nSHOW INTEGRATIONS LIKE 'quickstart_pgcdc_access';\nDESC INTEGRATION quickstart_pgcdc_access;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output for \u003Ccode\u003ESHOW INTEGRATIONS\u003C/code\u003E:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E| name                     | type              | category | enabled | comment                                              | created_on          |\n|--------------------------|-------------------|----------|---------|------------------------------------------------------|---------------------|\n| quickstart_pgcdc_access  | EXTERNAL_ACCESS   | SECURITY | true    | OpenFlow SPCS runtime access for PostgreSQL CDC      | 2025-10-07 10:00:00 |\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EWhat's an External Access Integration?\u003C/strong\u003E This allows your Openflow runtime to communicate with external services (your PostgreSQL database) from within Snowpark Container Services. The \u003Ccode\u003Epostgres_network_rule\u003C/code\u003E you created earlier defines which PostgreSQL endpoints are accessible.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003ECreate Runtime via Snowsight\u003C/h4\u003E\n","\u003Cp\u003EFollow these steps to create your runtime:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003ENavigate to Openflow\u003C/strong\u003E: Go to \u003Cstrong\u003EWork with data\u003C/strong\u003E &rarr; \u003Cstrong\u003EIngestion\u003C/strong\u003E &rarr; \u003Cstrong\u003EOpenflow\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESwitch to Runtimes Tab\u003C/strong\u003E: Click the \u003Cstrong\u003ERuntimes\u003C/strong\u003E tab\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EEnsure Correct Role\u003C/strong\u003E: Verify your role is set to \u003Ccode\u003EOPENFLOW_ADMIN\u003C/code\u003E (check top-right corner of Snowsight)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EClick Create Runtime\u003C/strong\u003E: Click the \u003Cstrong\u003E+ Runtime\u003C/strong\u003E button\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EConfigure Runtime\u003C/strong\u003E:\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EName\u003C/strong\u003E: \u003Ccode\u003EQUICKSTART_PGCDC_RUNTIME\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EDeployment\u003C/strong\u003E: Select \u003Ccode\u003EQUICKSTART_DEPLOYMENT\u003C/code\u003E (or your deployment name)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ERuntime Role\u003C/strong\u003E: Select \u003Ccode\u003EQUICKSTART_ROLE\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EExternal Access Integration\u003C/strong\u003E: Select \u003Ccode\u003Equickstart_pgcdc_access\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EClick Create\u003C/strong\u003E: Complete the runtime creation\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/openflow_spcs_runtime_create.gif?v=32b758de\" alt=\"Create Openflow Runtime\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ERuntime Creation Time\u003C/strong\u003E: Runtime creation typically takes 3-5 minutes. The status will progress from \u003Ccode\u003ECREATING\u003C/code\u003E &rarr; \u003Ccode\u003EACTIVE\u003C/code\u003E.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EVerify Runtime Status\u003C/h4\u003E\n","\u003Cp\u003ECheck that your runtime is active:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003ENavigate to Runtimes Tab\u003C/strong\u003E: Go to \u003Cstrong\u003EWork with data\u003C/strong\u003E &rarr; \u003Cstrong\u003EIngestion\u003C/strong\u003E &rarr; \u003Cstrong\u003EOpenflow\u003C/strong\u003E &rarr; \u003Cstrong\u003ERuntimes\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ECheck Status\u003C/strong\u003E: Look for \u003Ccode\u003EQUICKSTART_PGCDC_RUNTIME\u003C/code\u003E with status \u003Cstrong\u003EACTIVE\u003C/strong\u003E\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/openflow_spcs_runtime_active_example.png?v=32b758de\" alt=\"Openflow Runtime Active Status\"\u003E\u003C/p\u003E\n","\u003Cp\u003EExpected status: \u003Cstrong\u003EACTIVE\u003C/strong\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETroubleshooting\u003C/strong\u003E: If the runtime status shows \u003Ccode\u003EERROR\u003C/code\u003E or stays in \u003Ccode\u003ECREATING\u003C/code\u003E for more than 10 minutes:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EVerify the external access integration exists: \u003Ccode\u003ESHOW INTEGRATIONS LIKE 'quickstart_pgcdc_access';\u003C/code\u003E\u003C/li\u003E\u003Cli\u003ECheck that \u003Ccode\u003EQUICKSTART_ROLE\u003C/code\u003E has all required grants: \u003Ccode\u003ESHOW GRANTS TO ROLE QUICKSTART_ROLE;\u003C/code\u003E\u003C/li\u003E\u003Cli\u003EReview the \u003Ca href=\"/en/developers/guides/getting-started-with-openflow-spcs/\"\u003EOpenflow Snowflake Deployments\u003C/a\u003E troubleshooting guide\u003C/li\u003E\u003C/ul\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EAccess the Runtime Canvas\u003C/h4\u003E\n","\u003Cp\u003EOnce your runtime is active, you can access the Openflow canvas to add and configure connectors:\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EClick on the runtime name\u003C/strong\u003E (\u003Ccode\u003EQUICKSTART_PGCDC_RUNTIME\u003C/code\u003E) to open the canvas. This will open in a new browser tab where you'll configure connectors and build your data pipeline.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EAuthentication\u003C/strong\u003E: When opening the runtime canvas for the first time, you may be prompted to authenticate/authorize access. Accept these prompts to allow the canvas to access the runtime and required resources.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/openflow_runtime_empty_canvas.png?v=32b758de\" alt=\"Openflow Runtime Empty Canvas\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EREFERENCE DOCUMENTATION:\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003EFor detailed information, see \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/setup-openflow-spcs-create-runtime\"\u003ECreate runtime\u003C/a\u003E in the official documentation.\u003C/p\u003E\n\u003C/blockquote\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EAdd PostgreSQL Connector\u003C/h2\u003E\n","\u003Cp\u003ENavigate to your Openflow runtime canvas. In Snowsight's Openflow UI, you can access the canvas by clicking on the runtime name from the Overview page.\u003C/p\u003E\n","\u003Ch3\u003EOpenflow Database CDC Connectors\u003C/h3\u003E\n","\u003Cp\u003EWhile this quickstart focuses on PostgreSQL, the concepts and workflow apply to all Openflow database CDC connectors. Openflow provides CDC connectors for major relational databases, enabling real-time replication of database tables into Snowflake for comprehensive, centralized reporting.\u003C/p\u003E\n","\u003Ch4\u003ESupported Databases\u003C/h4\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/about\"\u003EPostgreSQL\u003C/a\u003E\u003C/strong\u003E: Versions 11-17 (Snowflake Postgres, AWS RDS, Amazon Aurora, GCP Cloud SQL, Azure Database, Standard) - \u003Cem\u003EUsed in this quickstart\u003C/em\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/mysql/about\"\u003EMySQL\u003C/a\u003E\u003C/strong\u003E: Versions 8.0, 8.4 (Standard, AWS RDS, Amazon Aurora, GCP Cloud SQL)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/sql-server/about\"\u003ESQL Server\u003C/a\u003E\u003C/strong\u003E: SQL Server 2017+ (Standard, AWS RDS, Azure SQL Database)\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch4\u003EWhy Use Openflow for CDC\u003C/h4\u003E\n","\u003Cp\u003EOpenflow provides a unified platform for CDC across all major databases with consistent workflows and metadata, whether you're using PostgreSQL, MySQL, SQL Server, or Oracle (coming soon).\u003C/p\u003E\n","\u003Ch3\u003EAdd PostgreSQL Connector to Runtime\u003C/h3\u003E\n","\u003Cp\u003ENavigate to \u003Cstrong\u003EWork with data\u003C/strong\u003E &rarr; \u003Cstrong\u003EIngestion\u003C/strong\u003E &rarr; \u003Cstrong\u003EOpenflow\u003C/strong\u003E &rarr; \u003Cstrong\u003EOverview\u003C/strong\u003E. Follow the animation below to add the PostgreSQL connector to your runtime:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/pgcdc_install_on_runtime.gif?v=32b758de\" alt=\"Add PostgreSQL Connector\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENew Tab &amp; Authentication\u003C/strong\u003E: Adding the connector to your runtime will open a new runtime tab in your browser with the canvas showing the \u003Cstrong\u003EPostgreSQL\u003C/strong\u003E processor group. If prompted, authenticate/authorize access to allow the canvas to access the runtime. You'll configure this connector in the next section.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EThe \u003Cstrong\u003EPostgreSQL\u003C/strong\u003E connector is now on your canvas. It includes all the processors and services needed for snapshot load and incremental CDC from PostgreSQL to Snowflake.\u003C/p\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EConfigure PostgreSQL Connector\u003C/h2\u003E\n","\u003Cp\u003EThe PostgreSQL connector uses three parameter contexts to organize its configuration:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003EPostgreSQL Source Parameters\u003C/strong\u003E - PostgreSQL connection details and CDC-specific settings like publication and replication slot\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EPostgreSQL Destination Parameters\u003C/strong\u003E - Snowflake table mapping and schema configuration\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EPostgreSQL Ingestion Parameters\u003C/strong\u003E - Schema and columns that need to be loaded into Snowflake\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003ETo access parameter contexts:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/access_parameter_contexts.gif?v=32b758de\" alt=\"Access Parameter Contexts\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EProduction Tip:\u003C/strong\u003E For production deployments, use a SecretManagerParameterProvider (like \u003Ccode\u003EAwsSecretsManagerParameterProvider\u003C/code\u003E) to store credentials in a secrets manager rather than directly in the connector configuration.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EConfigure PostgreSQL Source Parameters\u003C/h3\u003E\n","\u003Cp\u003EConfigure the PostgreSQL database connection details and CDC-specific settings.\u003C/p\u003E\n","\u003Ch4\u003EDownload PostgreSQL JDBC Driver\u003C/h4\u003E\n","\u003Cp\u003EBefore configuring the parameters, download the PostgreSQL JDBC driver that will be used for the database connection.\u003C/p\u003E\n","\u003Cp\u003EGet the PostgreSQL JDBC driver from \u003Ca href=\"https://jdbc.postgresql.org/download/\"\u003Ehttps://jdbc.postgresql.org/download/\u003C/a\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EThis quickstart uses \u003Ccode\u003Epostgresql-42.7.7.jar\u003C/code\u003E (you can use any recent version)\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EYou'll upload this JAR file as a reference asset so the connector can use it to connect to PostgreSQL.\u003C/p\u003E\n","\u003Ch4\u003EAccess PostgreSQL Source Parameters\u003C/h4\u003E\n","\u003Cp\u003EFrom the Parameter contexts list, click the \u003Cstrong\u003Ethree dots menu (⋮)\u003C/strong\u003E next to \u003Cstrong\u003EPostgreSQL Source Parameters\u003C/strong\u003E and select \u003Cstrong\u003EEdit\u003C/strong\u003E.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/edit_param_context_pg_source_params.png?v=32b758de\" alt=\"Edit PostgreSQL Source Parameters\"\u003E\u003C/p\u003E\n","\u003Cp\u003EClick on the \u003Cstrong\u003EParameters\u003C/strong\u003E tab and configure the following values:\u003C/p\u003E\n\u003Ctable\u003E\u003Cthead\u003E\u003Ctr\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EParameter\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EValue\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EDescription\u003C/th\u003E\u003C/tr\u003E\u003C/thead\u003E\u003Ctbody\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EPostgreSQL Connection URL\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Ejdbc:postgresql://&lt;YOUR-POSTGRES-HOST&gt;:5432/postgres\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EJDBC connection URL to your PostgreSQL instance. Replace \u003Ccode\u003E&lt;YOUR-POSTGRES-HOST&gt;\u003C/code\u003E with your actual PostgreSQL host (e.g., your Snowflake Postgres endpoint)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EPostgreSQL JDBC Driver\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Epostgresql-42.7.7.jar\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EReference to the PostgreSQL JDBC driver JAR (see upload instructions below)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EPostgreSQL Password\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003E&lt;YOUR-PASSWORD&gt;\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EPassword for the PostgreSQL user (stored as sensitive value)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EPostgreSQL Username\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Esnowflake_admin\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EPostgreSQL username (or the user you configured with REPLICATION privileges)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EPublication Name\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Ehealthcare_cdc_publication\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EName of the PostgreSQL publication created in \u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/0.init_healthcare.sql#L348\"\u003E0.init_healthcare.sql\u003C/a\u003E\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EReplication Slot Name\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ELeave empty for auto-generation\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EOptional. If specified, this exact name will be used for the replication slot. If left empty, Openflow automatically generates a unique name following the pattern \u003Ccode\u003Esnowflake_connector_&lt;unique_id&gt;\u003C/code\u003E.\u003C/td\u003E\u003C/tr\u003E\u003C/tbody\u003E\u003C/table\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EConnection URL Format\u003C/strong\u003E: The PostgreSQL JDBC URL format is \u003Ccode\u003Ejdbc:postgresql://HOST:PORT/DATABASE\u003C/code\u003E.\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EFor Snowflake Postgres: Use your Snowflake Postgres endpoint (e.g., \u003Ccode\u003Ejdbc:postgresql://your-snowflake-postgres-endpoint:5432/postgres\u003C/code\u003E)\u003C/li\u003E\u003Cli\u003EFor GCP Cloud SQL: Use the public IP address (e.g., \u003Ccode\u003Ejdbc:postgresql://34.123.45.67:5432/postgres\u003C/code\u003E)\u003C/li\u003E\u003Cli\u003EFor AWS RDS: Use the endpoint hostname (e.g., \u003Ccode\u003Ejdbc:postgresql://mydb.abc123.us-east-1.rds.amazonaws.com:5432/postgres\u003C/code\u003E)\u003C/li\u003E\u003Cli\u003EFor other services: Use your specific connection details\u003C/li\u003E\u003C/ul\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EUpload JDBC Driver as Reference Asset\u003C/h4\u003E\n","\u003Cp\u003EFollow the animation below to upload the downloaded JAR file and reference it in the \u003Cstrong\u003EPostgreSQL JDBC Driver\u003C/strong\u003E parameter:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/param_jdbc_driver_ref_asset.gif?v=32b758de\" alt=\"Upload JDBC Driver as Reference Asset\"\u003E\u003C/p\u003E\n","\u003Cp\u003EYour completed configuration should look like this:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/set_pg_source_params.png?v=32b758de\" alt=\"Set PostgreSQL Source Parameters\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote:\u003C/strong\u003E The screenshot shows \u003Ccode\u003Epostgres\u003C/code\u003E as the PostgreSQL Username. Based on your setup, use the appropriate username (e.g., Snowflake Postgres uses \u003Ccode\u003Esnowflake_admin\u003C/code\u003E by default).\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EClick \u003Cstrong\u003EApply\u003C/strong\u003E to save your PostgreSQL source parameters configuration.\u003C/p\u003E\n","\u003Ch3\u003EConfigure PostgreSQL Destination Parameters\u003C/h3\u003E\n","\u003Cp\u003EConfigure the Snowflake destination connection where PostgreSQL data will be replicated.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EIMPORTANT\u003C/strong\u003E: Ensure you have completed the \u003Ca href=\"#create-snowflake-objects\"\u003ECreate Snowflake Objects\u003C/a\u003E section before proceeding. The PostgreSQL connector requires the database, warehouse, and role to be created in advance.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EAccess PostgreSQL Destination Parameters\u003C/h4\u003E\n","\u003Cp\u003EFrom the Parameter contexts list, click the \u003Cstrong\u003Ethree dots menu (⋮)\u003C/strong\u003E next to \u003Cstrong\u003EPostgreSQL Destination Parameters\u003C/strong\u003E and select \u003Cstrong\u003EEdit\u003C/strong\u003E.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/edit_param_context_pg_destination_params.png?v=32b758de\" alt=\"Edit PostgreSQL Destination Parameters\"\u003E\u003C/p\u003E\n","\u003Cp\u003EClick on the \u003Cstrong\u003EParameters\u003C/strong\u003E tab and configure the following values:\u003C/p\u003E\n\u003Ctable\u003E\u003Cthead\u003E\u003Ctr\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EParameter\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EValue\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EDescription\u003C/th\u003E\u003C/tr\u003E\u003C/thead\u003E\u003Ctbody\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EDestination Database\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003EQUICKSTART_PGCDC_DB\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ESnowflake database where tables will be created (defined in \u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/1.snowflake_setup.sql#L23\"\u003E1.snowflake_setup.sql#L23\u003C/a\u003E)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003ESnowflake Account Identifier\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ELeave empty\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ENot required when using session token authentication\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003ESnowflake Authentication Strategy\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003ESNOWFLAKE_SESSION_TOKEN\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EUses the runtime's session for authentication (recommended for SPCS deployments)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003ESnowflake Private Key\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ELeave empty\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ENot required when using session token authentication\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003ESnowflake Private Key File\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ELeave empty\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ENot required when using session token authentication\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003ESnowflake Private Key Password\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ELeave empty\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ENot required when using session token authentication\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003ESnowflake Role\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003EQUICKSTART_ROLE\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ERuntime role with permissions to create tables and write data (defined in \u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/1.snowflake_setup.sql#L20\"\u003E1.snowflake_setup.sql#L20\u003C/a\u003E)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003ESnowflake Username\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ELeave empty\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ENot required when using session token authentication\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003ESnowflake Warehouse\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003EQUICKSTART_PGCDC_WH\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EWarehouse for data processing (defined in \u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/1.snowflake_setup.sql#L26\"\u003E1.snowflake_setup.sql#L26\u003C/a\u003E)\u003C/td\u003E\u003C/tr\u003E\u003C/tbody\u003E\u003C/table\u003E\n","\u003Cp\u003EYour completed configuration should look like this:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/set_pg_destination_params.png?v=32b758de\" alt=\"Set PostgreSQL Destination Parameters\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESession Token Authentication\u003C/strong\u003E: When using \u003Ccode\u003ESNOWFLAKE_SESSION_TOKEN\u003C/code\u003E, the connector authenticates using the Openflow runtime's Snowflake session. This is the recommended approach for SPCS deployments as it eliminates the need to manage separate credentials.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EClick \u003Cstrong\u003EApply\u003C/strong\u003E to save your PostgreSQL destination parameters configuration.\u003C/p\u003E\n","\u003Ch3\u003EConfigure PostgreSQL Ingestion Parameters\u003C/h3\u003E\n","\u003Cp\u003EConfigure CDC ingestion settings and table filters. This parameter context inherits values from both \u003Cstrong\u003EPostgreSQL Source Parameters\u003C/strong\u003E and \u003Cstrong\u003EPostgreSQL Destination Parameters\u003C/strong\u003E.\u003C/p\u003E\n","\u003Ch4\u003EAccess PostgreSQL Ingestion Parameters\u003C/h4\u003E\n","\u003Cp\u003EFrom the Parameter contexts list, click the \u003Cstrong\u003Ethree dots menu (⋮)\u003C/strong\u003E next to \u003Cstrong\u003EPostgreSQL Ingestion Parameters (1)\u003C/strong\u003E and select \u003Cstrong\u003EEdit\u003C/strong\u003E.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/pg_ingestion_params_no_inheritence.png?v=32b758de\" alt=\"Edit PostgreSQL Ingestion Parameters\"\u003E\u003C/p\u003E\n","\u003Cp\u003EClick on the \u003Cstrong\u003EParameters\u003C/strong\u003E tab. By default, you'll see only the parameters specific to this context. To view all parameters (including inherited ones), check the \u003Cstrong\u003EShow inherited parameters\u003C/strong\u003E checkbox at the bottom.\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/pg_ingestion_params_with_inheritence.png?v=32b758de\" alt=\"PostgreSQL Ingestion Parameters with Inheritance\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote:\u003C/strong\u003E The screenshot shows \u003Ccode\u003Epostgres\u003C/code\u003E as the PostgreSQL Username. Based on your setup, use the appropriate username (e.g., Snowflake Postgres uses \u003Ccode\u003Esnowflake_admin\u003C/code\u003E by default).\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EConfigure the following key parameters:\u003C/p\u003E\n\u003Ctable\u003E\u003Cthead\u003E\u003Ctr\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EParameter\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EValue\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003EDescription\u003C/th\u003E\u003C/tr\u003E\u003C/thead\u003E\u003Ctbody\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EColumn Filter JSON\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003E[]\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EEmpty array means all columns are included\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EIncluded Table Names\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ELeave empty\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EUse regex instead for flexible filtering\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EIncluded Table Regex\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Ehealthcare\\..*\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ERegular expression to match table names for CDC. The pattern \u003Ccode\u003Ehealthcare\\..*\u003C/code\u003E matches all tables in the \u003Ccode\u003Ehealthcare\u003C/code\u003E schema. The backslash escapes the dot to match a literal period in the schema-qualified table names (e.g., \u003Ccode\u003Ehealthcare.patients\u003C/code\u003E, \u003Ccode\u003Ehealthcare.doctors\u003C/code\u003E).\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EIngestion Type\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003Efull\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EPerforms full snapshot followed by incremental CDC. Other option is &quot;incremental&quot; which only performs incremental CDC, existing data is not loaded.\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EMerge Task Schedule CRON\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Ccode\u003E* * * * * ?\u003C/code\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ERuns merge tasks every second for near real-time updates\u003C/td\u003E\u003C/tr\u003E\u003C/tbody\u003E\u003C/table\u003E\n","\u003Cp\u003E\u003Cstrong\u003EInherited Parameters\u003C/strong\u003E (visible when &quot;Show inherited parameters&quot; is checked):\u003C/p\u003E\n","\u003Cp\u003EFrom \u003Cstrong\u003EPostgreSQL Source Parameters\u003C/strong\u003E:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EPostgreSQL Connection URL\u003C/li\u003E\u003Cli\u003EPostgreSQL JDBC Driver\u003C/li\u003E\u003Cli\u003EPostgreSQL Username\u003C/li\u003E\u003Cli\u003EPostgreSQL Password\u003C/li\u003E\u003Cli\u003EPublication Name (\u003Ccode\u003Ehealthcare_cdc_publication\u003C/code\u003E - created in \u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/0.init_healthcare.sql#L348\"\u003E0.init_healthcare.sql#L348\u003C/a\u003E)\u003C/li\u003E\u003Cli\u003EReplication Slot Name (auto-generated)\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EFrom \u003Cstrong\u003EPostgreSQL Destination Parameters\u003C/strong\u003E:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EDestination Database\u003C/li\u003E\u003Cli\u003ESnowflake Role\u003C/li\u003E\u003Cli\u003ESnowflake Warehouse\u003C/li\u003E\u003Cli\u003ESnowflake Authentication Strategy\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EYour completed configuration with inherited parameters should look like this:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/set_pg_ingestion_parmeters_with_inheritance.png?v=32b758de\" alt=\"Set PostgreSQL Ingestion Parameters\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote:\u003C/strong\u003E The screenshot shows \u003Ccode\u003Epostgres\u003C/code\u003E as the PostgreSQL Username. Based on your setup, use the appropriate username (e.g., Snowflake Postgres uses \u003Ccode\u003Esnowflake_admin\u003C/code\u003E by default).\u003C/p\u003E\n\u003C/blockquote\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EConfiguration Notes\u003C/strong\u003E:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ETable Regex Pattern\u003C/strong\u003E: The regex \u003Ccode\u003Ehealthcare\\..*\u003C/code\u003E matches all tables in the \u003Ccode\u003Ehealthcare\u003C/code\u003E schema. The backslash escapes the dot to match a literal period (e.g., \u003Ccode\u003Ehealthcare.patients\u003C/code\u003E, \u003Ccode\u003Ehealthcare.doctors\u003C/code\u003E, \u003Ccode\u003Ehealthcare.appointments\u003C/code\u003E, \u003Ccode\u003Ehealthcare.visits\u003C/code\u003E).\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EMerge Task Schedule\u003C/strong\u003E: The CRON expression \u003Ccode\u003E* * * * * ?\u003C/code\u003E means &quot;every second&quot;, providing near real-time CDC updates. For production workloads, adjust based on your latency requirements and cost considerations. Learn more about \u003Ca href=\"http://www.quartz-scheduler.org/documentation/quartz-2.3.0/tutorials/crontrigger.html\"\u003EQuartz CRON expressions\u003C/a\u003E.\u003C/li\u003E\u003C/ul\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EClick \u003Cstrong\u003EApply\u003C/strong\u003E to save your PostgreSQL ingestion parameters configuration.\u003C/p\u003E\n","\u003Cp\u003EWith all three parameter contexts configured, you're now ready to start the CDC pipeline!\u003C/p\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EVerify Snapshot Load\u003C/h2\u003E\n","\u003Cp\u003EWith the connector configured, you're now ready to start the CDC pipeline and verify that the initial snapshot is loaded correctly.\u003C/p\u003E\n","\u003Ch3\u003EEnable Services and Start Connector\u003C/h3\u003E\n","\u003Cp\u003EBefore starting the connector, you need to enable the controller services that manage the CDC replication process.\u003C/p\u003E\n","\u003Cp\u003EFollow these steps to enable services and start the connector:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003EOpen Controller Services\u003C/strong\u003E: Right-click on the canvas and select &quot;Configure&quot;\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EEnable Services\u003C/strong\u003E: Enable the two controller services (State Provider and Database Connection Pool)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EStart Process Groups\u003C/strong\u003E: Right-click on the process groups and start them\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EMonitor Progress\u003C/strong\u003E: Watch the connector flow execute the snapshot load\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/enable_service_and_start.gif?v=32b758de\" alt=\"Enable Services and Start Connector\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote\u003C/strong\u003E: You may see an error message about &quot;Snowflake Private Key Service&quot; failing to enable. This error can be safely ignored since this quickstart uses \u003Ccode\u003ESNOWFLAKE_SESSION_TOKEN\u003C/code\u003E authentication instead of private key authentication. The connector will function normally with session token authentication.\u003C/p\u003E\n\u003C/blockquote\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EWhat's Happening?\u003C/strong\u003E The connector performs two main operations:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003ESnapshot Load\u003C/strong\u003E: Captures all existing data from PostgreSQL tables and loads it into Snowflake\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ECDC Initialization\u003C/strong\u003E: Establishes the replication slot and begins listening for changes\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EThe snapshot typically takes 1-2 minutes for the demo dataset. For larger datasets, the duration will be proportional to the data volume.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EOnce the services are running, your connector status should show all components active:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/pg_connector_enabled_and_started.png?v=32b758de\" alt=\"PostgreSQL Connector Enabled and Started\"\u003E\u003C/p\u003E\n","\u003Ch3\u003EVerify Data in Snowflake\u003C/h3\u003E\n","\u003Cp\u003EAfter the snapshot completes, verify that the data was loaded successfully in Snowflake.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EIMPORTANT: Identifier Quoting Rule\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003EPostgreSQL creates lowercase unquoted identifiers (e.g., \u003Ccode\u003Ehealthcare\u003C/code\u003E, \u003Ccode\u003Eappointments\u003C/code\u003E, \u003Ccode\u003Epatient_id\u003C/code\u003E). When Openflow replicates these to Snowflake, they are preserved as \u003Cstrong\u003Ecase-sensitive lowercase\u003C/strong\u003E names.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EIn Snowflake, you MUST quote these identifiers in lowercase\u003C/strong\u003E:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E✅ Correct: \u003Ccode\u003EUSE SCHEMA &quot;healthcare&quot;; SELECT &quot;patient_id&quot;, &quot;status&quot; FROM &quot;appointments&quot;;\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E❌ Wrong: \u003Ccode\u003EUSE SCHEMA healthcare; SELECT patient_id, status FROM appointments;\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E❌ Wrong: \u003Ccode\u003ESELECT PATIENT_ID, STATUS FROM APPOINTMENTS;\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EWhy? Snowflake uppercases unquoted identifiers, so \u003Ccode\u003Eappointments\u003C/code\u003E becomes \u003Ccode\u003EAPPOINTMENTS\u003C/code\u003E, which won't match the actual table name \u003Ccode\u003Eappointments\u003C/code\u003E (lowercase). All queries in this quickstart follow this quoting convention.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003ECheck Record Counts\u003C/h4\u003E\n","\u003Cp\u003ERun the following query in Snowsight to verify all tables were created and populated:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE QUICKSTART_ROLE;\nUSE DATABASE QUICKSTART_PGCDC_DB;\nUSE SCHEMA &quot;healthcare&quot;;\nUSE WAREHOUSE QUICKSTART_PGCDC_WH;\n\nSELECT 'patients' as table_name, COUNT(*) as record_count FROM &quot;patients&quot;\nUNION ALL\nSELECT 'doctors', COUNT(*) FROM &quot;doctors&quot;\nUNION ALL\nSELECT 'appointments', COUNT(*) FROM &quot;appointments&quot;\nUNION ALL\nSELECT 'visits', COUNT(*) FROM &quot;visits&quot;\nORDER BY table_name;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E+----------------+--------------+\n| TABLE_NAME     | RECORD_COUNT |\n+----------------+--------------+\n| APPOINTMENTS   |          170 |\n| DOCTORS        |           10 |\n| PATIENTS       |          100 |\n| VISITS         |          100 |\n+----------------+--------------+\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003ENote: The initial snapshot loads 100 rows in \u003Ccode\u003E&quot;visits&quot;\u003C/code\u003E. Additional visit records are generated during the Live CDC demo, so this count will increase after running the steps in &quot;Generate Live CDC Events&quot;.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EVerify CDC Metadata\u003C/h4\u003E\n","\u003Cp\u003ECheck that CDC metadata columns are present and confirm the snapshot was loaded:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT \n    COUNT(*) as total_rows,\n    MIN(_SNOWFLAKE_INSERTED_AT) as earliest_inserted,\n    MAX(_SNOWFLAKE_INSERTED_AT) as latest_inserted,\n    COUNT(DISTINCT _SNOWFLAKE_INSERTED_AT) as unique_insert_timestamps\nFROM &quot;appointments&quot;;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output (timestamps will vary):\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E+------------+---------------------------+---------------------------+---------------------------+\n| TOTAL_ROWS | EARLIEST_INSERTED         | LATEST_INSERTED           | UNIQUE_INSERT_TIMESTAMPS  |\n+------------+---------------------------+---------------------------+---------------------------+\n|        170 | 2025-10-08 10:15:33.000   | 2025-10-08 10:15:45.000   |                        10 |\n+------------+---------------------------+---------------------------+---------------------------+\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThis confirms that all 170 appointments were successfully loaded during the snapshot phase.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ECDC Metadata Columns\u003C/strong\u003E: Openflow automatically adds the following metadata columns to track changes:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003E_SNOWFLAKE_INSERTED_AT\u003C/code\u003E (TIMESTAMP): When the row was first inserted into Snowflake during the snapshot or initial CDC event\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003E_SNOWFLAKE_UPDATED_AT\u003C/code\u003E (TIMESTAMP): When the row was last updated by CDC processing (remains NULL for snapshot-only rows)\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003E_SNOWFLAKE_DELETED\u003C/code\u003E (BOOLEAN): Logical delete flag (FALSE for active rows, TRUE when a DELETE event is captured)\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EDuring the Live CDC demo, you'll see \u003Ccode\u003E_SNOWFLAKE_UPDATED_AT\u003C/code\u003E populated when records are modified, and \u003Ccode\u003E_SNOWFLAKE_DELETED\u003C/code\u003E set to TRUE for deleted records.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EVerify Appointment Status Distribution\u003C/h4\u003E\n","\u003Cp\u003ECheck the distribution of appointment statuses:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT \n    &quot;status&quot;,\n    COUNT(*) as count,\n    ROUND(COUNT(*) * 100.0 / SUM(COUNT(*)) OVER (), 2) as percentage\nFROM &quot;appointments&quot;\nGROUP BY &quot;status&quot;\nORDER BY count DESC;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output (approximate - actual counts will vary):\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E+-----------+-------+------------+\n| STATUS    | COUNT | PERCENTAGE |\n+-----------+-------+------------+\n| completed |   100 |      58.82 |\n| cancelled |    40 |      23.53 |\n| scheduled |    15 |       8.82 |\n| no_show   |    10 |       5.88 |\n| confirmed |     5 |       2.94 |\n+-----------+-------+------------+\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote on Data Variability\u003C/strong\u003E: The exact counts and percentages will vary each time you run the initialization script because the appointment status is assigned using \u003Ccode\u003ERANDOM()\u003C/code\u003E in PostgreSQL. Your actual output might show \u003Ccode\u003Ecompleted: 102, cancelled: 44, no_show: 4\u003C/code\u003E or other values, which is completely normal. The important thing is that you see a mix of different statuses with \u003Ccode\u003Ecompleted\u003C/code\u003E being the most common (~60%), followed by \u003Ccode\u003Ecancelled\u003C/code\u003E (~25%).\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESave Baseline Results\u003C/strong\u003E: These snapshot results serve as your baseline for comparison. After running the CDC demo, you'll re-run this same query to see how the status distribution changed. Consider saving these results or taking a screenshot for easy side-by-side comparison later.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EVerify Doctor Workload\u003C/h4\u003E\n","\u003Cp\u003ECheck appointment distribution across doctors:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT \n    d.&quot;first_name&quot; || ' ' || d.&quot;last_name&quot; as doctor_name,\n    d.&quot;specialization&quot;,\n    d.&quot;department&quot;,\n    COUNT(a.&quot;appointment_id&quot;) as total_appointments,\n    SUM(CASE WHEN a.&quot;status&quot; = 'completed' THEN 1 ELSE 0 END) as completed_appointments,\n    SUM(CASE WHEN a.&quot;status&quot; IN ('scheduled', 'confirmed') THEN 1 ELSE 0 END) as upcoming_appointments\nFROM &quot;doctors&quot; d\nLEFT JOIN &quot;appointments&quot; a ON d.&quot;doctor_id&quot; = a.&quot;doctor_id&quot;\nGROUP BY d.&quot;doctor_id&quot;, d.&quot;first_name&quot;, d.&quot;last_name&quot;, d.&quot;specialization&quot;, d.&quot;department&quot;\nORDER BY total_appointments DESC\nLIMIT 5;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThis query shows the top 5 doctors by appointment volume, demonstrating that relational joins work correctly with the replicated data.\u003C/p\u003E\n","\u003Ch3\u003ERun Additional Verification Queries\u003C/h3\u003E\n","\u003Cp\u003EFor comprehensive verification, run the complete verification script from the companion GitHub repository:\u003C/p\u003E\n","\u003Cp\u003E📋 \u003Cstrong\u003EFull Verification Script\u003C/strong\u003E: \u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/2.verify_snapshot.sql\"\u003E2.verify_snapshot.sql\u003C/a\u003E\u003C/p\u003E\n","\u003Cp\u003EThe full script includes additional checks for:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EData quality validation (NULL checks)\u003C/li\u003E\u003Cli\u003EPatient demographics analysis\u003C/li\u003E\u003Cli\u003ERevenue summaries by doctor\u003C/li\u003E\u003Cli\u003ECommon diagnoses\u003C/li\u003E\u003Cli\u003EFollow-up and prescription statistics\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EYou can run this script directly in Snowsight by copying and pasting the SQL.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESnapshot Load Complete!\u003C/strong\u003E If all queries return expected results, your PostgreSQL tables are successfully replicated to Snowflake. The connector is now listening for changes and will automatically capture any INSERT, UPDATE, or DELETE operations in real-time.\u003C/p\u003E\n\u003C/blockquote\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003ESnowflake CoWork\u003C/h2\u003E\n","\u003Cp\u003ENow that the snapshot is loaded, let's set up Snowflake CoWork before generating CDC events. This allows you to establish a baseline understanding of your data, then observe changes in real-time after running the CDC demo.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EWhy Set Up Intelligence First?\u003C/strong\u003E By asking baseline questions about your snapshot data now, you'll be able to compare results after the CDC demo and see exactly how the data changed. This creates a powerful before/after experience for understanding CDC!\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EWhat You'll Build\u003C/h3\u003E\n","\u003Cp\u003EYou'll create an AI agent that can answer questions like:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E&quot;Show me doctor workload for today&quot;\u003C/li\u003E\u003Cli\u003E&quot;Which appointments were updated via CDC in the last hour?&quot;\u003C/li\u003E\u003Cli\u003E&quot;What's the revenue by specialization this month?&quot;\u003C/li\u003E\u003Cli\u003E&quot;How many records were soft-deleted today?&quot;\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EThe agent understands your healthcare schema AND the CDC metadata columns for tracking changes!\u003C/p\u003E\n","\u003Ch3\u003EPrerequisites\u003C/h3\u003E\n","\u003Cp\u003EBefore setting up Snowflake CoWork, ensure you have:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E✅ Completed snapshot load with Openflow pipeline running\u003C/li\u003E\u003Cli\u003E✅ Snowflake CoWork infrastructure created (this was done in \u003Ccode\u003E1.snowflake_setup.sql\u003C/code\u003E which created the \u003Ccode\u003Esnowflake_intelligence\u003C/code\u003E database and \u003Ccode\u003Eagents\u003C/code\u003E schema)\u003C/li\u003E\u003Cli\u003E✅ Default role and warehouse set in your Snowflake user profile\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003EUpload Semantic Model\u003C/h3\u003E\n","\u003Cp\u003EThe semantic model defines your healthcare schema for the AI agent. It includes table definitions, relationships, and CDC metadata columns.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENOTE:\u003C/strong\u003E The \u003Ccode\u003Esemantic_models\u003C/code\u003E stage and \u003Ccode\u003Esnowflake_intelligence\u003C/code\u003E database were already created when you ran \u003Ccode\u003E1.snowflake_setup.sql\u003C/code\u003E. You just need to upload the semantic model file!\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EUpload the semantic model to the stage using Snowsight:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ENavigate directly to \u003Cstrong\u003EIngestion\u003C/strong\u003E --&gt; \u003Cstrong\u003EAdd Data\u003C/strong\u003E: &lt;a href=&quot;https://app.snowflake.com/_deeplink/#/data/add-data?utm_source=snowflake-devrel&amp;utm_medium=developer-guides&amp;utm_campaign=-us-en-all&amp;utm_content=app-getting-started-with-openflow-postgresql-cdc&amp;utm_cta=developer-guides-deeplink&quot; class=&quot;_deeplink&quot;&gt;Load files into a Stage&lt;/a&gt;\u003C/li\u003E\u003Cli\u003ESelect the database, schema, and stage:\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EDatabase:\u003C/strong\u003E \u003Ccode\u003EQUICKSTART_PGCDC_DB\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESchema:\u003C/strong\u003E \u003Ccode\u003EPUBLIC\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EStage:\u003C/strong\u003E \u003Ccode\u003Esemantic_models\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003C/li\u003E\u003Cli\u003EClick \u003Cstrong\u003E+ Files\u003C/strong\u003E and select \u003Ccode\u003Ehealthcare_cdc_semantic_model.yaml\u003C/code\u003E from the \u003Ccode\u003Esemantic-models/\u003C/code\u003E directory in your cloned repository\u003C/li\u003E\u003Cli\u003EClick \u003Cstrong\u003EUpload\u003C/strong\u003E\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/upload_semantic_model.png?v=32b758de\" alt=\"Upload Semantic Model\"\u003E\u003C/p\u003E\n","\u003Cp\u003EOr use Snowflake CLI:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Esnow stage put semantic-models/healthcare_cdc_semantic_model.yaml @semantic_models \\\n  --database QUICKSTART_PGCDC_DB \\\n  --schema PUBLIC \\\n  --role QUICKSTART_ROLE \\\n  --overwrite\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EVerify the upload via &lt;a href=&quot;https://app.snowflake.com/_deeplink/#/data/databases/QUICKSTART_PGCDC_DB/schemas/PUBLIC/stage/SEMANTIC_MODELS?utm_source=snowflake-devrel&amp;utm_medium=developer-guides&amp;utm_campaign=-us-en-all&amp;utm_content=app-getting-started-with-openflow-postgresql-cdc&amp;utm_cta=developer-guides-deeplink&quot; class=&quot;_deeplink&quot;&gt;Database Explorer&lt;/a&gt;\u003C/p\u003E\n","\u003Ch3\u003ECreate the Agent\u003C/h3\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EIMPORTANT:\u003C/strong\u003E Before creating the agent, ensure you are using the \u003Ccode\u003EQUICKSTART_ROLE\u003C/code\u003E role in Snowsight. This ensures the agent is owned by the correct role and has proper access to resources. You can switch roles using the role selector in the top-right corner of Snowsight.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EAccess Agent Creation Interface\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003ESign in to Snowsight\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESwitch to \u003Ccode\u003EQUICKSTART_ROLE\u003C/code\u003E\u003C/strong\u003E using the role selector in the top-right corner\u003C/li\u003E\u003Cli\u003ENavigate directly to Agents: &lt;a href=&quot;https://app.snowflake.com/_deeplink/#/agents?utm_source=snowflake-devrel&amp;utm_medium=developer-guides&amp;utm_campaign=-us-en-all&amp;utm_content=app-buidling-new-snowflake-intelligence-agents&amp;utm_cta=developer-guides-deeplink&quot; class=&quot;_deeplink&quot;&gt;Create Snowflake CoWork Agent&lt;/a&gt;\u003C/li\u003E\u003Cli\u003ESelect \u003Cstrong\u003E&quot;Create agent&quot;\u003C/strong\u003E\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_create.png?v=32b758de\" alt=\"Agent Creation Interface\"\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EPlatform Integration:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E☑️ Select \u003Cstrong\u003E&quot;Create this agent for Snowflake CoWork&quot;\u003C/strong\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EAgent Details:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EAgent object name:\u003C/strong\u003E \u003Ccode\u003EHEALTHCARE_DATA_INTELLIGENCE\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EDisplay name:\u003C/strong\u003E \u003Ccode\u003EHealthcare Data Intelligence (Snapshot &amp; CDC)\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch4\u003EConfigure Agent Basics\u003C/h4\u003E\n","\u003Cp\u003EAfter creating the agent, configure its details:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EClick on the agent name\u003C/strong\u003E (\u003Ccode\u003EHEALTHCARE_DATA_INTELLIGENCE\u003C/code\u003E) in the agent list to open it\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agents_list.png?v=32b758de\" alt=\"Agents List\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003E\u003Cstrong\u003EClick &quot;Edit&quot;\u003C/strong\u003E button to start editing the agent configuration\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_edit.png?v=32b758de\" alt=\"Agent Edit Button\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EIMPORTANT:\u003C/strong\u003E As you configure each section below (About, Tools, Orchestration, Access), remember to click \u003Cstrong\u003E&quot;SAVE&quot;\u003C/strong\u003E after completing all configurations to ensure your changes are preserved.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003ENow configure the agent basics in the &quot;About&quot; section:\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_about.png?v=32b758de\" alt=\"Agent About Configuration\"\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EDescription:\u003C/strong\u003E \u003Ccode\u003EQuery and analyze healthcare appointment data with real-time CDC tracking using natural language. Powered by OpenFlow PostgreSQL CDC pipeline.\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExample Questions\u003C/strong\u003E (Add these to help users get started):\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Show me the appointment status distribution&quot;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Which doctors have the most appointments?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;What appointments were updated via CDC today?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Show revenue by doctor specialization&quot;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;How many records were soft-deleted in the last 24 hours?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch3\u003EConfigure Agent Tools\u003C/h3\u003E\n","\u003Ch4\u003EAdd Semantic Model\u003C/h4\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_tools_defaults.gif?v=32b758de\" alt=\"Agent Tools Configuration\"\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003E&quot;Tools&quot;\u003C/strong\u003E tab\u003C/li\u003E\u003Cli\u003EFind \u003Cstrong\u003E&quot;Semantic Models&quot;\u003C/strong\u003E section\u003C/li\u003E\u003Cli\u003EClick \u003Cstrong\u003E&quot;+ Add&quot;\u003C/strong\u003E button\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cstrong\u003EConfigure the Semantic Model:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003EName:\u003C/strong\u003E \u003Ccode\u003EHEALTHCARE_DATA_ANALYTICS\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EStage:\u003C/strong\u003E \u003Ccode\u003E@PUBLIC.semantic_models\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EFile:\u003C/strong\u003E \u003Ccode\u003Ehealthcare_cdc_semantic_model.yaml\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EDescription:\u003C/strong\u003E \u003Ccode\u003EHealthcare appointment management with real-time snapshot and CDC data tracking\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETIP:\u003C/strong\u003E The semantic model includes definitions for all four tables (patients, doctors, appointments, visits) plus their relationships and CDC metadata columns (_Snowflake_INSERTED_AT,_Snowflake_UPDATED_AT, _Snowflake_DELETED).\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EConfigure Orchestration\u003C/h3\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_orchestration.png?v=32b758de\" alt=\"Agent Orchestration Configuration\"\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003E&quot;Orchestration&quot;\u003C/strong\u003E tab\u003C/li\u003E\u003Cli\u003ESet \u003Cstrong\u003EModel:\u003C/strong\u003E \u003Ccode\u003Eauto\u003C/code\u003E (recommended - lets Snowflake choose the optimal model)\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOrchestration Instructions:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode\u003EWhenever you can answer visually with a chart, always choose to generate a chart even if the user didn't specify to. \nRespond in the same language as the question wherever possible.\nWhen querying appointments or visits, consider filtering out soft-deleted records (_SNOWFLAKE_DELETED = FALSE) unless the user specifically asks about deleted data.\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EResponse Instructions:\u003C/strong\u003E (Optional)\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode\u003EAlways provide specific metrics and counts when answering quantitative questions.\nWhen showing CDC-related data, explain what the metadata columns mean (e.g., _SNOWFLAKE_UPDATED_AT indicates when the record was modified via CDC).\nFocus on actionable insights for healthcare operations.\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETIP:\u003C/strong\u003E Use \u003Ccode\u003Eauto\u003C/code\u003E (default) to let Snowflake automatically select the best available model for your region and query type. Supported models include Claude 4.0, Claude 3.7, Claude 3.5, and GPT 4.1.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003ESet Access Controls\u003C/h3\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_access.png?v=32b758de\" alt=\"Agent Access Configuration\"\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003E&quot;Access&quot;\u003C/strong\u003E tab\u003C/li\u003E\u003Cli\u003EClick \u003Cstrong\u003E&quot;Add role&quot;\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003ESelect appropriate roles for your organization\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExample Role Configuration:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ERole:\u003C/strong\u003E \u003Ccode\u003EQUICKSTART_ROLE\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EPermission:\u003C/strong\u003E \u003Ccode\u003EOWNERSHIP\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENOTE:\u003C/strong\u003E All queries use the user's credentials. Ensure users have appropriate access to the \u003Ccode\u003EQUICKSTART_PGCDC_DB.&quot;healthcare&quot;\u003C/code\u003E schema and underlying tables.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EAsk Baseline Questions (Snapshot Data)\u003C/h3\u003E\n","\u003Cp\u003ENow that your agent is configured, let's ask baseline questions about the snapshot data to establish the initial state.\u003C/p\u003E\n","\u003Ch4\u003EGetting Started with Queries\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003E\n","\u003Cp\u003EAccess Snowflake CoWork: \u003Ca href=\"https://ai.snowflake.com/\"\u003EOpen Snowflake CoWork\u003C/a\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ESelect your agent \u003Ccode\u003EHealthcare Data Intelligence (Snapshot &amp; CDC)\u003C/code\u003E from the dropdown\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_chat_choose_agent.png?v=32b758de\" alt=\"Choose Agent\"\u003E\u003C/p\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003ESet the role and warehouse for the agent to use:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003ERole:\u003C/strong\u003E \u003Ccode\u003EQUICKSTART_ROLE\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EWarehouse:\u003C/strong\u003E \u003Ccode\u003EQUICKSTART_PGCDC_WH\u003C/code\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_pgcdc_chat_choose_role.gif?v=32b758de\" alt=\"Set Role and Warehouse\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EIMPORTANT:\u003C/strong\u003E The agent will use these credentials to query your data. Make sure the role has access to the \u003Ccode\u003EQUICKSTART_PGCDC_DB.&quot;healthcare&quot;\u003C/code\u003E schema and all tables.\u003C/p\u003E\n\u003C/blockquote\u003E\n\u003C/li\u003E\u003Cli\u003E\n","\u003Cp\u003EStart with these baseline questions:\u003C/p\u003E\n\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cstrong\u003EBaseline Questions:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;How many total appointments do we have?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E ~170 appointments from snapshot load\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Show me the appointment status distribution&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Breakdown showing completed (100), cancelled (40), scheduled (15), no_show (10), confirmed (5)\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Which doctors have the most appointments?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E List of 10 doctors with appointment counts\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;What's the total revenue from all visits?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Sum of charges from 100 visits (~$15,000-$20,000)\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Show me appointments by specialization&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Breakdown by General Practice, Cardiology, Pediatrics, Orthopedics, etc.\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Are there any records with CDC updates yet?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E &quot;No, all records are from the initial snapshot load. The _Snowflake_UPDATED_AT column is NULL for all records.&quot;\u003C/p\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_queries.gif?v=32b758de\" alt=\"Agent Queries\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EBaseline Established!\u003C/strong\u003E You now have a clear picture of your snapshot data. Keep these numbers in mind - after running the CDC demo in the next section, you'll ask follow-up questions to see exactly what changed!\u003C/p\u003E\n\u003C/blockquote\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EGenerate Live CDC Events\u003C/h2\u003E\n","\u003Cp\u003ENow that the snapshot is loaded, let's generate live CDC events to see real-time replication in action. We'll simulate a busy morning at DemoClinic Healthcare with various database operations.\u003C/p\u003E\n","\u003Ch3\u003EWhat CDC Events Will Be Generated\u003C/h3\u003E\n","\u003Cp\u003EThe demo script simulates a busy morning at DemoClinic Healthcare (8:00 AM - 12:45 PM) and will generate the following CDC events:\u003C/p\u003E\n\u003Ctable\u003E\u003Cthead\u003E\u003Ctr\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EEvent Type\u003C/strong\u003E\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EOperation\u003C/strong\u003E\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003ECount\u003C/strong\u003E\u003C/th\u003E\u003Cth colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EDescription\u003C/strong\u003E\u003C/th\u003E\u003C/tr\u003E\u003C/thead\u003E\u003Ctbody\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EINSERT\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ENew Appointments\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003E10\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E- 3 scheduled appointments (8:00 AM)&lt;br&gt;- 2 urgent walk-ins (10:00 AM)&lt;br&gt;- 5 future appointments (12:00 PM)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EINSERT\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ENew Visit Records\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003E4\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E- 2 completed visits (9:30 AM)&lt;br&gt;- 2 more completed visits (11:30 AM)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EUPDATE\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EAppointment Status Changes\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003E20+\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E- Scheduled &rarr; Confirmed (morning batch)&lt;br&gt;- Confirmed &rarr; Checked In (4 + 2 patients)&lt;br&gt;- Checked In &rarr; In Progress (2 + 2 appointments)&lt;br&gt;- In Progress &rarr; Completed (2 + 2 visits)&lt;br&gt;- Confirmed &rarr; Cancelled (1 appointment)&lt;br&gt;- Confirmed &rarr; No Show (1 patient)\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EDELETE\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003ERemoved Appointments\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003E2\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E- Old cancelled appointments deleted (soft delete in Snowflake)&lt;br&gt;- Deletes the 2 appointments with lowest IDs from old cancelled records\u003C/td\u003E\u003C/tr\u003E\u003Ctr\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003EUPDATE\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003EDoctor Records\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E\u003Cstrong\u003E1\u003C/strong\u003E\u003C/td\u003E\u003Ctd colspan=\"1\" rowspan=\"1\"\u003E- Doctor availability changed (accepting_new_patients = FALSE)\u003C/td\u003E\u003C/tr\u003E\u003C/tbody\u003E\u003C/table\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETotal Impact:\u003C/strong\u003E\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003E170 &rarr; 180\u003C/strong\u003E appointments (net +10, accounting for 2 deletes)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E100 &rarr; 104\u003C/strong\u003E visit records (net +4)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E20+\u003C/strong\u003E appointment status transitions captured\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E2\u003C/strong\u003E soft-deleted records (visible with \u003Ccode\u003E_SNOWFLAKE_DELETED = TRUE\u003C/code\u003E)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E1\u003C/strong\u003E doctor record update\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EReal CDC Patterns\u003C/strong\u003E: This script demonstrates all major CDC event types you'll encounter in production: customer records being created (INSERT), order statuses changing (UPDATE), and old data being archived (DELETE). The timing is designed to align with Openflow's 1-minute sync interval!\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003ERun CDC Demo Script\u003C/h3\u003E\n","\u003Cp\u003EThe easiest way to generate CDC events is to run the provided SQL script on your PostgreSQL database.\u003C/p\u003E\n","\u003Ch4\u003EOption 1: Using psql Command Line\u003C/h4\u003E\n","\u003Cp\u003EIf you have the environment variables set from earlier, run:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -f sql/3.live_appointments.sql\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EOr with explicit connection:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003Epsql -h YOUR_POSTGRES_HOST \\\n     -p 5432 \\\n     -U postgres \\\n     -d postgres \\\n     -f sql/3.live_appointments.sql\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EOption 2: Copy and Paste in pgAdmin or PostgreSQL Client\u003C/h4\u003E\n\u003Col\u003E\u003Cli\u003EOpen the script: \u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/3.live_appointments.sql\"\u003E3.live_appointments.sql\u003C/a\u003E\u003C/li\u003E\u003Cli\u003ECopy the entire contents\u003C/li\u003E\u003Cli\u003EPaste into your PostgreSQL client (pgAdmin, DBeaver, etc.)\u003C/li\u003E\u003Cli\u003EExecute the script\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003EThe script will:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ERun for approximately \u003Cstrong\u003E5 minutes\u003C/strong\u003E (with strategic pauses)\u003C/li\u003E\u003Cli\u003EDisplay progress messages with timestamps (8:00 AM &rarr; 12:45 PM simulation)\u003C/li\u003E\u003Cli\u003EWait 60 seconds after major operations to align with CDC sync intervals\u003C/li\u003E\u003Cli\u003EShow a summary of changes at the end\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EPerfect Timing for CDC\u003C/strong\u003E: The script includes 60-second pauses after key operations to align with Openflow's 1-minute CDC sync interval. This lets you:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003ESwitch to Snowflake between operations to observe changes appearing\u003C/li\u003E\u003Cli\u003ESee multiple CDC sync cycles in action\u003C/li\u003E\u003Cli\u003EUnderstand the near real-time nature of CDC (not instant, but very fast!)\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EThe script displays &quot;⏳ Waiting 60 seconds for CDC sync...&quot; messages to indicate when it's a good time to check Snowflake.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EExpected Output\u003C/h4\u003E\n","\u003Cp\u003EYou should see output like this:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E🕐 8:00 AM - New appointment requests coming in...\n✅ 3 new appointments scheduled\n\n🕐 8:15 AM - Front desk confirming today's appointments...\n✅ Today's appointments confirmed\n\n🕐 8:30 AM - Patients checking in for their appointments...\n✅ 4 patients checked in\n\n...\n\n═══════════════════════════════════════════════════════════\n📊 CDC Demo Summary - Changes Generated\n═══════════════════════════════════════════════════════════\n\n activity                            | count \n-------------------------------------+-------\n New appointments created            |    10\n Appointments updated (status changes)|    20\n New visit records created           |     4\n Doctor records updated              |     1\n\n✅ All CDC events have been generated!\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch3\u003EVerify Changes in Snowflake\u003C/h3\u003E\n","\u003Cp\u003EWhile the script is running (or immediately after), switch to Snowflake to see the changes appear in real-time.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETip - Refresh Openflow Canvas\u003C/strong\u003E: You can also monitor CDC activity in the Openflow UI. Right-click on the canvas and select \u003Cstrong\u003ERefresh\u003C/strong\u003E to see updated statistics (records processed, events captured, etc.) on the connector flows in real-time.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003ECheck Updated Row Counts\u003C/h4\u003E\n","\u003Cp\u003ERun this query to see the increased record counts:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003EUSE ROLE QUICKSTART_ROLE;\nUSE DATABASE QUICKSTART_PGCDC_DB;\nUSE SCHEMA &quot;healthcare&quot;;\nUSE WAREHOUSE QUICKSTART_PGCDC_WH;\n\nSELECT 'patients' as table_name, COUNT(*) as record_count FROM &quot;patients&quot;\nUNION ALL\nSELECT 'doctors', COUNT(*) FROM &quot;doctors&quot;\nUNION ALL\nSELECT 'appointments', COUNT(*) FROM &quot;appointments&quot;\nUNION ALL\nSELECT 'visits', COUNT(*) FROM &quot;visits&quot;\nORDER BY table_name;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output (compare to snapshot baseline of 170 appointments, 100 visits):\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E+----------------+--------------+\n| TABLE_NAME     | RECORD_COUNT |\n+----------------+--------------+\n| appointments   |          180 | -- +10 new appointments (net: 12 inserts - 2 deletes)\n| doctors        |           10 | -- unchanged\n| patients       |          100 | -- unchanged\n| visits         |          104 | -- +4 new visit records\n+----------------+--------------+\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EVerify CDC Metadata Shows Updates\u003C/h4\u003E\n","\u003Cp\u003ECheck the CDC metadata timestamps to see snapshot vs updated records:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT \n    COUNT(*) as total_records,\n    SUM(CASE WHEN _SNOWFLAKE_DELETED THEN 1 ELSE 0 END) as deleted_records,\n    COUNT(DISTINCT _SNOWFLAKE_INSERTED_AT) as distinct_insert_times,\n    COUNT(DISTINCT _SNOWFLAKE_UPDATED_AT) as distinct_update_times\nFROM &quot;appointments&quot;;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E+----------------+-----------------+-----------------------+-----------------------+\n| TOTAL_RECORDS  | DELETED_RECORDS | DISTINCT_INSERT_TIMES | DISTINCT_UPDATE_TIMES |\n+----------------+-----------------+-----------------------+-----------------------+\n|           180  |               2 |                    2+ |                    2+ |\n+----------------+-----------------+-----------------------+-----------------------+\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThis shows:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003E180\u003C/strong\u003E total appointments (170 original + 10 new from CDC)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E2\u003C/strong\u003E deleted appointments (soft deleted with \u003Ccode\u003E_SNOWFLAKE_DELETED = TRUE\u003C/code\u003E)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E2+\u003C/strong\u003E distinct insert times (snapshot load + CDC inserts)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003E2+\u003C/strong\u003E distinct update times (various CDC updates)\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003ETo see the distribution of when records were inserted:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT \n    DATE_TRUNC('minute', _SNOWFLAKE_INSERTED_AT) as insert_minute,\n    COUNT(*) as records_inserted\nFROM &quot;appointments&quot;\nGROUP BY insert_minute\nORDER BY insert_minute;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThis will show you the snapshot load followed by CDC inserts happening later.\u003C/p\u003E\n","\u003Ch4\u003EQuery the Journal Tables\u003C/h4\u003E\n","\u003Cp\u003ESnowflake Openflow creates journal tables that track all CDC events. These tables are created dynamically as CDC events occur for each table, following the naming pattern: \u003Ccode\u003E&lt;source_table_name&gt;_JOURNAL_&lt;timestamp&gt;_&lt;schema_generation&gt;\u003C/code\u003E where:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003E&lt;timestamp&gt;\u003C/code\u003E = Epoch seconds when the source table was added to replication\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003E&lt;schema_generation&gt;\u003C/code\u003E = Integer starting at 1, increasing with each schema change on the source table\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EBased on the CDC events generated by the live appointments script, you'll see these journal tables appear in order:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003E\u003Cstrong\u003EFirst\u003C/strong\u003E: \u003Ccode\u003Eappointments_JOURNAL_1759908563_1\u003C/code\u003E - Created when appointment status changes occur\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ESecond\u003C/strong\u003E: \u003Ccode\u003Evisits_JOURNAL_1759908563_1\u003C/code\u003E - Created when new visit records are added\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003EThird\u003C/strong\u003E: \u003Ccode\u003Edoctors_JOURNAL_1759908563_1\u003C/code\u003E - Created when doctor availability is updated\u003C/li\u003E\u003C/ol\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EJournal Table Naming\u003C/strong\u003E: The timestamp portion (e.g., \u003Ccode\u003E1759908563\u003C/code\u003E) will be different in your environment based on when tables are added to replication. The schema generation number starts at \u003Ccode\u003E1\u003C/code\u003E and increments if the source table schema changes. For more details, see \u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/setup#track-data-changes-in-tables\"\u003ETrack data changes in tables\u003C/a\u003E in the Snowflake documentation.\u003C/p\u003E\n\u003C/blockquote\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFind Your Journal Tables\u003C/strong\u003E: You can see which journal tables have been created by running:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESHOW TABLES LIKE '%_JOURNAL_%' IN SCHEMA &quot;healthcare&quot;;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThis will list all journal tables that Openflow has created as CDC events occurred. The tables appear in order as different table types experience their first CDC event.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EQuery recent CDC events for appointments:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- View recent CDC events for appointments\n-- Replace the timestamp with your actual journal table name\nSELECT \n    SEEN_AT as event_time,\n    EVENT_TYPE,\n    &quot;PRIMARY_KEY__appointment_id&quot; as appointment_id,\n    &quot;PAYLOAD__patient_id&quot; as patient_id,\n    &quot;PAYLOAD__doctor_id&quot; as doctor_id,\n    &quot;PAYLOAD__status&quot; as status,\n    &quot;PAYLOAD__reason_for_visit&quot; as reason_for_visit,\n    &quot;PAYLOAD__appointment_date&quot; as appointment_date\nFROM QUICKSTART_PGCDC_DB.&quot;healthcare&quot;.&quot;appointments_JOURNAL_1759908563_1&quot;\nWHERE SEEN_AT &gt;= DATEADD(minute, -10, CURRENT_TIMESTAMP)\nORDER BY SEEN_AT DESC\nLIMIT 20;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EJournal Table Structure\u003C/strong\u003E: Journal tables track all CDC events with:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ccode\u003EEVENT_TYPE\u003C/code\u003E: The operation type - \u003Ccode\u003EIncrementalInsertRows\u003C/code\u003E, \u003Ccode\u003EIncrementalUpdateRows\u003C/code\u003E, or \u003Ccode\u003EIncrementalDeleteRows\u003C/code\u003E\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003ESEEN_AT\u003C/code\u003E: Timestamp when the CDC event was captured\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003EPRIMARY_KEY__&lt;column&gt;\u003C/code\u003E: Primary key column(s) from the source table (quoted, lowercase)\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003EPAYLOAD__&lt;column&gt;\u003C/code\u003E: All data columns from the source table (quoted, lowercase)\u003C/li\u003E\u003Cli\u003E\u003Ccode\u003ESF_METADATA\u003C/code\u003E: Additional Snowflake CDC metadata\u003C/li\u003E\u003C/ul\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003ETo find your actual journal table names:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESHOW TABLES LIKE '%_JOURNAL_%' IN SCHEMA QUICKSTART_PGCDC_DB.&quot;healthcare&quot;;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EThis shows the complete audit trail of all changes captured by CDC!\u003C/p\u003E\n","\u003Ch4\u003EView Deleted Records\u003C/h4\u003E\n","\u003Cp\u003EQuery appointments that were deleted (soft delete):\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT \n    &quot;appointment_id&quot;,\n    &quot;patient_id&quot;,\n    &quot;status&quot;,\n    &quot;appointment_date&quot;,\n    &quot;reason_for_visit&quot;,\n    _SNOWFLAKE_INSERTED_AT,\n    _SNOWFLAKE_UPDATED_AT,\n    _SNOWFLAKE_DELETED\nFROM &quot;appointments&quot;\nWHERE _SNOWFLAKE_DELETED = TRUE;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output (the exact \u003Ccode\u003Eappointment_id\u003C/code\u003E and \u003Ccode\u003Epatient_id\u003C/code\u003E values will be consistent across runs due to deterministic \u003Ccode\u003EORDER BY appointment_id\u003C/code\u003E):\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E+-----------------+------------+------------+------------------+-----------------------------+---------------------------+---------------------------+----------------------+\n| APPOINTMENT_ID  | PATIENT_ID | STATUS     | APPOINTMENT_DATE | REASON_FOR_VISIT            | _SNOWFLAKE_INSERTED_AT    | _SNOWFLAKE_UPDATED_AT     | _SNOWFLAKE_DELETED   |\n+-----------------+------------+------------+------------------+-----------------------------+---------------------------+---------------------------+----------------------+\n|             123 |         45 | cancelled  | 2024-08-15       | Annual physical examination | 2025-10-08 10:15:33.000   | 2025-10-08 15:30:22.000   | TRUE                 |\n|             156 |         78 | cancelled  | 2024-09-01       | Routine checkup             | 2025-10-08 10:15:40.000   | 2025-10-08 15:30:22.000   | TRUE                 |\n+-----------------+------------+------------+------------------+-----------------------------+---------------------------+---------------------------+----------------------+\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote on Deleted Record IDs\u003C/strong\u003E: The specific appointment IDs deleted will be consistent across multiple runs of the demo because the DELETE query uses \u003Ccode\u003EORDER BY appointment_id\u003C/code\u003E to select the 2 oldest cancelled appointments deterministically. The actual IDs depend on which appointments were randomly assigned \u003Ccode\u003Ecancelled\u003C/code\u003E status during your PostgreSQL initialization.\u003C/p\u003E\n\u003C/blockquote\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESoft Deletes\u003C/strong\u003E: Notice that deleted records are still queryable in Snowflake! The \u003Ccode\u003E_SNOWFLAKE_DELETED\u003C/code\u003E flag marks them as deleted, but the data is preserved. This is crucial for:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003EAudit trails and compliance\u003C/li\u003E\u003Cli\u003EHistorical analysis\u003C/li\u003E\u003Cli\u003EData recovery if needed\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EYou can filter deleted records out of queries with \u003Ccode\u003EWHERE _SNOWFLAKE_DELETED = FALSE\u003C/code\u003E or \u003Ccode\u003EWHERE NOT _SNOWFLAKE_DELETED\u003C/code\u003E.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003ECompare Before and After Status Distribution\u003C/h4\u003E\n","\u003Cp\u003ERe-run the status distribution query to see the changes:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT \n    &quot;status&quot;,\n    COUNT(*) as count,\n    ROUND(COUNT(*) * 100.0 / SUM(COUNT(*)) OVER (), 2) as percentage\nFROM &quot;appointments&quot;\nWHERE NOT _SNOWFLAKE_DELETED  -- Exclude deleted records\nGROUP BY &quot;status&quot;\nORDER BY count DESC;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EKey Changes from Baseline:\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003EThe CDC script will create these changes:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Cstrong\u003Ecompleted\u003C/strong\u003E: Increases by +4 (new completed visits)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003Escheduled\u003C/strong\u003E: Increases by +5 (new future appointments)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003Eno_show\u003C/strong\u003E: Increases by +1 (missed appointment)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003Econfirmed\u003C/strong\u003E: Decreases as some move to other statuses\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003Ein_progress\u003C/strong\u003E: New status with +2 (active visits)\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ETotal active records\u003C/strong\u003E: 170 &rarr; 180 (+10 net, accounting for 2 soft deletes)\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003EThe exact counts and percentages will vary based on your baseline snapshot data (which uses \u003Ccode\u003ERANDOM()\u003C/code\u003E for initial status assignment), but you should see the relative changes described above.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EReal-time CDC in Action!\u003C/strong\u003E The changes you made in PostgreSQL appeared in Snowflake within seconds. This demonstrates the power of CDC for real-time data integration and analytics.\u003C/p\u003E\n\u003C/blockquote\u003E\n\u003Chr\u003E\n","\u003Ch3\u003EReturn to Snowflake CoWork (Ask CDC Questions)\u003C/h3\u003E\n","\u003Cp\u003ENow that CDC events have been processed, return to your Snowflake CoWork agent and ask CDC-specific questions to see the changes!\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003EAccess Snowflake CoWork: \u003Ca href=\"https://ai.snowflake.com/\"\u003EOpen Snowflake CoWork\u003C/a\u003E\u003C/li\u003E\u003Cli\u003ESelect your agent \u003Ccode\u003EHEALTHCARE_DATA_INTELLIGENCE\u003C/code\u003E from the dropdown\u003C/li\u003E\u003Cli\u003E\u003Cstrong\u003ERefresh the agent cache\u003C/strong\u003E by clicking the refresh button or typing a new question (this ensures the agent fetches the latest CDC data)\u003C/li\u003E\u003Cli\u003EAsk these CDC-focused questions:\u003C/li\u003E\u003C/ol\u003E\n","\u003Ch4\u003ECDC Monitoring Questions\u003C/h4\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETrack Recent Changes:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;How many appointments were updated via CDC in the last hour?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ECount of records with \u003Ccode\u003E_SNOWFLAKE_UPDATED_AT\u003C/code\u003E in the last hour (typically 10-30 records depending on timing)\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Show me all appointments that were modified today via CDC&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ETable with appointment details and \u003Ccode\u003E_SNOWFLAKE_UPDATED_AT\u003C/code\u003E timestamps\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Which appointments were soft-deleted?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E2 cancelled appointments that were removed (where \u003Ccode\u003E_SNOWFLAKE_DELETED = TRUE\u003C/code\u003E)\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ENote on Counts\u003C/strong\u003E: The exact numbers you see may vary based on when you run the CDC script, how long it runs, and the timing of CDC sync intervals. For example, you might see &quot;12 appointments were updated&quot; or &quot;30 appointments were updated&quot; - both are correct depending on which CDC events have been synced at query time. The key is to verify that CDC events are being captured, not to match exact counts.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003ECompare Before and After\u003C/h4\u003E\n","\u003Cp\u003E\u003Cstrong\u003ECompare to Your Baseline:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;What's the new appointment status distribution?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Updated counts showing more completed appointments than the baseline\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;How many new visit records were created today?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Visit count increase from baseline of 100 to 110 visits\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Show me appointments that changed from scheduled to completed&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Appointments with status transitions during the CDC demo\u003C/p\u003E\n","\u003Ch4\u003EOperational Analytics\u003C/h4\u003E\n","\u003Cp\u003E\u003Cstrong\u003EReal-time Operations:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Which doctors completed the most visits today?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Doctor rankings with today's completed visit counts\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;What's today's total revenue from visits?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Sum of charges from visits created today (~$2,000-$3,000 from new visits)\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Show me all urgent appointments added today&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Walk-in appointments with urgent status added during CDC demo\u003C/p\u003E\n","\u003Ch4\u003ECDC Audit Trail\u003C/h4\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETrack Changes:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Show me appointments with status changes in the last 2 hours?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Appointments with \u003Ccode\u003E_SNOWFLAKE_UPDATED_AT\u003C/code\u003E in last 2 hours\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;How many total records have been modified via CDC?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Count where \u003Ccode\u003E_SNOWFLAKE_UPDATED_AT IS NOT NULL\u003C/code\u003E (~30 records)\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;What percentage of appointments were updated via incremental vs snapshot only?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Ratio showing ~85% snapshot, ~15% CDC-modified\u003C/p\u003E\n","\u003Ch4\u003EAdvanced CDC Questions\u003C/h4\u003E\n","\u003Cp\u003E\u003Cstrong\u003EChange Patterns:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Show me the timeline of appointment status changes today&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Time-series of status transitions with timestamps\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Which patient had the most appointment updates?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Patient with multiple appointment modifications during the demo\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Compare snapshot-only vs CDC-updated appointment counts&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Breakdown showing 170 snapshot, 30 CDC-modified\u003C/p\u003E\n","\u003Ch4\u003EBusiness Insights\u003C/h4\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOperational Metrics:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;What's the cancellation rate for today's appointments?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Percentage of cancelled appointments\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;Show revenue by doctor for visits completed in the last hour&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Recent revenue attribution from new visits\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-text\"\u003E&quot;How many appointments need follow-up visits?&quot;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExpected:\u003C/strong\u003E Count from visits where \u003Ccode\u003Efollow_up_required = TRUE\u003C/code\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EPro Tip:\u003C/strong\u003E Snowflake CoWork understands the CDC metadata columns and can differentiate between snapshot data and real-time changes. Try asking comparative questions like &quot;Show me only the appointments that changed today&quot; to see CDC-specific insights!\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EAlternative: SQL Queries\u003C/h3\u003E\n","\u003Cp\u003EIf you prefer SQL over natural language, you can also use the comprehensive analytics script with 20+ pre-built queries:\u003C/p\u003E\n","\u003Cp\u003E📋 \u003Cstrong\u003EAnalytics Script\u003C/strong\u003E: \u003Ca href=\"https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/4.analytics_queries.sql\"\u003E4.analytics_queries.sql\u003C/a\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EExample SQL Queries:\u003C/strong\u003E\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003E1. CDC Change Volume:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT \n    'appointments' as table_name,\n    COUNT(*) as total_records,\n    SUM(CASE WHEN _SNOWFLAKE_UPDATED_AT IS NULL THEN 1 ELSE 0 END) as snapshot_only,\n    SUM(CASE WHEN _SNOWFLAKE_UPDATED_AT IS NOT NULL THEN 1 ELSE 0 END) as updated_via_cdc,\n    SUM(CASE WHEN _SNOWFLAKE_DELETED THEN 1 ELSE 0 END) as soft_deleted\nFROM &quot;appointments&quot;;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003E2. Recent CDC Events:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT \n    &quot;appointment_id&quot;,\n    &quot;patient_id&quot;,\n    &quot;status&quot;,\n    &quot;appointment_date&quot;,\n    _SNOWFLAKE_UPDATED_AT,\n    _SNOWFLAKE_DELETED\nFROM &quot;appointments&quot;\nWHERE _SNOWFLAKE_UPDATED_AT &gt;= DATEADD(hour, -24, CURRENT_TIMESTAMP)\nORDER BY _SNOWFLAKE_UPDATED_AT DESC;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003E\u003Cstrong\u003E3. Doctor Productivity with CDC Data:\u003C/strong\u003E\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003ESELECT \n    d.&quot;first_name&quot; || ' ' || d.&quot;last_name&quot; as doctor_name,\n    d.&quot;specialization&quot;,\n    COUNT(a.&quot;appointment_id&quot;) as total_appointments,\n    SUM(CASE WHEN a.&quot;status&quot; = 'completed' THEN 1 ELSE 0 END) as completed\nFROM &quot;doctors&quot; d\nLEFT JOIN &quot;appointments&quot; a ON d.&quot;doctor_id&quot; = a.&quot;doctor_id&quot;\nWHERE NOT a._SNOWFLAKE_DELETED OR a._SNOWFLAKE_DELETED IS NULL\nGROUP BY d.&quot;doctor_id&quot;, d.&quot;first_name&quot;, d.&quot;last_name&quot;, d.&quot;specialization&quot;\nORDER BY completed DESC;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EBest of Both Worlds:\u003C/strong\u003E Use Snowflake CoWork for ad-hoc exploration and business user queries, and SQL for repeatable reporting and dashboards!\u003C/p\u003E\n\u003C/blockquote\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003ECleanup\u003C/h2\u003E\n","\u003Cp\u003EWhen you're done with the quickstart, follow these steps to clean up all resources. This prevents unnecessary compute costs and removes test data from your environment.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003E⚠️ DESTRUCTIVE OPERATIONS\u003C/strong\u003E: Some cleanup steps below will permanently delete databases, schemas, tables, and all data created during this quickstart. Make sure you've captured any queries or insights you want to keep before proceeding!\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EStep 1: Stop the PostgreSQL Connector (Optional)\u003C/h3\u003E\n","\u003Cp\u003EIf you want to temporarily pause CDC replication without deleting any configuration:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to your Openflow runtime canvas\u003C/li\u003E\u003Cli\u003ERight-click on the \u003Cstrong\u003EPostgreSQL\u003C/strong\u003E processor group\u003C/li\u003E\u003Cli\u003ESelect \u003Cstrong\u003EStop\u003C/strong\u003E to halt CDC replication\u003C/li\u003E\u003Cli\u003EWait for the connector to fully stop (status indicator turns red)\u003C/li\u003E\u003C/ol\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ETIP:\u003C/strong\u003E Stopping the connector preserves your configuration while preventing further CDC processing and associated compute costs. You can restart it later by right-clicking and selecting \u003Cstrong\u003EStart\u003C/strong\u003E. Use this option if you want to keep your runtime and connector configuration intact.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EStep 2: Delete Openflow Runtime (Permanent)\u003C/h3\u003E\n","\u003Cp\u003EDeleting the Openflow runtime will automatically stop all services and connectors, and clean up the container infrastructure.\u003C/p\u003E\n","\u003Ch4\u003EFor Dedicated Runtime (Created for This Quickstart)\u003C/h4\u003E\n","\u003Cp\u003EIf you created a dedicated Openflow runtime for this quickstart:\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EVia Snowsight:\u003C/strong\u003E\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003EWork with data\u003C/strong\u003E &rarr; \u003Cstrong\u003EIngestion\u003C/strong\u003E &rarr; \u003Cstrong\u003EOpenflow\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EGo to \u003Cstrong\u003ERuntimes\u003C/strong\u003E tab\u003C/li\u003E\u003Cli\u003EFind your runtime (e.g., \u003Ccode\u003Equickstart_pgcdc_runtime\u003C/code\u003E)\u003C/li\u003E\u003Cli\u003EClick on the runtime and select \u003Cstrong\u003EDelete\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003EConfirm deletion\u003C/li\u003E\u003Cli\u003EWait for the runtime to be fully removed (this may take a few minutes)\u003C/li\u003E\u003C/ol\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EWhat Gets Deleted\u003C/strong\u003E: Deleting the runtime removes all connectors, services (NiFi, Registry), and the SPCS infrastructure. This automatically closes all database connections, including PostgreSQL replication slots.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EFor Shared Runtime (From Companion Quickstart)\u003C/h4\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003E⚠️ IMPORTANT\u003C/strong\u003E: If you're using the Openflow runtime from the companion quickstart &quot;\u003Ca href=\"https://quickstarts.snowflake.com/guide/getting-started-openflow-spcs\"\u003EGetting Started with Openflow on SPCS\u003C/a\u003E&quot;, DO NOT delete the runtime! It may be used by other connectors or projects.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Cp\u003EInstead, stop the PostgreSQL connector and its related services:\u003C/p\u003E\n\u003Col\u003E\u003Cli\u003ENavigate to \u003Cstrong\u003EWork with data\u003C/strong\u003E &rarr; \u003Cstrong\u003EIngestion\u003C/strong\u003E &rarr; \u003Cstrong\u003EOpenflow\u003C/strong\u003E\u003C/li\u003E\u003Cli\u003ESelect your runtime and open the canvas\u003C/li\u003E\u003Cli\u003ERight-click on the \u003Cstrong\u003EPostgreSQL\u003C/strong\u003E processor group\u003C/li\u003E\u003Cli\u003ESelect \u003Cstrong\u003EStop\u003C/strong\u003E to halt the connector\u003C/li\u003E\u003Cli\u003ERight-click on each related service (NiFi processors, controller services)\u003C/li\u003E\u003Cli\u003ESelect \u003Cstrong\u003EStop\u003C/strong\u003E or \u003Cstrong\u003EDisable\u003C/strong\u003E to stop all CDC-related services\u003C/li\u003E\u003Cli\u003EWait for all components to fully stop (status indicators turn red/gray)\u003C/li\u003E\u003C/ol\u003E\n","\u003Cp\u003E\u003Cimg src=\"https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/openflow_pgcdc_stop_all.gif?v=32b758de\" alt=\"Stop Openflow PostgreSQL Services\"\u003E\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EKeep the Runtime\u003C/strong\u003E: The shared runtime can be reused for future Openflow projects, including other CDC connectors, API integrations, or file ingestion pipelines. Stopping services preserves all configuration while eliminating compute costs.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EStep 3: Clean Up PostgreSQL\u003C/h3\u003E\n","\u003Cp\u003ERemove the CDC configuration and test database from PostgreSQL.\u003C/p\u003E\n","\u003Ch4\u003ETerminate Active Replication Slots\u003C/h4\u003E\n","\u003Cp\u003EConnect to your PostgreSQL database and run these queries:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- View replication slots\nSELECT slot_name, slot_type, active, restart_lsn \nFROM pg_replication_slots \nWHERE database = 'postgres';\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003ESince you stopped the connector in previous steps, the slot will show \u003Ccode\u003Eactive = false\u003C/code\u003E. Drop the inactive slot:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Drop inactive replication slot(s)\nSELECT pg_drop_replication_slot(slot_name) \nFROM pg_replication_slots \nWHERE database = 'postgres' \n  AND NOT active;\n\u003C/code\u003E\u003C/pre\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EReplication Slot Naming\u003C/strong\u003E: The replication slot name is automatically generated by Openflow following the pattern \u003Ccode\u003Esnowflake_connector_&lt;unique_id&gt;\u003C/code\u003E. The query above will show you the exact name.\u003C/p\u003E\n","\u003Cp\u003E\u003Cstrong\u003EIf Slot is Active\u003C/strong\u003E: If the slot still shows \u003Ccode\u003Eactive = true\u003C/code\u003E (connector not fully stopped), first terminate the backend connection:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Terminate the active backend connection\nSELECT pg_terminate_backend(active_pid)\nFROM pg_replication_slots\nWHERE slot_name = 'snowflake_connector_XXXXX' AND active = true;\n\n-- Then drop the slot\nSELECT pg_drop_replication_slot('snowflake_connector_XXXXX');\n\u003C/code\u003E\u003C/pre\u003E\n\u003C/blockquote\u003E\n","\u003Ch4\u003EDrop the Publication\u003C/h4\u003E\n","\u003Cp\u003ERemove the CDC publication:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Drop the publication for healthcare tables\nDROP PUBLICATION IF EXISTS healthcare_cdc_publication;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EDrop the Healthcare Schema (Optional)\u003C/h4\u003E\n","\u003Cp\u003EIf you want to completely remove the test data:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Drop the healthcare schema and all its objects\nDROP SCHEMA IF EXISTS healthcare CASCADE;\n\n-- Verify cleanup\nSELECT schema_name \nFROM information_schema.schemata \nWHERE schema_name = 'healthcare';\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output: Empty result set (0 rows), confirming the healthcare schema has been removed.\u003C/p\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003EKeep PostgreSQL?\u003C/strong\u003E If you're using a shared PostgreSQL instance, you may want to keep the schema and just drop the publication. If this was a dedicated test instance, you can safely drop everything.\u003C/p\u003E\n\u003C/blockquote\u003E\n","\u003Ch3\u003EStep 4: Drop Snowflake CoWork Agent\u003C/h3\u003E\n","\u003Cp\u003ERemove the AI agent and its associated database:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Use ACCOUNTADMIN role (required for agent operations)\nUSE ROLE ACCOUNTADMIN;\n\n-- Drop the Snowflake CoWork agent\nDROP AGENT IF EXISTS snowflake_intelligence.agents.HEALTHCARE_DATA_INTELLIGENCE;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch3\u003EStep 5: Drop Snowflake Objects\u003C/h3\u003E\n","\u003Cp\u003ERemove all Snowflake resources created for this quickstart:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Use ACCOUNTADMIN role for cleanup\nUSE ROLE ACCOUNTADMIN;\n\n-- Drop the main database (includes healthcare schema and all tables)\nDROP DATABASE IF EXISTS QUICKSTART_PGCDC_DB CASCADE;\n\n-- Drop the warehouse\nDROP WAREHOUSE IF EXISTS QUICKSTART_PGCDC_WH;\n\n-- Drop the external access integration\nDROP INTEGRATION IF EXISTS quickstart_pgcdc_access;\n\n-- Drop the role\nDROP ROLE IF EXISTS QUICKSTART_ROLE;\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch4\u003EVerify Cleanup\u003C/h4\u003E\n","\u003Cp\u003EConfirm all objects are removed:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-sql\"\u003E-- Check for remaining objects\nSHOW DATABASES LIKE 'QUICKSTART_PGCDC_DB';\nSHOW DATABASES LIKE 'snowflake_intelligence';\nSHOW WAREHOUSES LIKE 'QUICKSTART_PGCDC_WH';\nSHOW INTEGRATIONS LIKE 'quickstart_pgcdc_access';\nSHOW ROLES LIKE 'QUICKSTART_ROLE';\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Cp\u003EExpected output: Empty result sets for all queries.\u003C/p\u003E\n","\u003Ch3\u003EStep 6: Remove Local Files (Optional)\u003C/h3\u003E\n","\u003Cp\u003EIf you cloned the quickstart repository locally and no longer need it:\u003C/p\u003E\n\u003Cpre\u003E\u003Ccode class=\"language-bash\"\u003E# Navigate to parent directory\ncd ..\n\n# Remove the quickstart directory\nrm -rf openflow-postgresql-cdc-demo\n\n# Verify removal\nls -la | grep openflow-postgresql-cdc-demo\n\u003C/code\u003E\u003C/pre\u003E\n","\u003Ch3\u003ECleanup Complete\u003C/h3\u003E\n","\u003Cp\u003EAll resources have been removed. You can verify by:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E✅ Checking Snowflake compute usage (warehouse should not be running)\u003C/li\u003E\u003Cli\u003E✅ Confirming no active PostgreSQL replication slots\u003C/li\u003E\u003Cli\u003E✅ Verifying no Openflow services consuming compute credits\u003C/li\u003E\u003C/ul\u003E\n\u003Cblockquote\u003E\n","\u003Cp\u003E\u003Cstrong\u003ECost Savings\u003C/strong\u003E: By cleaning up unused resources, you avoid unnecessary compute costs. Warehouses, services, and replication slots all consume credits when active!\u003C/p\u003E\n\u003C/blockquote\u003E\n&lt;!-- ------------------------ --&gt;\n","\u003Ch2\u003EConclusion And Resources\u003C/h2\u003E\n","\u003Cp\u003ECongratulations! You've successfully built a real-time CDC pipeline from PostgreSQL to Snowflake using Openflow.\u003C/p\u003E\n","\u003Ch3\u003EWhat You Learned\u003C/h3\u003E\n\u003Cul\u003E\u003Cli\u003EHow to configure PostgreSQL logical replication for CDC\u003C/li\u003E\u003Cli\u003EHow to set up Snowflake CoWork with semantic models for natural language queries\u003C/li\u003E\u003Cli\u003EHow to configure Openflow PostgreSQL connector for CDC\u003C/li\u003E\u003Cli\u003EHow to capture both snapshot and incremental changes\u003C/li\u003E\u003Cli\u003EHow to analyze real-time data and CDC metadata with AI-powered insights\u003C/li\u003E\u003Cli\u003EHow to use natural language to explore CDC changes\u003C/li\u003E\u003C/ul\u003E\n","\u003Ch3\u003ERelated Resources\u003C/h3\u003E\n","\u003Cp\u003E\u003Cstrong\u003EOpenflow Documentation\u003C/strong\u003E:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/about\"\u003EOpenflow Overview\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/about\"\u003EPostgreSQL CDC Connector\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/mysql/about\"\u003EMySQL CDC Connector\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/sql-server/about\"\u003ESQL Server CDC Connector\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/manage\"\u003EManage Openflow\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/data-integration/openflow/monitor\"\u003EMonitor Openflow\u003C/a\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESnowflake CoWork\u003C/strong\u003E:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/snowflake-cortex/snowflake-intelligence\"\u003ESnowflake CoWork Overview\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/snowflake-cortex/semantic-model-spec\"\u003ESemantic Models\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/user-guide/snowflake-cortex/agents\"\u003EAgents\u003C/a\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003EPostgreSQL Resources\u003C/strong\u003E:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/product/features/postgres/\"\u003ESnowflake Postgres\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://www.snowflake.com/en/developers/guides/getting-started-with-snowflake-postgres/\"\u003EGetting Started with Snowflake Postgres\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://www.postgresql.org/docs/current/logical-replication.html\"\u003EPostgreSQL Logical Replication\u003C/a\u003E\u003C/li\u003E\u003C/ul\u003E\n","\u003Cp\u003E\u003Cstrong\u003ESnowflake Platform\u003C/strong\u003E:\u003C/p\u003E\n\u003Cul\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/developer-guide/snowpark-container-services/overview\"\u003ESnowpark Container Services\u003C/a\u003E\u003C/li\u003E\u003Cli\u003E\u003Ca href=\"https://docs.snowflake.com/en/sql-reference/sql/create-external-access-integration\"\u003EExternal Access Integration\u003C/a\u003E\u003C/li\u003E\u003C/ul\u003E\n\u003Chr\u003E\n","\u003Cp\u003E\u003Cstrong\u003EFeedback\u003C/strong\u003E: Please provide feedback on this quickstart via \u003Ca href=\"https://github.com/Snowflake-Labs/sfquickstarts/issues\"\u003EGitHub Issues\u003C/a\u003E\u003C/p\u003E"],"description":"Getting Started with Openflow PostgreSQL Change Data Capture (CDC)","title":"Getting Started with PostgreSQL CDC","isDeveloperGuidesPage":false,":type":"snowflake-site/components/contentfragment",":items":{},":itemsOrder":[],"elements":{"quickstartArticleBody":{"dataType":"string","title":"Quickstart Article Body","value":"\u003C!-- ------------------------ --\u003E\n## Overview\n\nThis quickstart demonstrates how to build a real-time Change Data Capture (CDC) pipeline from PostgreSQL to Snowflake using Openflow. You'll learn how to capture both initial snapshots and incremental changes, enabling real-time analytics on transactional data.\n\nWe use a healthcare appointment management system as our demo dataset, but the same patterns apply to any database-based application including e-commerce, CRM, ERP, and other transactional systems.\n\n### Healthcare Appointments Demo Dataset\n\nYou'll work with a realistic **Healthcare Appointment Management** system that includes:\n\n- **100 synthetic patients** with diverse demographics\n- **10 doctors** across 5 medical specializations\n- **170 appointments** (150 historical + 20 upcoming)\n- **120 visit records** with diagnoses and charges\n- **Real-time CDC events** demonstrating INSERT, UPDATE operations\n\n\u003E **IMPORTANT - Demo Data Disclaimer:** All patient data, doctor information, and healthcare records in this demo are **entirely fictitious** and created for demonstration purposes only. No real PHI (Protected Health Information) is used.\n\nBy completing this guide, you will build an end-to-end CDC pipeline that captures changes from PostgreSQL in real-time and enables analytics in Snowflake.\n\nHere is a summary of what you will learn in each step by following this quickstart:\n\n- **Setup Environment**: Configure Snowflake database objects, PostgreSQL instance, and network access\n- **Openflow Configuration**: Set up [Openflow](https://docs.snowflake.com/en/user-guide/data-integration/openflow/about) SPCS runtime\n- **Add PostgreSQL Connector**: Configure the [PostgreSQL CDC connector](https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/about)\n- **Initialize PostgreSQL Database**: Load healthcare schema and synthetic data\n- **Verify Snapshot Load**: Confirm initial data capture in Snowflake\n- **Generate Live CDC Events**: Simulate real-time appointment operations\n- **Real-time Analytics**: Query live data and analyze CDC metadata\n- **Monitor CDC Pipeline**: Track replication lag and data quality\n\n### What is Openflow\n\n[Snowflake Openflow](https://docs.snowflake.com/en/user-guide/data-integration/openflow/about) is an integration service that connects any data source and any destination with hundreds of processors supporting structured and unstructured text, images, audio, video and sensor data. Built on Apache NiFi, Openflow lets you run a fully managed service in your own cloud for complete control.\n\n**Key Features and Benefits**:\n\n- **Open and Extensible**: An extensible managed service powered by Apache NiFi, enabling you to build and extend processors from any data source to any destination\n- **Unified Data Integration Platform**: Handle complex, bi-directional data extraction and loading through a fully managed service\n- **Enterprise-Ready**: Out-of-the-box security, compliance, and observability hooks for data integration\n- **High Speed Ingestion**: Handle structured and unstructured data in both batch and streaming modes at virtually any scale\n- **Continuous Multimodal Data**: Near real-time unstructured data ingestion from sources like SharePoint, Google Drive, and more\n\n**Openflow Deployment Models**:\n\nOpenflow is available in two deployment options, both supporting the same connectors and features:\n\n- **Snowflake Deployment (SPCS)**: Streamlined and integrated solution using Snowpark Container Services. Native integration with Snowflake's security model for seamless authentication, authorization, and network security. *This quickstart uses SPCS deployment.*\n- **Bring Your Own Cloud (BYOC)**: Data processing engine runs within your own cloud environment (AWS, Azure, GCP) while Snowflake manages the overall service and control plane. Ideal for handling sensitive data preprocessing locally within your organization's cloud environment.\n\nLearn more at the [Openflow documentation](https://docs.snowflake.com/en/user-guide/data-integration/openflow/about) and [BYOC deployments](https://docs.snowflake.com/en/user-guide/data-integration/openflow/about-byoc).\n\n### What is Change Data Capture (CDC)\n\nChange Data Capture (CDC) is a design pattern that identifies and captures changes made to data in a database, then delivers those changes in real-time to a downstream system. Instead of periodically querying the entire database, CDC efficiently tracks only what changed.\n\n**How PostgreSQL CDC Works**:\n\nPostgreSQL CDC uses **logical replication**, which reads changes from the Write-Ahead Log (WAL). When data is modified in PostgreSQL:\n\n1. Changes are written to the WAL (a transaction log)\n2. A replication slot captures these changes\n3. A publication defines which tables to track\n4. Openflow reads from the replication slot and delivers changes to Snowflake\n\n**CDC Benefits**:\n\n- Changes flow to Snowflake within seconds\n- Complete history of all INSERT, UPDATE, DELETE operations  \n- Built-in audit trail with CDC metadata\n- Minimal overhead on source database\n- Only changes are transferred after initial snapshot\n\n**CDC vs Traditional Batch ETL**:\n\n| Aspect | CDC | Batch ETL |\n|--------|-----|-----------|\n| **Latency** | Seconds | Hours/Days |\n| **Data Freshness** | Real-time | Scheduled intervals |\n| **Network Impact** | Changes only | Full table scans |\n| **Database Load** | Minimal (log reading) | High (full queries) |\n| **History** | All changes tracked | Point-in-time snapshots |\n\nLearn more about [PostgreSQL CDC with Openflow](https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/about).\n\n### What You Will Learn\n\nYou'll configure PostgreSQL logical replication, set up the Openflow CDC connector, and capture both snapshot and incremental changes. Then you'll use Snowflake CoWork to query your CDC data with natural language.\n\n### What You Will Build\n\nA real-time healthcare appointment tracking system with an automated CDC pipeline from PostgreSQL to Snowflake, complete with audit trails for all data changes.\n\n### Prerequisites\n\nBefore starting, ensure you have:\n\n- **Snowflake Account**: Enterprise account with Openflow Snowflake Deployment enabled (AWS or Azure regions)\n- **Account Permissions**: ACCOUNTADMIN role or equivalent for initial setup\n- **PostgreSQL Instance**: PostgreSQL 11+ with logical replication enabled. **Recommended**: [Snowflake Postgres](https://www.snowflake.com/en/product/features/postgres/) - see [Getting Started with Snowflake Postgres](https://www.snowflake.com/en/developers/guides/getting-started-with-snowflake-postgres/) for setup. Alternatives: AWS RDS, Amazon Aurora, GCP Cloud SQL, Azure Database, or self-hosted\n- **Network Connectivity**: Ability to configure network access from Snowflake to PostgreSQL\n\n\u003E **Openflow Deployment**: This quickstart uses **Openflow Snowflake Deployment** (Snowflake-managed). If you're using [Openflow BYOC deployment](https://docs.snowflake.com/en/user-guide/data-integration/openflow/about-byoc), the connector setup and concepts are the same, but runtime deployment steps will differ.\n\n\u003C!-- ------------------------ --\u003E\n\n## Clone the QuickStart Repository\n\nFirst, clone the repository to get access to SQL scripts and setup files:\n\n```bash\ngit clone https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc.git\ncd sfguide-getting-started-openflow-postgresql-cdc\n```\n\n**Repository Contents:**\n\n- **`sql/0.init_healthcare.sql`** - PostgreSQL schema and synthetic data initialization\n- **`sql/1.snowflake_setup.sql`** - Snowflake environment setup (role, database, warehouse, network rules)\n- **`sql/2.verify_snapshot.sql`** - Snapshot load verification queries\n- **`sql/3.live_appointments.sql`** - Live CDC event generation script\n- **`sql/4.analytics_queries.sql`** - Real-time analytics query examples\n\n\u003C!-- ------------------------ --\u003E\n## Setup PostgreSQL Database\n\nIn this section, we'll configure PostgreSQL for CDC and load the healthcare demo data.\n\n### PostgreSQL Requirements\n\nThis guide assumes you have a PostgreSQL instance already created and available. Before proceeding, ensure your instance meets these requirements:\n\n\u003E **Required PostgreSQL Configuration**:\n\u003E\n\u003E - **PostgreSQL instance available**: You have a running PostgreSQL instance (Snowflake Postgres, AWS RDS, GCP Cloud SQL, Azure Database, or self-hosted) with network accessibility\n\u003E - **Logical replication enabled**: `wal_level = logical` (required for CDC) - see configuration instructions below\n\u003E - **User with REPLICATION privileges**: The PostgreSQL user must have replication permissions\n\u003E - **Network access**: Configure network access from Snowflake SPCS to your PostgreSQL instance\n\u003E - **Supported versions**: PostgreSQL 11-17\n\u003E\n\u003E This quickstart was tested with **Snowflake Postgres v17**.\n\n#### Enable Logical Replication (If Not Already Enabled)\n\nPostgreSQL CDC requires logical replication to be enabled. This allows the connector to capture changes from the Write-Ahead Log (WAL).\n\n**Grant REPLICATION privileges to your PostgreSQL user:**\n\n```sql\nALTER USER snowflake_admin WITH REPLICATION;\n```\n\n**Enable logical replication** via your PostgreSQL service:\n\n- **Snowflake Postgres**: Logical replication is enabled by default. No additional configuration required. See [Getting Started with Snowflake Postgres](https://www.snowflake.com/en/developers/guides/getting-started-with-snowflake-postgres/) for setup\n- **GCP Cloud SQL**: Set the `cloudsql.logical_decoding` and `cloudsql.enable_pglogical` flags to `on`\n- **AWS RDS** or **AWS Aurora**: Set `rds.logical_replication = 1` and apply it to your instance\n- **Azure Database**: Set `wal_level = logical` via the Azure portal or Azure CLI\n- **Self-hosted PostgreSQL**: Edit `postgresql.conf` to set `wal_level = logical` (or run `ALTER SYSTEM SET wal_level = logical;`), then restart PostgreSQL\n\n\u003E **Important**: For detailed configuration instructions specific to your PostgreSQL service, see [Snowflake's PostgreSQL CDC Setup Guide - Configure wal_level](https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/setup#configure-wal-level).\n\nAfter enabling logical replication and restarting your PostgreSQL instance if needed, you'll verify the `wal_level` setting in the next section after setting up your PostgreSQL client.\n\n### Setup Notes\n\nBefore configuring your PostgreSQL environment, note these setup considerations:\n\n- **Service Compatibility**: You can use any PostgreSQL service:\n  - Snowflake Postgres (recommended)\n  - AWS RDS\n  - Amazon Aurora\n  - GCP Cloud SQL\n  - Azure Database for PostgreSQL\n  - Self-hosted PostgreSQL\n  \n  The SQL scripts are compatible with all variants; configuration steps may vary slightly depending on your service.\n\n- **Client Tools**: You can use any PostgreSQL client you're comfortable with - `psql` command-line tool, pgAdmin, DBeaver, DataGrip, TablePlus, or others. This guide shows `psql` examples, but the SQL scripts work with any client.\n\n- **PostgreSQL User**: This guide uses the `snowflake_admin` user for both CLI connections and Openflow connector configuration. You can use any PostgreSQL user with appropriate privileges (superuser or replication role) - just ensure the user has permissions for logical replication and can create publications and replication slots.\n\n### Setup PostgreSQL Client Environment\n\nThis section shows how to install and configure the `psql` command-line tool, which is used throughout this guide.\n\n\u003E **Don't have psql installed?** The `psql` client is part of the PostgreSQL installation:\n\u003E\n\u003E - **macOS**: `brew install postgresql` (via Homebrew)\n\u003E - **Ubuntu/Debian**: `sudo apt-get install postgresql-client`\n\u003E - **RHEL/CentOS**: `sudo yum install postgresql`\n\u003E - **Windows**: Download from [PostgreSQL Downloads](https://www.postgresql.org/download/windows/)\n\u003E\n\u003E **Using a different client?** If you prefer pgAdmin, DBeaver, or another GUI client, you can adapt the `psql` commands throughout this guide by running the SQL portion in your client's query window.\n\n#### Set Environment Variables\n\nSet these environment variables to avoid repeating connection parameters:\n\n```bash\nexport PGHOST='YOUR-POSTGRES-HOST'        # e.g., your Snowflake Postgres endpoint\nexport PGPORT='5432'\nexport PGDATABASE='postgres'\nexport PGUSER='snowflake_admin'\n```\n\nThese variables will be referenced throughout the guide (e.g., `$PGHOST`, `$PGUSER`) for convenience.\n\n#### Configure Password File\n\nCreate a `.pgpass` file to avoid entering your password repeatedly. This file securely stores your PostgreSQL credentials.\n\n```bash\n# Create .pgpass file (Unix/Linux/macOS)\necho \"$PGHOST:$PGPORT:$PGDATABASE:$PGUSER:YOUR-PASSWORD\" \u003E\u003E ~/.pgpass\n\n# Set proper permissions (required for security)\nchmod 0600 ~/.pgpass\n```\n\n\u003E **Password File Format**: The `.pgpass` file format is `hostname:port:database:username:password`. You can use `*` as a wildcard for any field. Learn more about [PostgreSQL password files](https://www.postgresql.org/docs/current/libpq-pgpass.html).\n\n### Test PostgreSQL Connection\n\nBefore proceeding with any configuration, verify that your PostgreSQL instance is accessible and that logical replication is enabled.\n\n#### Check PostgreSQL Accessibility\n\nFirst, ensure your PostgreSQL instance allows external connections:\n\n**For Snowflake Postgres (Recommended):**\n\n- Your Snowflake Postgres instance is accessible via the endpoint provided during setup\n- Network connectivity between Snowflake SPCS and Snowflake Postgres is automatically configured\n- Note the **Connection Endpoint** - you'll need this for both client connection and Openflow connector configuration\n- See [Getting Started with Snowflake Postgres](https://www.snowflake.com/en/developers/guides/getting-started-with-snowflake-postgres/) for setup details\n\n**For GCP Cloud SQL:**\n\n- Navigate to Cloud SQL instance → **Connections** → **Networking**\n- Ensure **Public IP** is enabled (or VPC peering is configured for private)\n- Add authorized networks if needed (or configure for broad access during demo)\n- Note the **Public IP Address** - you'll need this for both client connection and Snowflake network rule\n\n**For AWS RDS:**\n\n- Navigate to RDS instance → **Connectivity & security**\n- Ensure **Publicly accessible** is \"Yes\" (or VPC peering is configured)\n- Check **Security group** allows inbound traffic on port 5432\n- Note the **Endpoint** - you'll need this for both client connection and Snowflake network rule\n\n**For Azure Database for PostgreSQL:**\n\n- Navigate to PostgreSQL server → **Connection security**\n- Ensure **Allow access to Azure services** is enabled\n- Add firewall rules for your IP address\n- Note the **Server name** - you'll need this for both client connection and Snowflake network rule\n\n**For self-hosted PostgreSQL:**\n\n- Ensure `pg_hba.conf` allows connections from your IP (or use `0.0.0.0/0` for demo)\n- Firewall allows inbound traffic on port 5432\n- PostgreSQL is listening on external interfaces (`listen_addresses = '*'` in `postgresql.conf`)\n\n#### Test Basic Connection\n\nTest the connection to your PostgreSQL instance using any method you prefer:\n\n**For Snowflake Postgres:** Use the `psql` connection URL provided during instance creation. The connection string format is typically provided in the Snowflake Postgres setup UI.\n\n**Option 1: Using psql:**\n\nIf you set up environment variables and `.pgpass` in the previous section, simply run:\n\n```bash\npsql -c \"SELECT version();\"\n```\n\nIf you didn't set up environment variables, specify connection parameters explicitly:\n\n```bash\npsql -h YOUR-POSTGRES-HOST -p 5432 -U snowflake_admin -d postgres -c \"SELECT version();\"\n```\n\n**Option 2: Using pgAdmin, DBeaver, or other GUI client:**\n\n- Create a new connection with your PostgreSQL host, port, username, and password\n- Test the connection\n- Run `SELECT version();` to verify\n\nExpected result (version number may vary):\n\n```text\n                                                 version                                                  \n----------------------------------------------------------------------------------------------------------\n PostgreSQL 17.2 on x86_64-pc-linux-gnu, compiled by gcc (Debian 12.2.0-14) 12.2.0, 64-bit\n(1 row)\n```\n\n\u003E **Connection Failed?** If you cannot connect to PostgreSQL, resolve this before proceeding. Common fixes:\n\u003E\n\u003E - **Check firewall**: Ensure port 5432 is open\n\u003E - **Check PostgreSQL config**: Verify `listen_addresses` in `postgresql.conf`\n\u003E - **Check pg_hba.conf**: Ensure host-based authentication allows your connection\n\u003E - **Check cloud provider**: Verify security groups, firewall rules, authorized networks\n\u003E - **Verify credentials**: Ensure username and password are correct\n\u003E\n\u003E All subsequent steps require a working PostgreSQL connection.\n\n#### Verify psql Configuration (Optional)\n\nIf you set up environment variables and `.pgpass`, test that they're working correctly:\n\n```bash\npsql -c \"SELECT current_database(), current_user;\"\n```\n\nExpected output:\n\n```text\n current_database | current_user \n------------------+--------------\n postgres         | snowflake_admin\n(1 row)\n```\n\nIf the connection succeeds without prompting for a password, your psql environment is configured correctly.\n\n#### Verify Logical Replication\n\nConfirm that logical replication is enabled (as required in the PostgreSQL Requirements section):\n\n\u003E **Snowflake Postgres Advantage:** If you're using Snowflake Postgres, logical replication (`wal_level = logical`) is **enabled by default**. You can skip this verification step, but feel free to confirm it works as expected.\n\n```bash\npsql -c \"SHOW wal_level;\"\n```\n\nExpected output:\n\n```text\n wal_level \n-----------\n logical\n(1 row)\n```\n\nIf the output shows `logical`, you're all set! If not, go back to the \"Enable Logical Replication\" section in PostgreSQL Requirements and ensure you've enabled `wal_level = logical` and restarted your PostgreSQL instance.\n\n### Initialize Healthcare Database\n\nNow we'll initialize the PostgreSQL database with the healthcare schema, synthetic data, and CDC configuration.\n\n#### Execute the Initialization Script\n\nThe `sql/0.init_healthcare.sql` script will:\n\n1. Grant replication privileges to the snowflake_admin user\n2. Create the `healthcare` schema\n3. Create tables: `patients`, `doctors`, `appointments`, `visits`\n4. Load 100 synthetic patients, 10 doctors, 170 appointments, and 100 visit records\n5. Create indexes for performance\n6. Configure CDC publication for logical replication\n\n#### Run the Script\n\n```bash\npsql -f sql/0.init_healthcare.sql\n```\n\n\u003E **Using a different PostgreSQL client?** If you're using pgAdmin, DBeaver, or another GUI client instead of `psql`, simply open `sql/0.init_healthcare.sql`, copy the entire contents, and execute it in your client's query window. The script contains standard PostgreSQL SQL and will work with any client.\n\u003E\n\u003E **Script Duration**: Approximately 10-15 seconds to complete.\n\n#### Verify PostgreSQL Setup\n\nBefore connecting Openflow, let's verify the entire PostgreSQL CDC configuration is correct.\n\n\u003E **Using a different PostgreSQL client?** All verification queries below use `psql` for consistency. If you're using a GUI client (pgAdmin, DBeaver, etc.), simply run the SQL portion of each command. For example, for `psql -c \"SELECT ...\"`, just run `SELECT ...` in your client.\n\n#### Check Tables Exist\n\n```bash\npsql -c \"\\dt healthcare.*\"\n```\n\nExpected output:\n\n```text\n              List of relations\n   Schema   |     Name     | Type  |      Owner      \n------------+--------------+-------+-----------------\n healthcare | appointments | table | snowflake_admin\n healthcare | doctors      | table | snowflake_admin\n healthcare | patients     | table | snowflake_admin\n healthcare | visits       | table | snowflake_admin\n(4 rows)\n```\n\n#### Check Row Counts\n\n```bash\npsql -c \"SELECT \n  (SELECT COUNT(*) FROM healthcare.patients) as patients,\n  (SELECT COUNT(*) FROM healthcare.doctors) as doctors,\n  (SELECT COUNT(*) FROM healthcare.appointments) as appointments,\n  (SELECT COUNT(*) FROM healthcare.visits) as visits;\"\n```\n\nExpected output:\n\n```text\n patients | doctors | appointments | visits \n----------+---------+--------------+--------\n      100 |      10 |          170 |    100\n(1 row)\n```\n\n\u003E **What's a Publication?** A PostgreSQL publication defines which tables are tracked for CDC. The Openflow connector subscribes to this publication to receive change events (INSERT, UPDATE, DELETE) in real-time.\n\n#### Verify CDC Publication\n\n```bash\npsql -c \"SELECT * FROM pg_publication WHERE pubname = 'healthcare_cdc_publication';\"\n```\n\nExpected output:\n\n```text\n          pubname           | pubowner | puballtables | pubinsert | pubupdate | pubdelete | pubtruncate \n----------------------------+----------+--------------+-----------+-----------+-----------+-------------\n healthcare_cdc_publication |    16390 | t            | t         | t         | t         | t\n(1 row)\n```\n\n#### Verify Published Tables\n\n```bash\npsql -c \"SELECT schemaname, tablename FROM pg_publication_tables WHERE pubname = 'healthcare_cdc_publication';\"\n```\n\nExpected output:\n\n```text\n schemaname |  tablename   \n------------+--------------\n healthcare | appointments\n healthcare | doctors\n healthcare | patients\n healthcare | visits\n(4 rows)\n```\n\n#### Check CDC Configuration\n\n```bash\npsql -c \"SELECT\n    current_setting('wal_level') AS wal_level,\n    current_setting('max_replication_slots') AS max_replication_slots,\n    current_setting('max_wal_senders') AS max_wal_senders,\n    (SELECT count(*) FROM pg_publication) AS publication_count,\n    (SELECT count(*) FROM pg_replication_slots) AS active_slots;\"\n```\n\nExpected output:\n\n```text\n wal_level | max_replication_slots | max_wal_senders | publication_count | active_slots \n-----------+-----------------------+-----------------+-------------------+--------------\n logical   | 10                    | 10              | 1                 | 0\n(1 row)\n```\n\n\u003E **What to check:**\n\u003E\n\u003E - `wal_level` should be `logical`\n\u003E - `max_replication_slots` should be at least 1 (typically 10 or more)\n\u003E - `max_wal_senders` should be at least 1 (typically 10 or more)\n\u003E - `publication_count` should be 1 (our healthcare_cdc_publication)\n\u003E - `active_slots` will be 0 now, and will increase to 1 once Openflow connects\n\n#### Verify Replication Privileges\n\n```bash\npsql -c \"SELECT rolname, rolsuper, rolreplication FROM pg_roles WHERE rolname = '$PGUSER';\"\n```\n\nExpected output:\n\n```text\n rolname         | rolsuper | rolreplication \n-----------------+----------+----------------\n snowflake_admin | f        | t\n(1 row)\n```\n\n\u003E **Snowflake Postgres Advantage:** If you're using Snowflake Postgres, the `snowflake_admin` user is **pre-configured with replication privileges** (`rolreplication = t`) and is not a superuser (`rolsuper = f`). This is the recommended secure configuration for CDC workloads.\n\u003E\n\u003E **Note:** For other managed services (AWS RDS, Azure), `rolsuper` is typically `f` (false). For self-hosted installations where you're using the superuser account, it may be `t` (true). The critical column to verify is `rolreplication` which must be `t` (true).\n\nThe `rolreplication` column should be `t` (true). If it's `f` (false), grant replication privileges:\n\n```bash\npsql -c \"ALTER USER $PGUSER WITH REPLICATION;\"\n```\n\n\u003E **Setup Complete!** Your PostgreSQL database is now fully configured for CDC with:\n\u003E\n\u003E - ✅ Logical replication enabled\n\u003E - ✅ Healthcare schema with 100 patients, 10 doctors, 170 appointments, 100 visits\n\u003E - ✅ CDC publication tracking all healthcare tables\n\u003E - ✅ Replication privileges granted\n\u003E\n\nNext, let us setup the Snowflake environment.\n\n\u003C!-- ------------------------ --\u003E\n## Setup Snowflake Environment\n\nIn this section, we'll set up the Snowflake objects needed for the CDC pipeline.\n\n### Create Snowflake Objects\n\nNow we'll set up all required Snowflake objects for the CDC pipeline. This includes creating a dedicated role, database, warehouse, and network access configuration.\n\n#### What We're Creating\n\n- **Role**: `QUICKSTART_ROLE` - Dedicated role for Openflow runtime\n- **Database**: `QUICKSTART_PGCDC_DB` - Database for healthcare CDC data\n- **Warehouse**: `QUICKSTART_PGCDC_WH` - Compute warehouse for data processing\n- **Network Rule**: PostgreSQL connection endpoint\n- **External Access Integration**: Allows SPCS to connect to PostgreSQL\n- **Snowflake CoWork Infrastructure**: `snowflake_intelligence` database and `agents` schema for AI-powered analytics\n\n#### Execute the Setup Script\n\nOpen \u003Ca href=\"https://app.snowflake.com/_deeplink/#/workspaces?utm_source=snowflake-devrel&utm_medium=developer-guides&utm_content=getting-started-with-openflow-postgresql-cdc&utm_cta=developer-guides-deeplink\" class=\"_deeplink\"\u003EWorkspaces\u003C/a\u003E in Snowsight (**Projects** → **Workspaces**), copy paste the `sql/1.snowflake_setup.sql` script and execute it.\n\n\u003E **IMPORTANT:** Before running the script, update line 64 with your PostgreSQL endpoint:\n\u003E\n\u003E ```sql\n\u003E VALUE_LIST = ('YOUR-POSTGRES-HOST:5432');\n\u003E ```\n\u003E\n\u003E Replace `YOUR-POSTGRES-HOST` with:\n\u003E\n\u003E - **Snowflake Postgres**: Your Snowflake Postgres connection endpoint\n\u003E - **GCP Cloud SQL**: Your instance's public IP (e.g., `34.123.45.67`)\n\u003E - **AWS RDS**: Your RDS endpoint hostname\n\u003E - **Azure Database**: Your Azure PostgreSQL server name\n\u003E - **Self-hosted**: Your server hostname or IP address\n\nThe script will:\n\n1. Create the `QUICKSTART_ROLE` role (or reuse if coming from SPCS quickstart)\n2. Create `QUICKSTART_PGCDC_DB` database with two schemas:\n   - `HEALTHCARE` - For CDC data tables\n   - `NETWORKS` - For network rule definitions\n3. Create `QUICKSTART_PGCDC_WH` warehouse (MEDIUM size, auto-suspend after 5 minutes)\n4. Create network rule for PostgreSQL connectivity\n5. Create external access integration `quickstart_pgcdc_access`\n6. Create Snowflake CoWork infrastructure (`snowflake_intelligence` database and `agents` schema)\n7. Grant appropriate permissions\n\n#### Verify Snowflake Setup\n\nAfter running the script, verify the setup in a new SQL worksheet in Snowsight.\n\nOpen a new SQL worksheet and run the following verification queries:\n\n#### Verify Schemas\n\n```sql\nUSE ROLE QUICKSTART_ROLE;\nUSE WAREHOUSE QUICKSTART_PGCDC_WH;\nSHOW SCHEMAS IN DATABASE QUICKSTART_PGCDC_DB;\n```\n\nExpected output (note: the `healthcare` schema will be automatically created by Openflow when the connector is added):\n\n```text\n| created_on          | name                  | is_default | is_current | database_name      | owner            | comment | options | retention_time | owner_role_type |\n|---------------------|-----------------------|------------|------------|--------------------|--------------------|---------|---------|----------------|-----------------|\n| 2025-10-07 10:00:00 | INFORMATION_SCHEMA    | N          | N          | QUICKSTART_PGCDC_DB | ACCOUNTADMIN      |         |         | 1              | ROLE            |\n| 2025-10-07 10:00:00 | NETWORKS              | N          | N          | QUICKSTART_PGCDC_DB | QUICKSTART_ROLE   |         |         | 1              | ROLE            |\n| 2025-10-07 10:00:00 | PUBLIC                | Y          | N          | QUICKSTART_PGCDC_DB | QUICKSTART_ROLE   |         |         | 1              | ROLE            |\n```\n\n#### Verify Integration\n\n```sql\nSHOW INTEGRATIONS LIKE 'quickstart_pgcdc_access';\n```\n\nExpected output:\n\n```text\n| name                      | type              | category          | enabled | comment                                    | created_on          |\n|---------------------------|-------------------|-------------------|---------|--------------------------------------------|--------------------|\n| quickstart_pgcdc_access   | EXTERNAL_ACCESS   | SECURITY          | true    | OpenFlow SPCS runtime access for PostgreSQL CDC | 2025-10-07 10:00:00 |\n```\n\n#### Verify Network Rule\n\nVerify that Snowflake's network rule is correctly configured to allow connections to your PostgreSQL instance.\n\n\u003E **⚠️ IMPORTANT - Snowflake Network Connectivity**\n\u003E\n\u003E For Openflow to connect to your PostgreSQL instance, two things must be true:\n\u003E\n\u003E 1. **PostgreSQL must allow inbound connections from Snowflake**: Configure your cloud provider's firewall/security groups to allow connections from Snowflake SPCS IP ranges (or use broad access for demo purposes)\n\u003E 2. **Snowflake network rule must match your PostgreSQL host/port**: The network rule created in `1.snowflake_setup.sql` must specify the exact host and port of your PostgreSQL instance\n\u003E\n\u003E This section verifies requirement #2. If you encounter connection errors when starting the Openflow connector later, you'll need to verify both requirements.\n\nCheck the network rule configuration:\n\n```sql\nDESC NETWORK RULE QUICKSTART_PGCDC_DB.NETWORKS.postgres_network_rule;\n```\n\nExpected output should show your actual PostgreSQL host:\n\n```text\n| name                     | type       | mode   | value_list                     | comment |\n|--------------------------|------------|--------|--------------------------------|---------|\n| postgres_network_rule    | HOST_PORT  | EGRESS | ['your-actual-host.com:5432']  |         |\n```\n\n\u003E **⚠️ Host Mismatch?** If the `value_list` doesn't match your PostgreSQL host, you **must** recreate the network rule and external access integration with the correct host:\n\u003E\n\u003E ```sql\n\u003E -- Drop existing objects\n\u003E USE ROLE ACCOUNTADMIN;\n\u003E DROP INTEGRATION IF EXISTS quickstart_pgcdc_access;\n\u003E USE ROLE QUICKSTART_ROLE;\n\u003E DROP NETWORK RULE IF EXISTS QUICKSTART_PGCDC_DB.NETWORKS.postgres_network_rule;\n\u003E \n\u003E -- Create network rule with CORRECT PostgreSQL host\n\u003E USE DATABASE QUICKSTART_PGCDC_DB;\n\u003E USE SCHEMA NETWORKS;\n\u003E CREATE OR REPLACE NETWORK RULE postgres_network_rule\n\u003E   MODE = EGRESS\n\u003E   TYPE = HOST_PORT\n\u003E   VALUE_LIST = ('YOUR-CORRECT-POSTGRES-HOST:5432');  -- ⚠️ Update this!\n\u003E \n\u003E -- Recreate external access integration\n\u003E USE ROLE ACCOUNTADMIN;\n\u003E CREATE OR REPLACE EXTERNAL ACCESS INTEGRATION quickstart_pgcdc_access\n\u003E   ALLOWED_NETWORK_RULES = (QUICKSTART_PGCDC_DB.NETWORKS.postgres_network_rule)\n\u003E   ENABLED = true\n\u003E   COMMENT = 'OpenFlow SPCS runtime access for PostgreSQL CDC';\n\u003E \n\u003E -- Grant to role\n\u003E GRANT USAGE ON INTEGRATION quickstart_pgcdc_access TO ROLE QUICKSTART_ROLE;\n\u003E \n\u003E -- Verify\n\u003E USE ROLE QUICKSTART_ROLE;\n\u003E SHOW INTEGRATIONS LIKE 'quickstart_pgcdc_access';\n\u003E ```\n\n**✅ Network Rule Verification Complete!**\n\nYou've verified that the Snowflake network rule matches your PostgreSQL host and port.\n\n\u003E **Note**: Full end-to-end connectivity (Snowflake → PostgreSQL) will be tested when the Openflow connector starts. If you encounter connection errors during connector startup, verify:\n\u003E\n\u003E 1. PostgreSQL firewall/security groups allow inbound connections from Snowflake SPCS\n\u003E 2. Network rule configuration is correct (verified above)\n\u003E 3. PostgreSQL credentials are correct\n\u003E 4. PostgreSQL is running and accessible\n\n\u003C!-- ------------------------ --\u003E\n## Openflow Configuration\n\nIn this section, you'll set up the Openflow Snowflake Deployments infrastructure needed to run the PostgreSQL connector. Before proceeding, ensure you've completed the Snowflake setup with `QUICKSTART_ROLE`, `QUICKSTART_PGCDC_DB` database, and `QUICKSTART_PGCDC_WH` warehouse.\n\n### Complete Openflow Snowflake Deployments Setup\n\nThis CDC quickstart builds on the foundational Openflow Snowflake Deployments setup. Navigate to the [Getting Started with Openflow Snowflake Deployments](/en/developers/guides/getting-started-with-openflow-spcs/) quickstart and complete the following two sections (approximately 15 minutes total):\n\n- **Setup Core Snowflake**: Create `OPENFLOW_ADMIN` role and enable BCR Bundle 2025_06.\n\n- **Create Deployment**: Set up your Openflow Snowflake Deployment (e.g., `QUICKSTART_DEPLOYMENT`).\n\nOnce your deployment is active, return here to create a runtime. If you already have an Openflow deployment, you can skip the deployment creation and just ensure you select the correct deployment name when creating the runtime.\n\nAfter completing these prerequisite sections, you'll have:\n\n- `OPENFLOW_ADMIN` role with deployment privileges\n- BCR Bundle 2025_06 enabled (required for CDC connectors)\n- Active Openflow deployment\n- Network rules for Snowflake infrastructure\n\n### Create Runtime for PostgreSQL CDC\n\nNow that you have an active Openflow deployment, create a runtime environment specifically configured for the PostgreSQL connector.\n\n**Resources from Setup Environment**: You already created the following in the \"Setup Environment\" section:\n\n- `QUICKSTART_ROLE` - Runtime role\n- `QUICKSTART_PGCDC_DB` - Database with `NETWORKS` schema  \n- `QUICKSTART_PGCDC_WH` - Warehouse\n- `postgres_network_rule` - Network rule\n- `quickstart_pgcdc_access` - External access integration\n\n#### Verify External Access Integration\n\nVerify the external access integration created in the \"Setup Environment\" section:\n\n```sql\nUSE ROLE QUICKSTART_ROLE;\n\n-- Verify integration exists and is enabled\nSHOW INTEGRATIONS LIKE 'quickstart_pgcdc_access';\nDESC INTEGRATION quickstart_pgcdc_access;\n```\n\nExpected output for `SHOW INTEGRATIONS`:\n\n```text\n| name                     | type              | category | enabled | comment                                              | created_on          |\n|--------------------------|-------------------|----------|---------|------------------------------------------------------|---------------------|\n| quickstart_pgcdc_access  | EXTERNAL_ACCESS   | SECURITY | true    | OpenFlow SPCS runtime access for PostgreSQL CDC      | 2025-10-07 10:00:00 |\n```\n\n\u003E **What's an External Access Integration?** This allows your Openflow runtime to communicate with external services (your PostgreSQL database) from within Snowpark Container Services. The `postgres_network_rule` you created earlier defines which PostgreSQL endpoints are accessible.\n\n#### Create Runtime via Snowsight\n\nFollow these steps to create your runtime:\n\n1. **Navigate to Openflow**: Go to **Work with data** → **Ingestion** → **Openflow**\n2. **Switch to Runtimes Tab**: Click the **Runtimes** tab\n3. **Ensure Correct Role**: Verify your role is set to `OPENFLOW_ADMIN` (check top-right corner of Snowsight)\n4. **Click Create Runtime**: Click the **+ Runtime** button\n5. **Configure Runtime**:\n   - **Name**: `QUICKSTART_PGCDC_RUNTIME`\n   - **Deployment**: Select `QUICKSTART_DEPLOYMENT` (or your deployment name)\n   - **Runtime Role**: Select `QUICKSTART_ROLE`\n   - **External Access Integration**: Select `quickstart_pgcdc_access`\n6. **Click Create**: Complete the runtime creation\n\n![Create Openflow Runtime](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/openflow_spcs_runtime_create.gif?v=32b758de)\n\n\u003E **Runtime Creation Time**: Runtime creation typically takes 3-5 minutes. The status will progress from `CREATING` → `ACTIVE`.\n\n#### Verify Runtime Status\n\nCheck that your runtime is active:\n\n1. **Navigate to Runtimes Tab**: Go to **Work with data** → **Ingestion** → **Openflow** → **Runtimes**\n2. **Check Status**: Look for `QUICKSTART_PGCDC_RUNTIME` with status **ACTIVE**\n\n![Openflow Runtime Active Status](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/openflow_spcs_runtime_active_example.png?v=32b758de)\n\nExpected status: **ACTIVE**\n\n\u003E **Troubleshooting**: If the runtime status shows `ERROR` or stays in `CREATING` for more than 10 minutes:\n\u003E\n\u003E - Verify the external access integration exists: `SHOW INTEGRATIONS LIKE 'quickstart_pgcdc_access';`\n\u003E - Check that `QUICKSTART_ROLE` has all required grants: `SHOW GRANTS TO ROLE QUICKSTART_ROLE;`\n\u003E - Review the [Openflow Snowflake Deployments](/en/developers/guides/getting-started-with-openflow-spcs/) troubleshooting guide\n\n#### Access the Runtime Canvas\n\nOnce your runtime is active, you can access the Openflow canvas to add and configure connectors:\n\n**Click on the runtime name** (`QUICKSTART_PGCDC_RUNTIME`) to open the canvas. This will open in a new browser tab where you'll configure connectors and build your data pipeline.\n\n\u003E **Authentication**: When opening the runtime canvas for the first time, you may be prompted to authenticate/authorize access. Accept these prompts to allow the canvas to access the runtime and required resources.\n\n![Openflow Runtime Empty Canvas](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/openflow_runtime_empty_canvas.png?v=32b758de)\n\n\u003E **REFERENCE DOCUMENTATION:**\n\u003E\n\u003E For detailed information, see [Create runtime](https://docs.snowflake.com/en/user-guide/data-integration/openflow/setup-openflow-spcs-create-runtime) in the official documentation.\n\n\u003C!-- ------------------------ --\u003E\n## Add PostgreSQL Connector\n\nNavigate to your Openflow runtime canvas. In Snowsight's Openflow UI, you can access the canvas by clicking on the runtime name from the Overview page.\n\n### Openflow Database CDC Connectors\n\nWhile this quickstart focuses on PostgreSQL, the concepts and workflow apply to all Openflow database CDC connectors. Openflow provides CDC connectors for major relational databases, enabling real-time replication of database tables into Snowflake for comprehensive, centralized reporting.\n\n#### Supported Databases\n\n- **[PostgreSQL](https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/about)**: Versions 11-17 (Snowflake Postgres, AWS RDS, Amazon Aurora, GCP Cloud SQL, Azure Database, Standard) - *Used in this quickstart*\n- **[MySQL](https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/mysql/about)**: Versions 8.0, 8.4 (Standard, AWS RDS, Amazon Aurora, GCP Cloud SQL)\n- **[SQL Server](https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/sql-server/about)**: SQL Server 2017+ (Standard, AWS RDS, Azure SQL Database)\n\n#### Why Use Openflow for CDC\n\nOpenflow provides a unified platform for CDC across all major databases with consistent workflows and metadata, whether you're using PostgreSQL, MySQL, SQL Server, or Oracle (coming soon).\n\n### Add PostgreSQL Connector to Runtime\n\nNavigate to **Work with data** → **Ingestion** → **Openflow** → **Overview**. Follow the animation below to add the PostgreSQL connector to your runtime:\n\n![Add PostgreSQL Connector](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/pgcdc_install_on_runtime.gif?v=32b758de)\n\n\u003E **New Tab & Authentication**: Adding the connector to your runtime will open a new runtime tab in your browser with the canvas showing the **PostgreSQL** processor group. If prompted, authenticate/authorize access to allow the canvas to access the runtime. You'll configure this connector in the next section.\n\nThe **PostgreSQL** connector is now on your canvas. It includes all the processors and services needed for snapshot load and incremental CDC from PostgreSQL to Snowflake.\n\n\u003C!-- ------------------------ --\u003E\n## Configure PostgreSQL Connector\n\nThe PostgreSQL connector uses three parameter contexts to organize its configuration:\n\n1. **PostgreSQL Source Parameters** - PostgreSQL connection details and CDC-specific settings like publication and replication slot\n2. **PostgreSQL Destination Parameters** - Snowflake table mapping and schema configuration\n3. **PostgreSQL Ingestion Parameters** - Schema and columns that need to be loaded into Snowflake\n\nTo access parameter contexts:\n\n![Access Parameter Contexts](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/access_parameter_contexts.gif?v=32b758de)\n\n\u003E **Production Tip:** For production deployments, use a SecretManagerParameterProvider (like `AwsSecretsManagerParameterProvider`) to store credentials in a secrets manager rather than directly in the connector configuration.\n\n### Configure PostgreSQL Source Parameters\n\nConfigure the PostgreSQL database connection details and CDC-specific settings.\n\n#### Download PostgreSQL JDBC Driver\n\nBefore configuring the parameters, download the PostgreSQL JDBC driver that will be used for the database connection.\n\nGet the PostgreSQL JDBC driver from [https://jdbc.postgresql.org/download/](https://jdbc.postgresql.org/download/)\n\n- This quickstart uses `postgresql-42.7.7.jar` (you can use any recent version)\n\nYou'll upload this JAR file as a reference asset so the connector can use it to connect to PostgreSQL.\n\n#### Access PostgreSQL Source Parameters\n\nFrom the Parameter contexts list, click the **three dots menu (⋮)** next to **PostgreSQL Source Parameters** and select **Edit**.\n\n![Edit PostgreSQL Source Parameters](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/edit_param_context_pg_source_params.png?v=32b758de)\n\nClick on the **Parameters** tab and configure the following values:\n\n| Parameter | Value | Description |\n|-----------|-------|-------------|\n| **PostgreSQL Connection URL** | `jdbc:postgresql://\u003CYOUR-POSTGRES-HOST\u003E:5432/postgres` | JDBC connection URL to your PostgreSQL instance. Replace `\u003CYOUR-POSTGRES-HOST\u003E` with your actual PostgreSQL host (e.g., your Snowflake Postgres endpoint) |\n| **PostgreSQL JDBC Driver** | `postgresql-42.7.7.jar` | Reference to the PostgreSQL JDBC driver JAR (see upload instructions below) |\n| **PostgreSQL Password** | `\u003CYOUR-PASSWORD\u003E` | Password for the PostgreSQL user (stored as sensitive value) |\n| **PostgreSQL Username** | `snowflake_admin` | PostgreSQL username (or the user you configured with REPLICATION privileges) |\n| **Publication Name** | `healthcare_cdc_publication` | Name of the PostgreSQL publication created in [0.init_healthcare.sql](https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/0.init_healthcare.sql#L348) |\n| **Replication Slot Name** | Leave empty for auto-generation | Optional. If specified, this exact name will be used for the replication slot. If left empty, Openflow automatically generates a unique name following the pattern `snowflake_connector_\u003Cunique_id\u003E`. |\n\n\u003E **Connection URL Format**: The PostgreSQL JDBC URL format is `jdbc:postgresql://HOST:PORT/DATABASE`.\n\u003E\n\u003E - For Snowflake Postgres: Use your Snowflake Postgres endpoint (e.g., `jdbc:postgresql://your-snowflake-postgres-endpoint:5432/postgres`)\n\u003E - For GCP Cloud SQL: Use the public IP address (e.g., `jdbc:postgresql://34.123.45.67:5432/postgres`)\n\u003E - For AWS RDS: Use the endpoint hostname (e.g., `jdbc:postgresql://mydb.abc123.us-east-1.rds.amazonaws.com:5432/postgres`)\n\u003E - For other services: Use your specific connection details\n\n#### Upload JDBC Driver as Reference Asset\n\nFollow the animation below to upload the downloaded JAR file and reference it in the **PostgreSQL JDBC Driver** parameter:\n\n![Upload JDBC Driver as Reference Asset](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/param_jdbc_driver_ref_asset.gif?v=32b758de)\n\nYour completed configuration should look like this:\n\n![Set PostgreSQL Source Parameters](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/set_pg_source_params.png?v=32b758de)\n\n\u003E **Note:** The screenshot shows `postgres` as the PostgreSQL Username. Based on your setup, use the appropriate username (e.g., Snowflake Postgres uses `snowflake_admin` by default).\n\nClick **Apply** to save your PostgreSQL source parameters configuration.\n\n### Configure PostgreSQL Destination Parameters\n\nConfigure the Snowflake destination connection where PostgreSQL data will be replicated.\n\n\u003E **IMPORTANT**: Ensure you have completed the [Create Snowflake Objects](#create-snowflake-objects) section before proceeding. The PostgreSQL connector requires the database, warehouse, and role to be created in advance.\n\n#### Access PostgreSQL Destination Parameters\n\nFrom the Parameter contexts list, click the **three dots menu (⋮)** next to **PostgreSQL Destination Parameters** and select **Edit**.\n\n![Edit PostgreSQL Destination Parameters](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/edit_param_context_pg_destination_params.png?v=32b758de)\n\nClick on the **Parameters** tab and configure the following values:\n\n| Parameter | Value | Description |\n|-----------|-------|-------------|\n| **Destination Database** | `QUICKSTART_PGCDC_DB` | Snowflake database where tables will be created (defined in [1.snowflake_setup.sql#L23](https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/1.snowflake_setup.sql#L23)) |\n| **Snowflake Account Identifier** | Leave empty | Not required when using session token authentication |\n| **Snowflake Authentication Strategy** | `SNOWFLAKE_SESSION_TOKEN` | Uses the runtime's session for authentication (recommended for SPCS deployments) |\n| **Snowflake Private Key** | Leave empty | Not required when using session token authentication |\n| **Snowflake Private Key File** | Leave empty | Not required when using session token authentication |\n| **Snowflake Private Key Password** | Leave empty | Not required when using session token authentication |\n| **Snowflake Role** | `QUICKSTART_ROLE` | Runtime role with permissions to create tables and write data (defined in [1.snowflake_setup.sql#L20](https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/1.snowflake_setup.sql#L20)) |\n| **Snowflake Username** | Leave empty | Not required when using session token authentication |\n| **Snowflake Warehouse** | `QUICKSTART_PGCDC_WH` | Warehouse for data processing (defined in [1.snowflake_setup.sql#L26](https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/1.snowflake_setup.sql#L26)) |\n\nYour completed configuration should look like this:\n\n![Set PostgreSQL Destination Parameters](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/set_pg_destination_params.png?v=32b758de)\n\n\u003E **Session Token Authentication**: When using `SNOWFLAKE_SESSION_TOKEN`, the connector authenticates using the Openflow runtime's Snowflake session. This is the recommended approach for SPCS deployments as it eliminates the need to manage separate credentials.\n\nClick **Apply** to save your PostgreSQL destination parameters configuration.\n\n### Configure PostgreSQL Ingestion Parameters\n\nConfigure CDC ingestion settings and table filters. This parameter context inherits values from both **PostgreSQL Source Parameters** and **PostgreSQL Destination Parameters**.\n\n#### Access PostgreSQL Ingestion Parameters\n\nFrom the Parameter contexts list, click the **three dots menu (⋮)** next to **PostgreSQL Ingestion Parameters (1)** and select **Edit**.\n\n![Edit PostgreSQL Ingestion Parameters](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/pg_ingestion_params_no_inheritence.png?v=32b758de)\n\nClick on the **Parameters** tab. By default, you'll see only the parameters specific to this context. To view all parameters (including inherited ones), check the **Show inherited parameters** checkbox at the bottom.\n\n![PostgreSQL Ingestion Parameters with Inheritance](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/pg_ingestion_params_with_inheritence.png?v=32b758de)\n\n\u003E **Note:** The screenshot shows `postgres` as the PostgreSQL Username. Based on your setup, use the appropriate username (e.g., Snowflake Postgres uses `snowflake_admin` by default).\n\nConfigure the following key parameters:\n\n| Parameter | Value | Description |\n|-----------|-------|-------------|\n| **Column Filter JSON** | `[]` | Empty array means all columns are included |\n| **Included Table Names** | Leave empty | Use regex instead for flexible filtering |\n| **Included Table Regex** | `healthcare\\..*` | Regular expression to match table names for CDC. The pattern `healthcare\\..*` matches all tables in the `healthcare` schema. The backslash escapes the dot to match a literal period in the schema-qualified table names (e.g., `healthcare.patients`, `healthcare.doctors`). |\n| **Ingestion Type** | `full` | Performs full snapshot followed by incremental CDC. Other option is \"incremental\" which only performs incremental CDC, existing data is not loaded. |\n| **Merge Task Schedule CRON** | `* * * * * ?` | Runs merge tasks every second for near real-time updates |\n\n**Inherited Parameters** (visible when \"Show inherited parameters\" is checked):\n\nFrom **PostgreSQL Source Parameters**:\n\n- PostgreSQL Connection URL\n- PostgreSQL JDBC Driver\n- PostgreSQL Username\n- PostgreSQL Password\n- Publication Name (`healthcare_cdc_publication` - created in [0.init_healthcare.sql#L348](https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/0.init_healthcare.sql#L348))\n- Replication Slot Name (auto-generated)\n\nFrom **PostgreSQL Destination Parameters**:\n\n- Destination Database\n- Snowflake Role\n- Snowflake Warehouse\n- Snowflake Authentication Strategy\n\nYour completed configuration with inherited parameters should look like this:\n\n![Set PostgreSQL Ingestion Parameters](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/set_pg_ingestion_parmeters_with_inheritance.png?v=32b758de)\n\n\u003E **Note:** The screenshot shows `postgres` as the PostgreSQL Username. Based on your setup, use the appropriate username (e.g., Snowflake Postgres uses `snowflake_admin` by default).\n\n\u003E **Configuration Notes**:\n\u003E\n\u003E - **Table Regex Pattern**: The regex `healthcare\\..*` matches all tables in the `healthcare` schema. The backslash escapes the dot to match a literal period (e.g., `healthcare.patients`, `healthcare.doctors`, `healthcare.appointments`, `healthcare.visits`).\n\u003E - **Merge Task Schedule**: The CRON expression `* * * * * ?` means \"every second\", providing near real-time CDC updates. For production workloads, adjust based on your latency requirements and cost considerations. Learn more about [Quartz CRON expressions](http://www.quartz-scheduler.org/documentation/quartz-2.3.0/tutorials/crontrigger.html).\n\nClick **Apply** to save your PostgreSQL ingestion parameters configuration.\n\nWith all three parameter contexts configured, you're now ready to start the CDC pipeline!\n\n\u003C!-- ------------------------ --\u003E\n## Verify Snapshot Load\n\nWith the connector configured, you're now ready to start the CDC pipeline and verify that the initial snapshot is loaded correctly.\n\n### Enable Services and Start Connector\n\nBefore starting the connector, you need to enable the controller services that manage the CDC replication process.\n\nFollow these steps to enable services and start the connector:\n\n1. **Open Controller Services**: Right-click on the canvas and select \"Configure\"\n2. **Enable Services**: Enable the two controller services (State Provider and Database Connection Pool)\n3. **Start Process Groups**: Right-click on the process groups and start them\n4. **Monitor Progress**: Watch the connector flow execute the snapshot load\n\n![Enable Services and Start Connector](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/enable_service_and_start.gif?v=32b758de)\n\n\u003E **Note**: You may see an error message about \"Snowflake Private Key Service\" failing to enable. This error can be safely ignored since this quickstart uses `SNOWFLAKE_SESSION_TOKEN` authentication instead of private key authentication. The connector will function normally with session token authentication.\n\n\u003E **What's Happening?** The connector performs two main operations:\n\u003E\n\u003E 1. **Snapshot Load**: Captures all existing data from PostgreSQL tables and loads it into Snowflake\n\u003E 2. **CDC Initialization**: Establishes the replication slot and begins listening for changes\n\u003E\n\u003E The snapshot typically takes 1-2 minutes for the demo dataset. For larger datasets, the duration will be proportional to the data volume.\n\nOnce the services are running, your connector status should show all components active:\n\n![PostgreSQL Connector Enabled and Started](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/pg_connector_enabled_and_started.png?v=32b758de)\n\n### Verify Data in Snowflake\n\nAfter the snapshot completes, verify that the data was loaded successfully in Snowflake.\n\n\u003E **IMPORTANT: Identifier Quoting Rule**\n\u003E\n\u003E PostgreSQL creates lowercase unquoted identifiers (e.g., `healthcare`, `appointments`, `patient_id`). When Openflow replicates these to Snowflake, they are preserved as **case-sensitive lowercase** names.\n\u003E\n\u003E **In Snowflake, you MUST quote these identifiers in lowercase**:\n\u003E\n\u003E - ✅ Correct: `USE SCHEMA \"healthcare\"; SELECT \"patient_id\", \"status\" FROM \"appointments\";`\n\u003E - ❌ Wrong: `USE SCHEMA healthcare; SELECT patient_id, status FROM appointments;`\n\u003E - ❌ Wrong: `SELECT PATIENT_ID, STATUS FROM APPOINTMENTS;`\n\u003E\n\u003E Why? Snowflake uppercases unquoted identifiers, so `appointments` becomes `APPOINTMENTS`, which won't match the actual table name `appointments` (lowercase). All queries in this quickstart follow this quoting convention.\n\n#### Check Record Counts\n\nRun the following query in Snowsight to verify all tables were created and populated:\n\n```sql\nUSE ROLE QUICKSTART_ROLE;\nUSE DATABASE QUICKSTART_PGCDC_DB;\nUSE SCHEMA \"healthcare\";\nUSE WAREHOUSE QUICKSTART_PGCDC_WH;\n\nSELECT 'patients' as table_name, COUNT(*) as record_count FROM \"patients\"\nUNION ALL\nSELECT 'doctors', COUNT(*) FROM \"doctors\"\nUNION ALL\nSELECT 'appointments', COUNT(*) FROM \"appointments\"\nUNION ALL\nSELECT 'visits', COUNT(*) FROM \"visits\"\nORDER BY table_name;\n```\n\nExpected output:\n\n```text\n+----------------+--------------+\n| TABLE_NAME     | RECORD_COUNT |\n+----------------+--------------+\n| APPOINTMENTS   |          170 |\n| DOCTORS        |           10 |\n| PATIENTS       |          100 |\n| VISITS         |          100 |\n+----------------+--------------+\n```\n\n\u003E Note: The initial snapshot loads 100 rows in `\"visits\"`. Additional visit records are generated during the Live CDC demo, so this count will increase after running the steps in \"Generate Live CDC Events\".\n\n#### Verify CDC Metadata\n\nCheck that CDC metadata columns are present and confirm the snapshot was loaded:\n\n```sql\nSELECT \n    COUNT(*) as total_rows,\n    MIN(_SNOWFLAKE_INSERTED_AT) as earliest_inserted,\n    MAX(_SNOWFLAKE_INSERTED_AT) as latest_inserted,\n    COUNT(DISTINCT _SNOWFLAKE_INSERTED_AT) as unique_insert_timestamps\nFROM \"appointments\";\n```\n\nExpected output (timestamps will vary):\n\n```text\n+------------+---------------------------+---------------------------+---------------------------+\n| TOTAL_ROWS | EARLIEST_INSERTED         | LATEST_INSERTED           | UNIQUE_INSERT_TIMESTAMPS  |\n+------------+---------------------------+---------------------------+---------------------------+\n|        170 | 2025-10-08 10:15:33.000   | 2025-10-08 10:15:45.000   |                        10 |\n+------------+---------------------------+---------------------------+---------------------------+\n```\n\nThis confirms that all 170 appointments were successfully loaded during the snapshot phase.\n\n\u003E **CDC Metadata Columns**: Openflow automatically adds the following metadata columns to track changes:\n\u003E\n\u003E - `_SNOWFLAKE_INSERTED_AT` (TIMESTAMP): When the row was first inserted into Snowflake during the snapshot or initial CDC event\n\u003E - `_SNOWFLAKE_UPDATED_AT` (TIMESTAMP): When the row was last updated by CDC processing (remains NULL for snapshot-only rows)\n\u003E - `_SNOWFLAKE_DELETED` (BOOLEAN): Logical delete flag (FALSE for active rows, TRUE when a DELETE event is captured)\n\u003E\n\u003E During the Live CDC demo, you'll see `_SNOWFLAKE_UPDATED_AT` populated when records are modified, and `_SNOWFLAKE_DELETED` set to TRUE for deleted records.\n\n#### Verify Appointment Status Distribution\n\nCheck the distribution of appointment statuses:\n\n```sql\nSELECT \n    \"status\",\n    COUNT(*) as count,\n    ROUND(COUNT(*) * 100.0 / SUM(COUNT(*)) OVER (), 2) as percentage\nFROM \"appointments\"\nGROUP BY \"status\"\nORDER BY count DESC;\n```\n\nExpected output (approximate - actual counts will vary):\n\n```text\n+-----------+-------+------------+\n| STATUS    | COUNT | PERCENTAGE |\n+-----------+-------+------------+\n| completed |   100 |      58.82 |\n| cancelled |    40 |      23.53 |\n| scheduled |    15 |       8.82 |\n| no_show   |    10 |       5.88 |\n| confirmed |     5 |       2.94 |\n+-----------+-------+------------+\n```\n\n\u003E **Note on Data Variability**: The exact counts and percentages will vary each time you run the initialization script because the appointment status is assigned using `RANDOM()` in PostgreSQL. Your actual output might show `completed: 102, cancelled: 44, no_show: 4` or other values, which is completely normal. The important thing is that you see a mix of different statuses with `completed` being the most common (~60%), followed by `cancelled` (~25%).\n\u003E\n\u003E **Save Baseline Results**: These snapshot results serve as your baseline for comparison. After running the CDC demo, you'll re-run this same query to see how the status distribution changed. Consider saving these results or taking a screenshot for easy side-by-side comparison later.\n\n#### Verify Doctor Workload\n\nCheck appointment distribution across doctors:\n\n```sql\nSELECT \n    d.\"first_name\" || ' ' || d.\"last_name\" as doctor_name,\n    d.\"specialization\",\n    d.\"department\",\n    COUNT(a.\"appointment_id\") as total_appointments,\n    SUM(CASE WHEN a.\"status\" = 'completed' THEN 1 ELSE 0 END) as completed_appointments,\n    SUM(CASE WHEN a.\"status\" IN ('scheduled', 'confirmed') THEN 1 ELSE 0 END) as upcoming_appointments\nFROM \"doctors\" d\nLEFT JOIN \"appointments\" a ON d.\"doctor_id\" = a.\"doctor_id\"\nGROUP BY d.\"doctor_id\", d.\"first_name\", d.\"last_name\", d.\"specialization\", d.\"department\"\nORDER BY total_appointments DESC\nLIMIT 5;\n```\n\nThis query shows the top 5 doctors by appointment volume, demonstrating that relational joins work correctly with the replicated data.\n\n### Run Additional Verification Queries\n\nFor comprehensive verification, run the complete verification script from the companion GitHub repository:\n\n📋 **Full Verification Script**: [2.verify_snapshot.sql](https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/2.verify_snapshot.sql)\n\nThe full script includes additional checks for:\n\n- Data quality validation (NULL checks)\n- Patient demographics analysis\n- Revenue summaries by doctor\n- Common diagnoses\n- Follow-up and prescription statistics\n\nYou can run this script directly in Snowsight by copying and pasting the SQL.\n\n\u003E **Snapshot Load Complete!** If all queries return expected results, your PostgreSQL tables are successfully replicated to Snowflake. The connector is now listening for changes and will automatically capture any INSERT, UPDATE, or DELETE operations in real-time.\n\n\u003C!-- ------------------------ --\u003E\n## Snowflake CoWork\n\nNow that the snapshot is loaded, let's set up Snowflake CoWork before generating CDC events. This allows you to establish a baseline understanding of your data, then observe changes in real-time after running the CDC demo.\n\n\u003E **Why Set Up Intelligence First?** By asking baseline questions about your snapshot data now, you'll be able to compare results after the CDC demo and see exactly how the data changed. This creates a powerful before/after experience for understanding CDC!\n\n### What You'll Build\n\nYou'll create an AI agent that can answer questions like:\n\n- \"Show me doctor workload for today\"\n- \"Which appointments were updated via CDC in the last hour?\"\n- \"What's the revenue by specialization this month?\"\n- \"How many records were soft-deleted today?\"\n\nThe agent understands your healthcare schema AND the CDC metadata columns for tracking changes!\n\n### Prerequisites\n\nBefore setting up Snowflake CoWork, ensure you have:\n\n- ✅ Completed snapshot load with Openflow pipeline running\n- ✅ Snowflake CoWork infrastructure created (this was done in `1.snowflake_setup.sql` which created the `snowflake_intelligence` database and `agents` schema)\n- ✅ Default role and warehouse set in your Snowflake user profile\n\n### Upload Semantic Model\n\nThe semantic model defines your healthcare schema for the AI agent. It includes table definitions, relationships, and CDC metadata columns.\n\n\u003E **NOTE:** The `semantic_models` stage and `snowflake_intelligence` database were already created when you ran `1.snowflake_setup.sql`. You just need to upload the semantic model file!\n\nUpload the semantic model to the stage using Snowsight:\n\n1. Navigate directly to **Ingestion** --\u003E **Add Data**: \u003Ca href=\"https://app.snowflake.com/_deeplink/#/data/add-data?utm_source=snowflake-devrel&utm_medium=developer-guides&utm_campaign=-us-en-all&utm_content=app-getting-started-with-openflow-postgresql-cdc&utm_cta=developer-guides-deeplink\" class=\"_deeplink\"\u003ELoad files into a Stage\u003C/a\u003E\n2. Select the database, schema, and stage:\n   - **Database:** `QUICKSTART_PGCDC_DB`\n   - **Schema:** `PUBLIC`\n   - **Stage:** `semantic_models`\n3. Click **+ Files** and select `healthcare_cdc_semantic_model.yaml` from the `semantic-models/` directory in your cloned repository\n4. Click **Upload**\n\n![Upload Semantic Model](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/upload_semantic_model.png?v=32b758de)\n\nOr use Snowflake CLI:\n\n```bash\nsnow stage put semantic-models/healthcare_cdc_semantic_model.yaml @semantic_models \\\n  --database QUICKSTART_PGCDC_DB \\\n  --schema PUBLIC \\\n  --role QUICKSTART_ROLE \\\n  --overwrite\n```\n\nVerify the upload via \u003Ca href=\"https://app.snowflake.com/_deeplink/#/data/databases/QUICKSTART_PGCDC_DB/schemas/PUBLIC/stage/SEMANTIC_MODELS?utm_source=snowflake-devrel&utm_medium=developer-guides&utm_campaign=-us-en-all&utm_content=app-getting-started-with-openflow-postgresql-cdc&utm_cta=developer-guides-deeplink\" class=\"_deeplink\"\u003EDatabase Explorer\u003C/a\u003E\n\n### Create the Agent\n\n\u003E **IMPORTANT:** Before creating the agent, ensure you are using the `QUICKSTART_ROLE` role in Snowsight. This ensures the agent is owned by the correct role and has proper access to resources. You can switch roles using the role selector in the top-right corner of Snowsight.\n\n#### Access Agent Creation Interface\n\n1. Sign in to Snowsight\n2. **Switch to `QUICKSTART_ROLE`** using the role selector in the top-right corner\n3. Navigate directly to Agents: \u003Ca href=\"https://app.snowflake.com/_deeplink/#/agents?utm_source=snowflake-devrel&utm_medium=developer-guides&utm_campaign=-us-en-all&utm_content=app-buidling-new-snowflake-intelligence-agents&utm_cta=developer-guides-deeplink\" class=\"_deeplink\"\u003ECreate Snowflake CoWork Agent\u003C/a\u003E\n4. Select **\"Create agent\"**\n\n![Agent Creation Interface](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_create.png?v=32b758de)\n\n**Platform Integration:**\n\n- ☑️ Select **\"Create this agent for Snowflake CoWork\"**\n\n**Agent Details:**\n\n- **Agent object name:** `HEALTHCARE_DATA_INTELLIGENCE`\n- **Display name:** `Healthcare Data Intelligence (Snapshot & CDC)`\n\n#### Configure Agent Basics\n\nAfter creating the agent, configure its details:\n\n1. **Click on the agent name** (`HEALTHCARE_DATA_INTELLIGENCE`) in the agent list to open it\n\n   ![Agents List](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agents_list.png?v=32b758de)\n\n2. **Click \"Edit\"** button to start editing the agent configuration\n\n   ![Agent Edit Button](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_edit.png?v=32b758de)\n\n\u003E **IMPORTANT:** As you configure each section below (About, Tools, Orchestration, Access), remember to click **\"SAVE\"** after completing all configurations to ensure your changes are preserved.\n\nNow configure the agent basics in the \"About\" section:\n\n![Agent About Configuration](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_about.png?v=32b758de)\n\n- **Description:** `Query and analyze healthcare appointment data with real-time CDC tracking using natural language. Powered by OpenFlow PostgreSQL CDC pipeline.`\n\n**Example Questions** (Add these to help users get started):\n\n```text\n\"Show me the appointment status distribution\"\n```\n\n```text\n\"Which doctors have the most appointments?\"\n```\n\n```text\n\"What appointments were updated via CDC today?\"\n```\n\n```text\n\"Show revenue by doctor specialization\"\n```\n\n```text\n\"How many records were soft-deleted in the last 24 hours?\"\n```\n\n### Configure Agent Tools\n\n#### Add Semantic Model\n\n![Agent Tools Configuration](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_tools_defaults.gif?v=32b758de)\n\n1. Navigate to **\"Tools\"** tab\n2. Find **\"Semantic Models\"** section\n3. Click **\"+ Add\"** button\n\n**Configure the Semantic Model:**\n\n- **Name:** `HEALTHCARE_DATA_ANALYTICS`\n- **Stage:** `@PUBLIC.semantic_models`\n- **File:** `healthcare_cdc_semantic_model.yaml`\n- **Description:** `Healthcare appointment management with real-time snapshot and CDC data tracking`\n\n\u003E **TIP:** The semantic model includes definitions for all four tables (patients, doctors, appointments, visits) plus their relationships and CDC metadata columns (_Snowflake_INSERTED_AT,_Snowflake_UPDATED_AT, _Snowflake_DELETED).\n\n### Configure Orchestration\n\n![Agent Orchestration Configuration](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_orchestration.png?v=32b758de)\n\n1. Navigate to **\"Orchestration\"** tab\n2. Set **Model:** `auto` (recommended - lets Snowflake choose the optimal model)\n\n**Orchestration Instructions:**\n\n```\nWhenever you can answer visually with a chart, always choose to generate a chart even if the user didn't specify to. \nRespond in the same language as the question wherever possible.\nWhen querying appointments or visits, consider filtering out soft-deleted records (_SNOWFLAKE_DELETED = FALSE) unless the user specifically asks about deleted data.\n```\n\n**Response Instructions:** (Optional)\n\n```\nAlways provide specific metrics and counts when answering quantitative questions.\nWhen showing CDC-related data, explain what the metadata columns mean (e.g., _SNOWFLAKE_UPDATED_AT indicates when the record was modified via CDC).\nFocus on actionable insights for healthcare operations.\n```\n\n\u003E **TIP:** Use `auto` (default) to let Snowflake automatically select the best available model for your region and query type. Supported models include Claude 4.0, Claude 3.7, Claude 3.5, and GPT 4.1.\n\n### Set Access Controls\n\n![Agent Access Configuration](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_agent_access.png?v=32b758de)\n\n1. Navigate to **\"Access\"** tab\n2. Click **\"Add role\"**\n3. Select appropriate roles for your organization\n\n**Example Role Configuration:**\n\n- **Role:** `QUICKSTART_ROLE`\n- **Permission:** `OWNERSHIP`\n\n\u003E **NOTE:** All queries use the user's credentials. Ensure users have appropriate access to the `QUICKSTART_PGCDC_DB.\"healthcare\"` schema and underlying tables.\n\n### Ask Baseline Questions (Snapshot Data)\n\nNow that your agent is configured, let's ask baseline questions about the snapshot data to establish the initial state.\n\n#### Getting Started with Queries\n\n1. Access Snowflake CoWork: [Open Snowflake CoWork](https://ai.snowflake.com/)\n2. Select your agent `Healthcare Data Intelligence (Snapshot & CDC)` from the dropdown\n\n   ![Choose Agent](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_chat_choose_agent.png?v=32b758de)\n\n3. Set the role and warehouse for the agent to use:\n   - **Role:** `QUICKSTART_ROLE`\n   - **Warehouse:** `QUICKSTART_PGCDC_WH`\n\n   ![Set Role and Warehouse](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_pgcdc_chat_choose_role.gif?v=32b758de)\n\n      \u003E **IMPORTANT:** The agent will use these credentials to query your data. Make sure the role has access to the `QUICKSTART_PGCDC_DB.\"healthcare\"` schema and all tables.\n\n4. Start with these baseline questions:\n\n**Baseline Questions:**\n\n```text\n\"How many total appointments do we have?\"\n```\n\n**Expected:** ~170 appointments from snapshot load\n\n```text\n\"Show me the appointment status distribution\"\n```\n\n**Expected:** Breakdown showing completed (100), cancelled (40), scheduled (15), no_show (10), confirmed (5)\n\n```text\n\"Which doctors have the most appointments?\"\n```\n\n**Expected:** List of 10 doctors with appointment counts\n\n```text\n\"What's the total revenue from all visits?\"\n```\n\n**Expected:** Sum of charges from 100 visits (~$15,000-$20,000)\n\n```text\n\"Show me appointments by specialization\"\n```\n\n**Expected:** Breakdown by General Practice, Cardiology, Pediatrics, Orthopedics, etc.\n\n```text\n\"Are there any records with CDC updates yet?\"\n```\n\n**Expected:** \"No, all records are from the initial snapshot load. The _Snowflake_UPDATED_AT column is NULL for all records.\"\n\n![Agent Queries](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/si_queries.gif?v=32b758de)\n\n\u003E **Baseline Established!** You now have a clear picture of your snapshot data. Keep these numbers in mind - after running the CDC demo in the next section, you'll ask follow-up questions to see exactly what changed!\n\n\u003C!-- ------------------------ --\u003E\n## Generate Live CDC Events\n\nNow that the snapshot is loaded, let's generate live CDC events to see real-time replication in action. We'll simulate a busy morning at DemoClinic Healthcare with various database operations.\n\n### What CDC Events Will Be Generated\n\nThe demo script simulates a busy morning at DemoClinic Healthcare (8:00 AM - 12:45 PM) and will generate the following CDC events:\n\n| **Event Type** | **Operation** | **Count** | **Description** |\n|----------------|---------------|-----------|-----------------|\n| **INSERT** | New Appointments | **10** | - 3 scheduled appointments (8:00 AM)\u003Cbr\u003E- 2 urgent walk-ins (10:00 AM)\u003Cbr\u003E- 5 future appointments (12:00 PM) |\n| **INSERT** | New Visit Records | **4** | - 2 completed visits (9:30 AM)\u003Cbr\u003E- 2 more completed visits (11:30 AM) |\n| **UPDATE** | Appointment Status Changes | **20+** | - Scheduled → Confirmed (morning batch)\u003Cbr\u003E- Confirmed → Checked In (4 + 2 patients)\u003Cbr\u003E- Checked In → In Progress (2 + 2 appointments)\u003Cbr\u003E- In Progress → Completed (2 + 2 visits)\u003Cbr\u003E- Confirmed → Cancelled (1 appointment)\u003Cbr\u003E- Confirmed → No Show (1 patient) |\n| **DELETE** | Removed Appointments | **2** | - Old cancelled appointments deleted (soft delete in Snowflake)\u003Cbr\u003E- Deletes the 2 appointments with lowest IDs from old cancelled records |\n| **UPDATE** | Doctor Records | **1** | - Doctor availability changed (accepting_new_patients = FALSE) |\n\n**Total Impact:**\n\n- **170 → 180** appointments (net +10, accounting for 2 deletes)\n- **100 → 104** visit records (net +4)\n- **20+** appointment status transitions captured\n- **2** soft-deleted records (visible with `_SNOWFLAKE_DELETED = TRUE`)\n- **1** doctor record update\n\n\u003E **Real CDC Patterns**: This script demonstrates all major CDC event types you'll encounter in production: customer records being created (INSERT), order statuses changing (UPDATE), and old data being archived (DELETE). The timing is designed to align with Openflow's 1-minute sync interval!\n\n### Run CDC Demo Script\n\nThe easiest way to generate CDC events is to run the provided SQL script on your PostgreSQL database.\n\n#### Option 1: Using psql Command Line\n\nIf you have the environment variables set from earlier, run:\n\n```bash\npsql -f sql/3.live_appointments.sql\n```\n\nOr with explicit connection:\n\n```bash\npsql -h YOUR_POSTGRES_HOST \\\n     -p 5432 \\\n     -U postgres \\\n     -d postgres \\\n     -f sql/3.live_appointments.sql\n```\n\n#### Option 2: Copy and Paste in pgAdmin or PostgreSQL Client\n\n1. Open the script: [3.live_appointments.sql](https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/3.live_appointments.sql)\n2. Copy the entire contents\n3. Paste into your PostgreSQL client (pgAdmin, DBeaver, etc.)\n4. Execute the script\n\nThe script will:\n\n- Run for approximately **5 minutes** (with strategic pauses)\n- Display progress messages with timestamps (8:00 AM → 12:45 PM simulation)\n- Wait 60 seconds after major operations to align with CDC sync intervals\n- Show a summary of changes at the end\n\n\u003E **Perfect Timing for CDC**: The script includes 60-second pauses after key operations to align with Openflow's 1-minute CDC sync interval. This lets you:\n\u003E\n\u003E - Switch to Snowflake between operations to observe changes appearing\n\u003E - See multiple CDC sync cycles in action\n\u003E - Understand the near real-time nature of CDC (not instant, but very fast!)\n\u003E\n\u003E The script displays \"⏳ Waiting 60 seconds for CDC sync...\" messages to indicate when it's a good time to check Snowflake.\n\n#### Expected Output\n\nYou should see output like this:\n\n```text\n🕐 8:00 AM - New appointment requests coming in...\n✅ 3 new appointments scheduled\n\n🕐 8:15 AM - Front desk confirming today's appointments...\n✅ Today's appointments confirmed\n\n🕐 8:30 AM - Patients checking in for their appointments...\n✅ 4 patients checked in\n\n...\n\n═══════════════════════════════════════════════════════════\n📊 CDC Demo Summary - Changes Generated\n═══════════════════════════════════════════════════════════\n\n activity                            | count \n-------------------------------------+-------\n New appointments created            |    10\n Appointments updated (status changes)|    20\n New visit records created           |     4\n Doctor records updated              |     1\n\n✅ All CDC events have been generated!\n```\n\n### Verify Changes in Snowflake\n\nWhile the script is running (or immediately after), switch to Snowflake to see the changes appear in real-time.\n\n\u003E **Tip - Refresh Openflow Canvas**: You can also monitor CDC activity in the Openflow UI. Right-click on the canvas and select **Refresh** to see updated statistics (records processed, events captured, etc.) on the connector flows in real-time.\n\n#### Check Updated Row Counts\n\nRun this query to see the increased record counts:\n\n```sql\nUSE ROLE QUICKSTART_ROLE;\nUSE DATABASE QUICKSTART_PGCDC_DB;\nUSE SCHEMA \"healthcare\";\nUSE WAREHOUSE QUICKSTART_PGCDC_WH;\n\nSELECT 'patients' as table_name, COUNT(*) as record_count FROM \"patients\"\nUNION ALL\nSELECT 'doctors', COUNT(*) FROM \"doctors\"\nUNION ALL\nSELECT 'appointments', COUNT(*) FROM \"appointments\"\nUNION ALL\nSELECT 'visits', COUNT(*) FROM \"visits\"\nORDER BY table_name;\n```\n\nExpected output (compare to snapshot baseline of 170 appointments, 100 visits):\n\n```text\n+----------------+--------------+\n| TABLE_NAME     | RECORD_COUNT |\n+----------------+--------------+\n| appointments   |          180 | -- +10 new appointments (net: 12 inserts - 2 deletes)\n| doctors        |           10 | -- unchanged\n| patients       |          100 | -- unchanged\n| visits         |          104 | -- +4 new visit records\n+----------------+--------------+\n```\n\n#### Verify CDC Metadata Shows Updates\n\nCheck the CDC metadata timestamps to see snapshot vs updated records:\n\n```sql\nSELECT \n    COUNT(*) as total_records,\n    SUM(CASE WHEN _SNOWFLAKE_DELETED THEN 1 ELSE 0 END) as deleted_records,\n    COUNT(DISTINCT _SNOWFLAKE_INSERTED_AT) as distinct_insert_times,\n    COUNT(DISTINCT _SNOWFLAKE_UPDATED_AT) as distinct_update_times\nFROM \"appointments\";\n```\n\nExpected output:\n\n```text\n+----------------+-----------------+-----------------------+-----------------------+\n| TOTAL_RECORDS  | DELETED_RECORDS | DISTINCT_INSERT_TIMES | DISTINCT_UPDATE_TIMES |\n+----------------+-----------------+-----------------------+-----------------------+\n|           180  |               2 |                    2+ |                    2+ |\n+----------------+-----------------+-----------------------+-----------------------+\n```\n\nThis shows:\n\n- **180** total appointments (170 original + 10 new from CDC)\n- **2** deleted appointments (soft deleted with `_SNOWFLAKE_DELETED = TRUE`)\n- **2+** distinct insert times (snapshot load + CDC inserts)\n- **2+** distinct update times (various CDC updates)\n\nTo see the distribution of when records were inserted:\n\n```sql\nSELECT \n    DATE_TRUNC('minute', _SNOWFLAKE_INSERTED_AT) as insert_minute,\n    COUNT(*) as records_inserted\nFROM \"appointments\"\nGROUP BY insert_minute\nORDER BY insert_minute;\n```\n\nThis will show you the snapshot load followed by CDC inserts happening later.\n\n#### Query the Journal Tables\n\nSnowflake Openflow creates journal tables that track all CDC events. These tables are created dynamically as CDC events occur for each table, following the naming pattern: `\u003Csource_table_name\u003E_JOURNAL_\u003Ctimestamp\u003E_\u003Cschema_generation\u003E` where:\n\n- `\u003Ctimestamp\u003E` = Epoch seconds when the source table was added to replication\n- `\u003Cschema_generation\u003E` = Integer starting at 1, increasing with each schema change on the source table\n\nBased on the CDC events generated by the live appointments script, you'll see these journal tables appear in order:\n\n1. **First**: `appointments_JOURNAL_1759908563_1` - Created when appointment status changes occur\n2. **Second**: `visits_JOURNAL_1759908563_1` - Created when new visit records are added  \n3. **Third**: `doctors_JOURNAL_1759908563_1` - Created when doctor availability is updated\n\n\u003E **Journal Table Naming**: The timestamp portion (e.g., `1759908563`) will be different in your environment based on when tables are added to replication. The schema generation number starts at `1` and increments if the source table schema changes. For more details, see [Track data changes in tables](https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/setup#track-data-changes-in-tables) in the Snowflake documentation.\n\n\u003E **Find Your Journal Tables**: You can see which journal tables have been created by running:\n\u003E\n\u003E ```sql\n\u003E SHOW TABLES LIKE '%_JOURNAL_%' IN SCHEMA \"healthcare\";\n\u003E ```\n\u003E\n\u003E This will list all journal tables that Openflow has created as CDC events occurred. The tables appear in order as different table types experience their first CDC event.\n\nQuery recent CDC events for appointments:\n\n```sql\n-- View recent CDC events for appointments\n-- Replace the timestamp with your actual journal table name\nSELECT \n    SEEN_AT as event_time,\n    EVENT_TYPE,\n    \"PRIMARY_KEY__appointment_id\" as appointment_id,\n    \"PAYLOAD__patient_id\" as patient_id,\n    \"PAYLOAD__doctor_id\" as doctor_id,\n    \"PAYLOAD__status\" as status,\n    \"PAYLOAD__reason_for_visit\" as reason_for_visit,\n    \"PAYLOAD__appointment_date\" as appointment_date\nFROM QUICKSTART_PGCDC_DB.\"healthcare\".\"appointments_JOURNAL_1759908563_1\"\nWHERE SEEN_AT \u003E= DATEADD(minute, -10, CURRENT_TIMESTAMP)\nORDER BY SEEN_AT DESC\nLIMIT 20;\n```\n\n\u003E **Journal Table Structure**: Journal tables track all CDC events with:\n\u003E\n\u003E - `EVENT_TYPE`: The operation type - `IncrementalInsertRows`, `IncrementalUpdateRows`, or `IncrementalDeleteRows`\n\u003E - `SEEN_AT`: Timestamp when the CDC event was captured\n\u003E - `PRIMARY_KEY__\u003Ccolumn\u003E`: Primary key column(s) from the source table (quoted, lowercase)\n\u003E - `PAYLOAD__\u003Ccolumn\u003E`: All data columns from the source table (quoted, lowercase)\n\u003E - `SF_METADATA`: Additional Snowflake CDC metadata\n\nTo find your actual journal table names:\n\n```sql\nSHOW TABLES LIKE '%_JOURNAL_%' IN SCHEMA QUICKSTART_PGCDC_DB.\"healthcare\";\n```\n\nThis shows the complete audit trail of all changes captured by CDC!\n\n#### View Deleted Records\n\nQuery appointments that were deleted (soft delete):\n\n```sql\nSELECT \n    \"appointment_id\",\n    \"patient_id\",\n    \"status\",\n    \"appointment_date\",\n    \"reason_for_visit\",\n    _SNOWFLAKE_INSERTED_AT,\n    _SNOWFLAKE_UPDATED_AT,\n    _SNOWFLAKE_DELETED\nFROM \"appointments\"\nWHERE _SNOWFLAKE_DELETED = TRUE;\n```\n\nExpected output (the exact `appointment_id` and `patient_id` values will be consistent across runs due to deterministic `ORDER BY appointment_id`):\n\n```text\n+-----------------+------------+------------+------------------+-----------------------------+---------------------------+---------------------------+----------------------+\n| APPOINTMENT_ID  | PATIENT_ID | STATUS     | APPOINTMENT_DATE | REASON_FOR_VISIT            | _SNOWFLAKE_INSERTED_AT    | _SNOWFLAKE_UPDATED_AT     | _SNOWFLAKE_DELETED   |\n+-----------------+------------+------------+------------------+-----------------------------+---------------------------+---------------------------+----------------------+\n|             123 |         45 | cancelled  | 2024-08-15       | Annual physical examination | 2025-10-08 10:15:33.000   | 2025-10-08 15:30:22.000   | TRUE                 |\n|             156 |         78 | cancelled  | 2024-09-01       | Routine checkup             | 2025-10-08 10:15:40.000   | 2025-10-08 15:30:22.000   | TRUE                 |\n+-----------------+------------+------------+------------------+-----------------------------+---------------------------+---------------------------+----------------------+\n```\n\n\u003E **Note on Deleted Record IDs**: The specific appointment IDs deleted will be consistent across multiple runs of the demo because the DELETE query uses `ORDER BY appointment_id` to select the 2 oldest cancelled appointments deterministically. The actual IDs depend on which appointments were randomly assigned `cancelled` status during your PostgreSQL initialization.\n\n\u003E **Soft Deletes**: Notice that deleted records are still queryable in Snowflake! The `_SNOWFLAKE_DELETED` flag marks them as deleted, but the data is preserved. This is crucial for:\n\u003E\n\u003E - Audit trails and compliance\n\u003E - Historical analysis\n\u003E - Data recovery if needed\n\u003E\n\u003E You can filter deleted records out of queries with `WHERE _SNOWFLAKE_DELETED = FALSE` or `WHERE NOT _SNOWFLAKE_DELETED`.\n\n#### Compare Before and After Status Distribution\n\nRe-run the status distribution query to see the changes:\n\n```sql\nSELECT \n    \"status\",\n    COUNT(*) as count,\n    ROUND(COUNT(*) * 100.0 / SUM(COUNT(*)) OVER (), 2) as percentage\nFROM \"appointments\"\nWHERE NOT _SNOWFLAKE_DELETED  -- Exclude deleted records\nGROUP BY \"status\"\nORDER BY count DESC;\n```\n\n**Key Changes from Baseline:**\n\nThe CDC script will create these changes:\n\n- **completed**: Increases by +4 (new completed visits)\n- **scheduled**: Increases by +5 (new future appointments)  \n- **no_show**: Increases by +1 (missed appointment)\n- **confirmed**: Decreases as some move to other statuses\n- **in_progress**: New status with +2 (active visits)\n- **Total active records**: 170 → 180 (+10 net, accounting for 2 soft deletes)\n\nThe exact counts and percentages will vary based on your baseline snapshot data (which uses `RANDOM()` for initial status assignment), but you should see the relative changes described above.\n\n\u003E **Real-time CDC in Action!** The changes you made in PostgreSQL appeared in Snowflake within seconds. This demonstrates the power of CDC for real-time data integration and analytics.\n\n---\n\n### Return to Snowflake CoWork (Ask CDC Questions)\n\nNow that CDC events have been processed, return to your Snowflake CoWork agent and ask CDC-specific questions to see the changes!\n\n1. Access Snowflake CoWork: [Open Snowflake CoWork](https://ai.snowflake.com/)\n2. Select your agent `HEALTHCARE_DATA_INTELLIGENCE` from the dropdown\n3. **Refresh the agent cache** by clicking the refresh button or typing a new question (this ensures the agent fetches the latest CDC data)\n4. Ask these CDC-focused questions:\n\n#### CDC Monitoring Questions\n\n**Track Recent Changes:**\n\n```text\n\"How many appointments were updated via CDC in the last hour?\"\n```\n\nCount of records with `_SNOWFLAKE_UPDATED_AT` in the last hour (typically 10-30 records depending on timing)\n\n```text\n\"Show me all appointments that were modified today via CDC\"\n```\n\nTable with appointment details and `_SNOWFLAKE_UPDATED_AT` timestamps\n\n```text\n\"Which appointments were soft-deleted?\"\n```\n\n2 cancelled appointments that were removed (where `_SNOWFLAKE_DELETED = TRUE`)\n\n\u003E **Note on Counts**: The exact numbers you see may vary based on when you run the CDC script, how long it runs, and the timing of CDC sync intervals. For example, you might see \"12 appointments were updated\" or \"30 appointments were updated\" - both are correct depending on which CDC events have been synced at query time. The key is to verify that CDC events are being captured, not to match exact counts.\n\n#### Compare Before and After\n\n**Compare to Your Baseline:**\n\n```text\n\"What's the new appointment status distribution?\"\n```\n\n**Expected:** Updated counts showing more completed appointments than the baseline\n\n```text\n\"How many new visit records were created today?\"\n```\n\n**Expected:** Visit count increase from baseline of 100 to 110 visits\n\n```text\n\"Show me appointments that changed from scheduled to completed\"\n```\n\n**Expected:** Appointments with status transitions during the CDC demo\n\n#### Operational Analytics\n\n**Real-time Operations:**\n\n```text\n\"Which doctors completed the most visits today?\"\n```\n\n**Expected:** Doctor rankings with today's completed visit counts\n\n```text\n\"What's today's total revenue from visits?\"\n```\n\n**Expected:** Sum of charges from visits created today (~$2,000-$3,000 from new visits)\n\n```text\n\"Show me all urgent appointments added today\"\n```\n\n**Expected:** Walk-in appointments with urgent status added during CDC demo\n\n#### CDC Audit Trail\n\n**Track Changes:**\n\n```text\n\"Show me appointments with status changes in the last 2 hours?\"\n```\n\n**Expected:** Appointments with `_SNOWFLAKE_UPDATED_AT` in last 2 hours\n\n```text\n\"How many total records have been modified via CDC?\"\n```\n\n**Expected:** Count where `_SNOWFLAKE_UPDATED_AT IS NOT NULL` (~30 records)\n\n```text\n\"What percentage of appointments were updated via incremental vs snapshot only?\"\n```\n\n**Expected:** Ratio showing ~85% snapshot, ~15% CDC-modified\n\n#### Advanced CDC Questions\n\n**Change Patterns:**\n\n```text\n\"Show me the timeline of appointment status changes today\"\n```\n\n**Expected:** Time-series of status transitions with timestamps\n\n```text\n\"Which patient had the most appointment updates?\"\n```\n\n**Expected:** Patient with multiple appointment modifications during the demo\n\n```text\n\"Compare snapshot-only vs CDC-updated appointment counts\"\n```\n\n**Expected:** Breakdown showing 170 snapshot, 30 CDC-modified\n\n#### Business Insights\n\n**Operational Metrics:**\n\n```text\n\"What's the cancellation rate for today's appointments?\"\n```\n\n**Expected:** Percentage of cancelled appointments\n\n```text\n\"Show revenue by doctor for visits completed in the last hour\"\n```\n\n**Expected:** Recent revenue attribution from new visits\n\n```text\n\"How many appointments need follow-up visits?\"\n```\n\n**Expected:** Count from visits where `follow_up_required = TRUE`\n\n\u003E **Pro Tip:** Snowflake CoWork understands the CDC metadata columns and can differentiate between snapshot data and real-time changes. Try asking comparative questions like \"Show me only the appointments that changed today\" to see CDC-specific insights!\n\n### Alternative: SQL Queries\n\nIf you prefer SQL over natural language, you can also use the comprehensive analytics script with 20+ pre-built queries:\n\n📋 **Analytics Script**: [4.analytics_queries.sql](https://github.com/Snowflake-Labs/sfguide-getting-started-openflow-postgresql-cdc/blob/main/sql/4.analytics_queries.sql)\n\n**Example SQL Queries:**\n\n**1. CDC Change Volume:**\n\n```sql\nSELECT \n    'appointments' as table_name,\n    COUNT(*) as total_records,\n    SUM(CASE WHEN _SNOWFLAKE_UPDATED_AT IS NULL THEN 1 ELSE 0 END) as snapshot_only,\n    SUM(CASE WHEN _SNOWFLAKE_UPDATED_AT IS NOT NULL THEN 1 ELSE 0 END) as updated_via_cdc,\n    SUM(CASE WHEN _SNOWFLAKE_DELETED THEN 1 ELSE 0 END) as soft_deleted\nFROM \"appointments\";\n```\n\n**2. Recent CDC Events:**\n\n```sql\nSELECT \n    \"appointment_id\",\n    \"patient_id\",\n    \"status\",\n    \"appointment_date\",\n    _SNOWFLAKE_UPDATED_AT,\n    _SNOWFLAKE_DELETED\nFROM \"appointments\"\nWHERE _SNOWFLAKE_UPDATED_AT \u003E= DATEADD(hour, -24, CURRENT_TIMESTAMP)\nORDER BY _SNOWFLAKE_UPDATED_AT DESC;\n```\n\n**3. Doctor Productivity with CDC Data:**\n\n```sql\nSELECT \n    d.\"first_name\" || ' ' || d.\"last_name\" as doctor_name,\n    d.\"specialization\",\n    COUNT(a.\"appointment_id\") as total_appointments,\n    SUM(CASE WHEN a.\"status\" = 'completed' THEN 1 ELSE 0 END) as completed\nFROM \"doctors\" d\nLEFT JOIN \"appointments\" a ON d.\"doctor_id\" = a.\"doctor_id\"\nWHERE NOT a._SNOWFLAKE_DELETED OR a._SNOWFLAKE_DELETED IS NULL\nGROUP BY d.\"doctor_id\", d.\"first_name\", d.\"last_name\", d.\"specialization\"\nORDER BY completed DESC;\n```\n\n\u003E **Best of Both Worlds:** Use Snowflake CoWork for ad-hoc exploration and business user queries, and SQL for repeatable reporting and dashboards!\n\n\u003C!-- ------------------------ --\u003E\n## Cleanup\n\nWhen you're done with the quickstart, follow these steps to clean up all resources. This prevents unnecessary compute costs and removes test data from your environment.\n\n\u003E **⚠️ DESTRUCTIVE OPERATIONS**: Some cleanup steps below will permanently delete databases, schemas, tables, and all data created during this quickstart. Make sure you've captured any queries or insights you want to keep before proceeding!\n\n### Step 1: Stop the PostgreSQL Connector (Optional)\n\nIf you want to temporarily pause CDC replication without deleting any configuration:\n\n1. Navigate to your Openflow runtime canvas\n2. Right-click on the **PostgreSQL** processor group\n3. Select **Stop** to halt CDC replication\n4. Wait for the connector to fully stop (status indicator turns red)\n\n\u003E **TIP:** Stopping the connector preserves your configuration while preventing further CDC processing and associated compute costs. You can restart it later by right-clicking and selecting **Start**. Use this option if you want to keep your runtime and connector configuration intact.\n\n### Step 2: Delete Openflow Runtime (Permanent)\n\nDeleting the Openflow runtime will automatically stop all services and connectors, and clean up the container infrastructure.\n\n#### For Dedicated Runtime (Created for This Quickstart)\n\nIf you created a dedicated Openflow runtime for this quickstart:\n\n**Via Snowsight:**\n\n1. Navigate to **Work with data** → **Ingestion** → **Openflow**\n2. Go to **Runtimes** tab\n3. Find your runtime (e.g., `quickstart_pgcdc_runtime`)\n4. Click on the runtime and select **Delete**\n5. Confirm deletion\n6. Wait for the runtime to be fully removed (this may take a few minutes)\n\n\u003E **What Gets Deleted**: Deleting the runtime removes all connectors, services (NiFi, Registry), and the SPCS infrastructure. This automatically closes all database connections, including PostgreSQL replication slots.\n\n#### For Shared Runtime (From Companion Quickstart)\n\n\u003E **⚠️ IMPORTANT**: If you're using the Openflow runtime from the companion quickstart \"[Getting Started with Openflow on SPCS](https://quickstarts.snowflake.com/guide/getting-started-openflow-spcs)\", DO NOT delete the runtime! It may be used by other connectors or projects.\n\nInstead, stop the PostgreSQL connector and its related services:\n\n1. Navigate to **Work with data** → **Ingestion** → **Openflow**\n2. Select your runtime and open the canvas\n3. Right-click on the **PostgreSQL** processor group\n4. Select **Stop** to halt the connector\n5. Right-click on each related service (NiFi processors, controller services)\n6. Select **Stop** or **Disable** to stop all CDC-related services\n7. Wait for all components to fully stop (status indicators turn red/gray)\n\n![Stop Openflow PostgreSQL Services](https://www.snowflake.com/content/dam/snowflake-site/developers/guides/getting-started-with-openflow-postgresql-cdc/openflow_pgcdc_stop_all.gif?v=32b758de)\n\n\u003E **Keep the Runtime**: The shared runtime can be reused for future Openflow projects, including other CDC connectors, API integrations, or file ingestion pipelines. Stopping services preserves all configuration while eliminating compute costs.\n\n### Step 3: Clean Up PostgreSQL\n\nRemove the CDC configuration and test database from PostgreSQL.\n\n#### Terminate Active Replication Slots\n\nConnect to your PostgreSQL database and run these queries:\n\n```sql\n-- View replication slots\nSELECT slot_name, slot_type, active, restart_lsn \nFROM pg_replication_slots \nWHERE database = 'postgres';\n```\n\nSince you stopped the connector in previous steps, the slot will show `active = false`. Drop the inactive slot:\n\n```sql\n-- Drop inactive replication slot(s)\nSELECT pg_drop_replication_slot(slot_name) \nFROM pg_replication_slots \nWHERE database = 'postgres' \n  AND NOT active;\n```\n\n\u003E **Replication Slot Naming**: The replication slot name is automatically generated by Openflow following the pattern `snowflake_connector_\u003Cunique_id\u003E`. The query above will show you the exact name.\n\u003E\n\u003E **If Slot is Active**: If the slot still shows `active = true` (connector not fully stopped), first terminate the backend connection:\n\u003E\n\u003E ```sql\n\u003E -- Terminate the active backend connection\n\u003E SELECT pg_terminate_backend(active_pid)\n\u003E FROM pg_replication_slots\n\u003E WHERE slot_name = 'snowflake_connector_XXXXX' AND active = true;\n\u003E \n\u003E -- Then drop the slot\n\u003E SELECT pg_drop_replication_slot('snowflake_connector_XXXXX');\n\u003E ```\n\n#### Drop the Publication\n\nRemove the CDC publication:\n\n```sql\n-- Drop the publication for healthcare tables\nDROP PUBLICATION IF EXISTS healthcare_cdc_publication;\n```\n\n#### Drop the Healthcare Schema (Optional)\n\nIf you want to completely remove the test data:\n\n```sql\n-- Drop the healthcare schema and all its objects\nDROP SCHEMA IF EXISTS healthcare CASCADE;\n\n-- Verify cleanup\nSELECT schema_name \nFROM information_schema.schemata \nWHERE schema_name = 'healthcare';\n```\n\nExpected output: Empty result set (0 rows), confirming the healthcare schema has been removed.\n\n\u003E **Keep PostgreSQL?** If you're using a shared PostgreSQL instance, you may want to keep the schema and just drop the publication. If this was a dedicated test instance, you can safely drop everything.\n\n### Step 4: Drop Snowflake CoWork Agent\n\nRemove the AI agent and its associated database:\n\n```sql\n-- Use ACCOUNTADMIN role (required for agent operations)\nUSE ROLE ACCOUNTADMIN;\n\n-- Drop the Snowflake CoWork agent\nDROP AGENT IF EXISTS snowflake_intelligence.agents.HEALTHCARE_DATA_INTELLIGENCE;\n```\n\n### Step 5: Drop Snowflake Objects\n\nRemove all Snowflake resources created for this quickstart:\n\n```sql\n-- Use ACCOUNTADMIN role for cleanup\nUSE ROLE ACCOUNTADMIN;\n\n-- Drop the main database (includes healthcare schema and all tables)\nDROP DATABASE IF EXISTS QUICKSTART_PGCDC_DB CASCADE;\n\n-- Drop the warehouse\nDROP WAREHOUSE IF EXISTS QUICKSTART_PGCDC_WH;\n\n-- Drop the external access integration\nDROP INTEGRATION IF EXISTS quickstart_pgcdc_access;\n\n-- Drop the role\nDROP ROLE IF EXISTS QUICKSTART_ROLE;\n```\n\n#### Verify Cleanup\n\nConfirm all objects are removed:\n\n```sql\n-- Check for remaining objects\nSHOW DATABASES LIKE 'QUICKSTART_PGCDC_DB';\nSHOW DATABASES LIKE 'snowflake_intelligence';\nSHOW WAREHOUSES LIKE 'QUICKSTART_PGCDC_WH';\nSHOW INTEGRATIONS LIKE 'quickstart_pgcdc_access';\nSHOW ROLES LIKE 'QUICKSTART_ROLE';\n```\n\nExpected output: Empty result sets for all queries.\n\n### Step 6: Remove Local Files (Optional)\n\nIf you cloned the quickstart repository locally and no longer need it:\n\n```bash\n# Navigate to parent directory\ncd ..\n\n# Remove the quickstart directory\nrm -rf openflow-postgresql-cdc-demo\n\n# Verify removal\nls -la | grep openflow-postgresql-cdc-demo\n```\n\n### Cleanup Complete\n\nAll resources have been removed. You can verify by:\n\n- ✅ Checking Snowflake compute usage (warehouse should not be running)\n- ✅ Confirming no active PostgreSQL replication slots\n- ✅ Verifying no Openflow services consuming compute credits\n\n\u003E **Cost Savings**: By cleaning up unused resources, you avoid unnecessary compute costs. Warehouses, services, and replication slots all consume credits when active!\n\n\u003C!-- ------------------------ --\u003E\n## Conclusion And Resources\n\nCongratulations! You've successfully built a real-time CDC pipeline from PostgreSQL to Snowflake using Openflow.\n\n### What You Learned\n\n- How to configure PostgreSQL logical replication for CDC\n- How to set up Snowflake CoWork with semantic models for natural language queries\n- How to configure Openflow PostgreSQL connector for CDC\n- How to capture both snapshot and incremental changes\n- How to analyze real-time data and CDC metadata with AI-powered insights\n- How to use natural language to explore CDC changes\n\n### Related Resources\n\n**Openflow Documentation**:\n\n- [Openflow Overview](https://docs.snowflake.com/en/user-guide/data-integration/openflow/about)\n- [PostgreSQL CDC Connector](https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/postgres/about)\n- [MySQL CDC Connector](https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/mysql/about)\n- [SQL Server CDC Connector](https://docs.snowflake.com/en/user-guide/data-integration/openflow/connectors/sql-server/about)\n- [Manage Openflow](https://docs.snowflake.com/en/user-guide/data-integration/openflow/manage)\n- [Monitor Openflow](https://docs.snowflake.com/en/user-guide/data-integration/openflow/monitor)\n\n**Snowflake CoWork**:\n\n- [Snowflake CoWork Overview](https://docs.snowflake.com/en/user-guide/snowflake-cortex/snowflake-intelligence)\n- [Semantic Models](https://docs.snowflake.com/en/user-guide/snowflake-cortex/semantic-model-spec)\n- [Agents](https://docs.snowflake.com/en/user-guide/snowflake-cortex/agents)\n\n**PostgreSQL Resources**:\n\n- [Snowflake Postgres](https://www.snowflake.com/en/product/features/postgres/)\n- [Getting Started with Snowflake Postgres](https://www.snowflake.com/en/developers/guides/getting-started-with-snowflake-postgres/)\n- [PostgreSQL Logical Replication](https://www.postgresql.org/docs/current/logical-replication.html)\n\n**Snowflake Platform**:\n\n- [Snowpark Container Services](https://docs.snowflake.com/en/developer-guide/snowpark-container-services/overview)\n- [External Access Integration](https://docs.snowflake.com/en/sql-reference/sql/create-external-access-integration)\n\n---\n\n**Feedback**: Please provide feedback on this quickstart via [GitHub Issues](https://github.com/Snowflake-Labs/sfquickstarts/issues)\n","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-984e0605e1","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":{"layout":"SIMPLE","id":"container-a4868885af",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"quickstart_last_modi":{"id":"quickstart-last-modified-ac4d41b6b3","icon":{"id":"icon","icon":"calendar",":type":"snowflake-site/components/icon","appliedCssClassNames":"snowflake-icon-blue"},"lastModifiedDatePrefix":"Updated","lastModifiedDate":"2026-05-19",":type":"snowflake-site/components/quickstart/quickstart-last-modified","appliedCssClassNames":"snowflake-responsive-component-top-padding-small"},"text":{"id":"text-e783c92742","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":{"layout":"SIMPLE","id":"container-006a6e7d15",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{},":itemsOrder":[]},"isBlogPage":false,"isActiveTOC":false,":type":"snowflake-site/components/flexible-column-container"}},":itemsOrder":["contentfragment","flexible_column_cont"]},"flexible_column_content_container_2":{"layout":"SIMPLE","id":"container-44e8ae6de7",":type":"snowflake-site/components/flexible-column-container/flexible-column-content-container",":items":{"quickstart_table_of_":{"layout":"SIMPLE","id":"container-5f3877e705","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-6b5e70afee","fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/getting-started-with-openflow-postgresql-cdc",":type":"snowflake-site/components/quickstart/quickstart-table-of-content","headings":["\u003Ch2\u003EOverview\u003C/h2\u003E","\u003Ch2\u003EClone the QuickStart Repository\u003C/h2\u003E","\u003Ch2\u003ESetup PostgreSQL Database\u003C/h2\u003E","\u003Ch2\u003ESetup Snowflake Environment\u003C/h2\u003E","\u003Ch2\u003EOpenflow Configuration\u003C/h2\u003E","\u003Ch2\u003EAdd PostgreSQL Connector\u003C/h2\u003E","\u003Ch2\u003EConfigure PostgreSQL Connector\u003C/h2\u003E","\u003Ch2\u003EVerify Snapshot Load\u003C/h2\u003E","\u003Ch2\u003ESnowflake CoWork\u003C/h2\u003E","\u003Ch2\u003EGenerate Live CDC Events\u003C/h2\u003E","\u003Ch2\u003ECleanup\u003C/h2\u003E","\u003Ch2\u003EConclusion And Resources\u003C/h2\u003E"]},"quickstart_button":{"id":"quickstart-button-0cc99fbc06","fragmentPath":"/content/dam/snowflake-site/en/content-fragments/quickstarts/getting-started-with-openflow-postgresql-cdc",":type":"snowflake-site/components/quickstart/quickstart-button","appliedCssClassNames":"snowflake-responsive-component-top-padding-none"}},":itemsOrder":["quickstart_table_of_","quickstart_button"]}},":itemsOrder":["quickstart_table_of_"]},"isBlogPage":false,"isActiveTOC":false,":type":"snowflake-site/components/flexible-column-container"},"markup_editor":{"id":"markup-editor-74e053466a","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}}","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"}},":itemsOrder":["quickstart_hero","flexible_column_cont","markup_editor"],":type":"wcm/foundation/components/responsivegrid"},"modal_container":{"layout":"SIMPLE","id":"container-1b83778a39",":type":"snowflake-site/components/modal/modal-container",":items":{},":itemsOrder":[]},"experiencefragment-footer":{"id":"experiencefragment-d66eac26bc","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","layout":"SIMPLE","id":"container-e5407811ca",":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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-3a51e9bd5d",":type":"snowflake-site/components/container",":items":{"flexible_column_cont":{"id":"flexible-column-container-608252655a","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":{"layout":"SIMPLE","id":"container-607c88a23e",":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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-0ab7911978",":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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-efffe8bada",":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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-94ad876dc9",":type":"snowflake-site/components/container",":items":{"text":{"id":"text-49ff17ac28","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-f50bbfdf65","marketoForm":{"successUrl":null,"formId":"45871","edit":false,"script":null,"values":null,"hidden":null},"serverInstance":"252-RFO-227.mktoweb.com","marketoConfigured":true,"formConfigured":true,"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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-6e9308f154",":type":"snowflake-site/components/container",":items":{"text":{"id":"text-d89b3282d1","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-0e5be05215","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-c96a6e21a6",":type":"snowflake-site/components/container",":items":{"text":{"id":"text-4994371c4a","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-73ab4e572b",":type":"snowflake-site/components/container",":items":{"text":{"id":"text-4624c12b3c","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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-1759a0b0ce",":type":"snowflake-site/components/container",":items":{"text":{"id":"text-ff206b4b3a","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"]},"isBlogPage":false,"isActiveTOC":false,":type":"snowflake-site/components/flexible-column-container"}},":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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-ad80800036",":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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-db5cd1d5f9",":type":"snowflake-site/components/container",":items":{"flexible_column_cont":{"id":"flexible-column-container-993228baba","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":{"layout":"SIMPLE","id":"container-d5b42c8fb1",":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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-b1eb260399",":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"},"layout":"RESPONSIVE_GRID","columnCount":12,"id":"container-2638d29261",":type":"snowflake-site/components/container",":items":{"image":{"id":"image-784a95854f","additionalClasses":"sf-footer__logo","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,":type":"snowflake-site/components/image"}},":itemsOrder":["image"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-extra-small"},"text_copy_copy_16360":{"id":"text-6d95b6d576","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-a6abba7bd2","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","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"}},":itemsOrder":["container","text_copy_copy_16360","markup_editor"],"appliedCssClassNames":"snowflake-responsive-container-inner-padding-none"}},":itemsOrder":["container"]},"isBlogPage":false,"isActiveTOC":false,":type":"snowflake-site/components/flexible-column-container"}},":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-8818cd3c58","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}","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"}},":itemsOrder":["container_copy","container_573483281_","markup_editor_copy"]}},":itemsOrder":["root"],"classNames":"aem-xf"},"markup_editor":{"id":"markup-editor-e7d5d31d7c","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}}","isGSAPEnabled":false,":type":"snowflake-site/components/markup-editor"}},":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/getting-started-with-openflow-postgresql-cdc","analyticsDebugMode":false,"locale":"en","analyticsContentTags":["snowflake-site:taxonomy/solution-center/certification/quickstart","snowflake-site:taxonomy/product/platform","snowflake-site:taxonomy/snowflake-feature/postgres","snowflake-site:taxonomy/snowflake-feature/transformation","snowflake-site:taxonomy/snowflake-feature/openflow","snowflake-site:taxonomy/snowflake-feature/ingestion"],"isPasswordProtected":false,"analyticsEnabled":true}
  