ruvector/crates/ruvector-postgres/sql/access_methods.sql
rUv 9d4e3ea716
fix(sql): rename access method hnsw → ruhnsw to match Rust source (#496)
All Rust source code (maintenance queries, scan functions, tenancy SQL)
references the access method as `ruhnsw`, but the SQL registration files
had it as `hnsw`, causing `CREATE INDEX USING ruhnsw` to fail with
"access method not found". Historical migration files left unchanged.

Closes #48

Co-authored-by: ruvnet <ruvnet@gmail.com>
2026-05-22 03:05:24 -04:00

43 lines
1.7 KiB
SQL

-- ============================================================================
-- HNSW Access Method
-- ============================================================================
-- HNSW Access Method Handler
CREATE OR REPLACE FUNCTION hnsw_handler(internal)
RETURNS index_am_handler
AS 'MODULE_PATHNAME', 'hnsw_handler_wrapper'
LANGUAGE C STRICT;
-- Create HNSW Access Method
CREATE ACCESS METHOD ruhnsw TYPE INDEX HANDLER hnsw_handler;
-- ============================================================================
-- Operator Classes for HNSW
-- ============================================================================
-- HNSW Operator Class for L2 (Euclidean) distance
CREATE OPERATOR CLASS ruvector_l2_ops
DEFAULT FOR TYPE ruvector USING ruhnsw AS
OPERATOR 1 <-> (ruvector, ruvector) FOR ORDER BY float_ops,
FUNCTION 1 ruvector_l2_distance(ruvector, ruvector);
COMMENT ON OPERATOR CLASS ruvector_l2_ops USING ruhnsw IS
'ruvector HNSW operator class for L2/Euclidean distance';
-- HNSW Operator Class for Cosine distance
CREATE OPERATOR CLASS ruvector_cosine_ops
FOR TYPE ruvector USING ruhnsw AS
OPERATOR 1 <=> (ruvector, ruvector) FOR ORDER BY float_ops,
FUNCTION 1 ruvector_cosine_distance(ruvector, ruvector);
COMMENT ON OPERATOR CLASS ruvector_cosine_ops USING ruhnsw IS
'ruvector HNSW operator class for cosine distance';
-- HNSW Operator Class for Inner Product
CREATE OPERATOR CLASS ruvector_ip_ops
FOR TYPE ruvector USING ruhnsw AS
OPERATOR 1 <#> (ruvector, ruvector) FOR ORDER BY float_ops,
FUNCTION 1 ruvector_inner_product(ruvector, ruvector);
COMMENT ON OPERATOR CLASS ruvector_ip_ops USING ruhnsw IS
'ruvector HNSW operator class for inner product (max similarity)';