✅ Eugene trace report

Script name: examples/E5/bad/1.sql

✅ Statement number 1 for 10ms

-- 1.sql
create table prices (
    id integer generated always as identity
        primary key,
    price int not null
)

Locks at start

No locks held at the start of this statement.

New locks taken

No new locks taken by this statement.

❌ Eugene trace report

Script name: examples/E5/bad/2.sql

✅ Statement number 1 for 10ms

-- 2.sql
set local lock_timeout = '2s'

Locks at start

No locks held at the start of this statement.

New locks taken

No new locks taken by this statement.

❌ Statement number 2 for 10ms

alter table prices
    alter price set data type bigint

Locks at start

No locks held at the start of this statement.

New locks taken

SchemaObjectModeRelkindOIDSafeDuration held (ms)
publicpricesAccessExclusiveLockTable110
publicpricesShareLockTable110
publicprices_pkeyAccessExclusiveLockIndex110

Triggered rules

E5: Type change requiring table rewrite

The column price in the table public.prices was changed from type int4 to int8. This requires an AccessExclusiveLock that will block all other transactions from using the table while it is being rewritten.

E6: Creating a new index on an existing table

A new index was created on the table public.prices. The index was created non-concurrently, which blocks all writes to the table. Use CREATE INDEX CONCURRENTLY to avoid blocking writes.

E10: Rewrote table or index while holding dangerous lock

The Table public.prices was rewritten while holding AccessExclusiveLock on the Table public.prices. This blocks SELECT, FOR UPDATE, FOR NO KEY UPDATE, FOR SHARE, FOR KEY SHARE, UPDATE, DELETE, INSERT, MERGE while the rewrite is in progress.