Skip to content

Commit

Permalink
fix(get_view_names): Use proper schema (#1082)
Browse files Browse the repository at this point in the history
* Fix get view names func

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

* wip

* Use information_schema.tables

* [pre-commit.ci] auto fixes from pre-commit.com hooks

for more information, see https://pre-commit.ci

---------

Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: Elliana May <me@mause.me>
  • Loading branch information
3 people authored Sep 4, 2024
1 parent 2d276c5 commit d5319c8
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 5 deletions.
27 changes: 22 additions & 5 deletions duckdb_engine/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -320,12 +320,29 @@ def get_view_names(
include: Optional[Any] = None,
**kw: Any,
) -> Any:
s = "SELECT table_name FROM information_schema.tables WHERE table_type='VIEW' and table_schema=:schema_name"
rs = connection.execute(
text(s), {"schema_name": schema if schema is not None else "main"}
)
s = """
SELECT table_name
FROM information_schema.tables
WHERE
table_type='VIEW'
AND table_schema = :schema_name
"""
params = {}
database_name = None

if schema is not None:
database_name, schema = self.identifier_preparer._separate(schema)
else:
schema = "main"

return [row[0] for row in rs]
params.update({"schema_name": schema})

if database_name is not None:
s += "AND table_catalog = :database_name\n"
params.update({"database_name": database_name})

rs = connection.execute(text(s), params)
return [view for (view,) in rs]

@cache # type: ignore[call-arg]
def get_schema_names(self, connection: "Connection", **kw: "Any"): # type: ignore[no-untyped-def]
Expand Down
3 changes: 3 additions & 0 deletions duckdb_engine/tests/test_basic.py
Original file line number Diff line number Diff line change
Expand Up @@ -248,6 +248,9 @@ def test_get_views(conn: Connection, dialect: Dialect) -> None:
views = dialect.get_view_names(conn, schema="scheme")
assert views == ["schema_test"]

views = dialect.get_view_names(conn, schema="memory.scheme")
assert views == ["schema_test"]

assert dialect.has_table(conn, table_name="test")
assert dialect.has_table(conn, table_name="schema_test", schema="scheme")

Expand Down

0 comments on commit d5319c8

Please sign in to comment.