QuackDB.Ecto (quackdb v0.4.0)

Copy Markdown View Source

Convenience imports for Ecto-based QuackDB query modules.

Use this in modules that build DuckDB analytical, spatial, series, or full-text search Ecto queries and want the standard Ecto query DSL together with QuackDB's Ecto helper macros:

defmodule MyApp.Analytics do
  use QuackDB.Ecto

  def category_scores do
    from event in "events",
      group_by: event.category,
      select: %{
        category: event.category,
        median_score: median(event.score),
        fts_score: search_score("fts_main_events", event.id, ^"duckdb")
      }
  end
end

The macro imports:

QuackDB.Ecto.Conditionals.case_when/1 is also imported for multi-branch DuckDB CASE WHEN expressions using Elixir clause syntax.

Imports can be disabled individually. When spatial and text helpers are both enabled, shared contains/2 dispatches obvious text calls to DuckDB contains and spatial helper calls to ST_Contains. Ambiguous calls raise; use contains_text/2 or st_contains/2 when intent is not obvious.

use QuackDB.Ecto, spatial: false
use QuackDB.Ecto, full_text_search: false
use QuackDB.Ecto, analytics: false
use QuackDB.Ecto, regex: false
use QuackDB.Ecto, text: false
use QuackDB.Ecto, series: false
use QuackDB.Ecto, window_frames: false
use QuackDB.Ecto, query: false