SlideShare a Scribd company logo
PRACTICAL POSGRESQL INDEXES FOR WEB
DEVELOPER (RAILS)
Long Nguyen
1 — © Employment Hero, 2016
AGENDA
> What is index
> Multiple indexes
> Gin and Gist
> N-gram indexes
> Full-text search
> Couple of tips
2 — © Employment Hero, 2016
WHAT IS INDEX ?
> Default will be BTree. They are
balanced: B-Trees evenly distribute
the keys among the nodes, minimizing
the number of times we have to follow
a pointer from one node to another.
Each pointer leads to a child node that
contains more or less the same number
of keys each other child node does.
> What happen when we create a new
index is that. PG will create actual
physical file in the system to keep
track of those indexes.
3 — © Employment Hero, 2016
MULTIPLE INDEXES
> https://wiki.postgresql.org/images/0/0b/
PGforSmarties.pdf
4 — © Employment Hero, 2016
N-GRAM
create extension pg_trgm;
select show_trgm('alice');
select * from members where first_name like '%Alice%';
CREATE INDEX CONCURRENTLY index_members_on_firstname_trigram
ON members
USING gin (first_name gin_trgm_ops);
drop index index_members_on_firstname_trigram;
5 — © Employment Hero, 2016
FULL-TEXT SEARCH
> https://kvyengineering.com/2016/03/30/understand-
more-about-full-text-search-for-rails-developer/
> From ... like '%name%' ... to full-text search
6 — © Employment Hero, 2016
GIN & GIST
7 — © Employment Hero, 2016
DO YOU SQL CAN DO THIS ? !
WITH RECURSIVE
x(i) AS ( VALUES(0) UNION ALL SELECT i + 1 FROM x WHERE i < 101),
Z(Ix, Iy, Cx, Cy, X, Y, I) AS (
SELECT Ix, Iy, X::float, Y::float, X::float, Y::float, 0
FROM
(SELECT -2.2 + 0.031 * i, i FROM x) AS xgen(x,ix)
CROSS JOIN
(SELECT -1.5 + 0.031 * i, i FROM x) AS ygen(y,iy)
UNION ALL
SELECT Ix, Iy, Cx, Cy, X * X - Y * Y + Cx AS X, Y * X * 2 + Cy, I + 1
FROM Z
WHERE X * X + Y * Y < 16.0
AND I < 27
),
Zt (Ix, Iy, I) AS (
SELECT Ix, Iy, MAX(I) AS I
FROM Z
GROUP BY Iy, Ix
ORDER BY Iy, Ix
)
SELECT array_to_string(
array_agg(
SUBSTRING(
' .,,,-----++++%%%%@@@@#### ',
GREATEST(I,1),
1
)
),''
)
FROM Zt
GROUP BY Iy
ORDER BY Iy;
8 — © Employment Hero, 2016
REFERENCES
> http://blog.codeship.com/discovering-computer-
science-behind-postgres-indexes/
> https://wiki.postgresql.org/images/0/0b/
PGforSmarties.pdf
9 — © Employment Hero, 2016

More Related Content

PDF
『あれ?Cssが反映されない!』を二度とやらないために
PDF
Code refactoring
PDF
Python and PostgreSQL: Let's Work Together! | PyConFr 2018 | Dimitri Fontaine
PDF
You Don't Know Node: Quick Intro to 6 Core Features
PDF
An R shiny demo for IDA MOOC facilitation, Developing Data Products
PDF
Is writing performant code too expensive?
PDF
The Ring programming language version 1.5.3 book - Part 15 of 184
PDF
Operational Intelligence with WSO2 BAM
『あれ?Cssが反映されない!』を二度とやらないために
Code refactoring
Python and PostgreSQL: Let's Work Together! | PyConFr 2018 | Dimitri Fontaine
You Don't Know Node: Quick Intro to 6 Core Features
An R shiny demo for IDA MOOC facilitation, Developing Data Products
Is writing performant code too expensive?
The Ring programming language version 1.5.3 book - Part 15 of 184
Operational Intelligence with WSO2 BAM

Similar to Pg for web developer (20)

PDF
The Ring programming language version 1.9 book - Part 21 of 210
PDF
From Knowledge Graphs to AI-powered SEO: Using taxonomies, schemas and knowle...
PDF
MySQL 8.0 Preview: What Is Coming?
PPTX
Introduction to Reactive Extensions (Rx)
PDF
The Ring programming language version 1.8 book - Part 19 of 202
PDF
Indexed Hive
PDF
7° Sessione - L’intelligenza artificiale a supporto della ricerca, servizi di...
PDF
He stopped using for/while loops, you won't believe what happened next!
PPTX
20150812 高中coding營 windows 10 app
PPTX
Building Python Applications on Windows Azure
PDF
Creating an Uber Clone - Part XXIV - Transcript.pdf
PPTX
Back to Basics, webinar 2: La tua prima applicazione MongoDB
PDF
greenDAO
PDF
Trend briefs security
PDF
All About JSON and ClickHouse - Tips, Tricks and New Features-2022-07-26-FINA...
PPTX
Dmitry Chastukhin - Business Intelligence hacking – Breaking ICCube
PDF
20180420 hk-the powerofmysql8
PDF
Piano rubyslava final
PPTX
ORIGINLAB 2018 FOR PERSOLAL USE.pptx
PPT
Yui app-framework
The Ring programming language version 1.9 book - Part 21 of 210
From Knowledge Graphs to AI-powered SEO: Using taxonomies, schemas and knowle...
MySQL 8.0 Preview: What Is Coming?
Introduction to Reactive Extensions (Rx)
The Ring programming language version 1.8 book - Part 19 of 202
Indexed Hive
7° Sessione - L’intelligenza artificiale a supporto della ricerca, servizi di...
He stopped using for/while loops, you won't believe what happened next!
20150812 高中coding營 windows 10 app
Building Python Applications on Windows Azure
Creating an Uber Clone - Part XXIV - Transcript.pdf
Back to Basics, webinar 2: La tua prima applicazione MongoDB
greenDAO
Trend briefs security
All About JSON and ClickHouse - Tips, Tricks and New Features-2022-07-26-FINA...
Dmitry Chastukhin - Business Intelligence hacking – Breaking ICCube
20180420 hk-the powerofmysql8
Piano rubyslava final
ORIGINLAB 2018 FOR PERSOLAL USE.pptx
Yui app-framework
Ad

Recently uploaded (20)

PPTX
Introduction to Artificial Intelligence
PDF
PTS Company Brochure 2025 (1).pdf.......
PDF
How Creative Agencies Leverage Project Management Software.pdf
PDF
How to Migrate SBCGlobal Email to Yahoo Easily
PDF
medical staffing services at VALiNTRY
PDF
Understanding Forklifts - TECH EHS Solution
PDF
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 42 Updates Latest 2025
PPTX
Essential Infomation Tech presentation.pptx
PDF
Odoo Companies in India – Driving Business Transformation.pdf
PDF
Navsoft: AI-Powered Business Solutions & Custom Software Development
PDF
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
PDF
How to Choose the Right IT Partner for Your Business in Malaysia
PPTX
VVF-Customer-Presentation2025-Ver1.9.pptx
PDF
AI in Product Development-omnex systems
PDF
EN-Survey-Report-SAP-LeanIX-EA-Insights-2025.pdf
PDF
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
PPTX
history of c programming in notes for students .pptx
PDF
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
PDF
Which alternative to Crystal Reports is best for small or large businesses.pdf
Introduction to Artificial Intelligence
PTS Company Brochure 2025 (1).pdf.......
How Creative Agencies Leverage Project Management Software.pdf
How to Migrate SBCGlobal Email to Yahoo Easily
medical staffing services at VALiNTRY
Understanding Forklifts - TECH EHS Solution
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
Internet Downloader Manager (IDM) Crack 6.42 Build 42 Updates Latest 2025
Essential Infomation Tech presentation.pptx
Odoo Companies in India – Driving Business Transformation.pdf
Navsoft: AI-Powered Business Solutions & Custom Software Development
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
How to Choose the Right IT Partner for Your Business in Malaysia
VVF-Customer-Presentation2025-Ver1.9.pptx
AI in Product Development-omnex systems
EN-Survey-Report-SAP-LeanIX-EA-Insights-2025.pdf
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
history of c programming in notes for students .pptx
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
Which alternative to Crystal Reports is best for small or large businesses.pdf
Ad

Pg for web developer