Queryprestaties verbeteren in PostgreSQL
Amy McCarty
Instructor
Wat
Waarom
Waar
| ingredient | recipe |
|---|---|
| tomatoes | spaghetti & meatballs |
| green onions | fried rice |
| eggs | fried rice |
| ground beef | spaghetti & meatballs |
| pasta | spaghetti & meatballs |
| rice | fried rice |
| soy sauce | fried rice |
SELECT *
FROM cookbook
WHERE recipe = 'fried rice'

SELECT * FROM pg_indexes
| schemaname | tablename | indexname | tablespace | indexdef |
|---|---|---|---|---|
| food | dinner | recipe_index | null | CREATE INDEX recipe_index ... |

CREATE INDEX recipe_index
ON cookbook (recipe);
CREATE INDEX CONCURRENTLY recipe_index
ON cookbook (recipe, serving_size);
Gebruik een index
Vermijd een index
Vaak geüpdatete tabellen

Query planner
EXPLAIN
SELECT *
FROM cookbook
Queryplan
Seq scan on cookbook (cost=0.00...22.70
rows = 1270 width = 36)
Queryprestaties verbeteren in PostgreSQL