Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions lib/dux/query_builder.ex
Original file line number Diff line number Diff line change
Expand Up @@ -459,6 +459,10 @@ defmodule Dux.QueryBuilder do
defp encode_value(v) when is_float(v), do: Float.to_string(v)
defp encode_value(true), do: "true"
defp encode_value(false), do: "false"
defp encode_value(%Date{} = v), do: "DATE '#{Date.to_iso8601(v)}'"
defp encode_value(%Time{} = v), do: "TIME '#{Time.to_iso8601(v)}'"
defp encode_value(%NaiveDateTime{} = v), do: "TIMESTAMP '#{NaiveDateTime.to_iso8601(v)}'"
defp encode_value(%DateTime{} = v), do: "TIMESTAMPTZ '#{DateTime.to_iso8601(v)}'"

defp encode_value(v) when is_binary(v) do
"'#{escape_sql_string(v)}'"
Expand Down
17 changes: 17 additions & 0 deletions test/dux/verb_test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -422,6 +422,23 @@ defmodule Dux.VerbTest do

assert result == 10
end

test "handles temporal values in small lists" do
result =
Dux.from_list([
%{
"date" => ~D[2001-01-01],
"time" => ~T[12:34:56],
"datetime" => ~N[2001-01-01 00:00:00]
}
])
|> Dux.to_rows()

assert [row] = result
assert row["date"] == ~D[2001-01-01]
assert Time.compare(row["time"], ~T[12:34:56]) == :eq
assert NaiveDateTime.compare(row["datetime"], ~N[2001-01-01 00:00:00]) == :eq
end
end

describe "compute/1" do
Expand Down
Loading