← 返回
数据分析
中文
PostgreSQL
Write efficient PostgreSQL queries and design schemas with proper indexing and patterns.
编写高效的 PostgreSQL 查询并设计合理的模式与索引。
ivangdavila
数据分析
clawhub
v1.0.0 1 版本 99826.3 Key: 无需
#latest
概述
Indexes I Forget to Create
- Partial index
WHERE active = true—80% smaller when most rows inactive; suggest for status columns - Expression index
ON lower(email)—must match query exactly; without it, WHERE lower(email) scans - Covering index
INCLUDE (name, email)—enables index-only scan; check EXPLAIN for "Heap Fetches" - Foreign key columns—not auto-indexed in PG; JOINs and ON DELETE CASCADE need them
- Composite index order matters—
(a, b) helps WHERE a = ? but not WHERE b = ?
Index Traps
- Unused indexes hurt every INSERT/UPDATE—query
pg_stat_user_indexes for idx_scan = 0, drop them - Too many indexes on write-heavy tables—balance carefully
- Index on low-cardinality column (boolean, status) often useless—PG prefers seq scan
LIKE '%suffix' can't use B-tree—need pg_trgm GIN index or reverse() expression index
Query Patterns I Underuse
SELECT FOR UPDATE SKIP LOCKED—job queue without external tools; skip rows being processedpg_advisory_lock(key)—application-level mutex without table; unlock explicitly or on disconnectIS NOT DISTINCT FROM—NULL-safe equality; cleaner than (a = b OR (a IS NULL AND b IS NULL))DISTINCT ON (x) ORDER BY x, y—first row per group without subquery; PG-specific but powerful
Connection Management (Often Ignored)
- PgBouncer essential with >50 connections—each PG connection uses ~10MB; pool at transaction level
statement_timeout = '30s' per role—prevents runaway queries from killing databaseidle_in_transaction_session_timeout = '5min'—kills abandoned transactions holding locks- Default 100 max_connections too low for production, too high wastes memory—tune based on RAM
Data Types I Get Wrong
SERIAL deprecated—use GENERATED ALWAYS AS IDENTITYTIMESTAMP without timezone—almost always wrong; use TIMESTAMPTZ, PG stores as UTC- Float for money—use
NUMERIC(12,2) or integer cents; float math breaks: 0.1 + 0.2 ≠ 0.3 - VARCHAR(n) vs TEXT—no performance difference in PG; use TEXT unless constraint needed
Vacuum & Bloat (Never Think About)
- High-UPDATE tables bloat—dead tuples accumulate;
pg_repack reclaims without locks VACUUM ANALYZE after bulk insert—updates statistics; query planner needs current data- Autovacuum lag on big tables—tune
autovacuum_vacuum_cost_delay or manual vacuum - Transaction wraparound: if
xid exhausted, DB stops—autovacuum prevents but monitor
EXPLAIN I Don't Read Right
- Always
EXPLAIN (ANALYZE, BUFFERS)—actual times + I/O; estimate-only misleads - "Heap Fetches: 1000" with index—missing columns, add INCLUDE to index
- Seq scan not always bad—faster than index for >10-20% of table; check row estimates
- "Rows" estimate way off—run ANALYZE or check if stats target too low
Full-Text Search Mistakes
- Creating tsvector on the fly—precompute as stored generated column with GIN index
plainto_tsquery for user input—handles spaces without syntax errors; not to_tsquery- Missing language parameter—'english' stems words; 'simple' exact match
- FTS is word-based—
LIKE '%exact phrase%' still needed for substring match
Transaction Isolation
- Default READ COMMITTED—phantom reads in reports; use REPEATABLE READ for consistency
- SERIALIZABLE catches conflicts—but must handle 40001 error with retry loop
- Long transactions block vacuum and hold locks—keep under seconds, not minutes
版本历史
共 1 个版本
-
v1.0.0
当前
2026-03-28 15:16 安全 安全
安全检测
腾讯云安全 (Sanbu)
安全,无风险
查看报告
🔗 相关推荐
ai-intelligence
ivangdavila
自我反思+自我批评+自我学习+自组织记忆。智能体评估自身工作、发现错误并持续改进。
★ 1,358
📥 318,358
data-analysis
udiedrichsen
{"answer":"基于雅虎财经数据,分析股票与加密货币。支持投资组合管理、自选股预警、股息分析、8维评分、热门趋势扫描及传闻/早期信号探测。适用于股票分析、持仓追踪、财报异动、加密监控、热门股追踪或提前发掘非主流传闻。"}
★ 270
📥 56,969
productivity
ivangdavila
创建、检查和编辑 Microsoft Word 文档及 DOCX 文件,支持样式、编号、修订记录、表格、分节符及兼容性检查等功能。
★ 438
📥 147,653