github
html_url | issue_url | id | node_id | user | created_at | updated_at | author_association | body | reactions | issue | performed_via_github_app |
---|---|---|---|---|---|---|---|---|---|---|---|
https://github.com/simonw/sqlite-utils/issues/441#issuecomment-1154373361 | https://api.github.com/repos/simonw/sqlite-utils/issues/441 | 1154373361 | IC_kwDOCGYnMM5Ezlbx | 9599 | 2022-06-13T20:01:25Z | 2022-06-13T20:01:25Z | OWNER | Yeah, at the moment the best way to do this is with `search_sql()`, but you're right it really isn't very intuitive. Here's how I would do this, using a CTE trick to combine the queries: ```python search_sql = db["articles"].search_sql(columns=["title", "author"])) sql = f""" with search_results as ({search_sql}) select * from search_results where owner = :owner """ results = db.query(sql, {"query": "my search query", "owner": "my owner"}) ``` I'm not sure if `sqlite-utils` should ever evolve to provide a better way of doing this kind of thing to be honest - if it did, it would turn into more of an ORM. Something like [PeeWee](http://docs.peewee-orm.com/en/latest/) may be a better option here. | { "total_count": 1, "+1": 1, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
1257724585 | |
https://github.com/simonw/sqlite-utils/issues/441#issuecomment-1155421299 | https://api.github.com/repos/simonw/sqlite-utils/issues/441 | 1155421299 | IC_kwDOCGYnMM5E3lRz | 9599 | 2022-06-14T16:23:52Z | 2022-06-14T16:23:52Z | OWNER | Actually I have a thought for something that could help here: I could add a mechanism for inserting additional where filters and parameters into that `.search()` method. | { "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
1257724585 | |
https://github.com/simonw/sqlite-utils/issues/441#issuecomment-1155750270 | https://api.github.com/repos/simonw/sqlite-utils/issues/441 | 1155750270 | IC_kwDOCGYnMM5E41l- | 9599 | 2022-06-14T21:57:57Z | 2022-06-14T21:57:57Z | OWNER | I added `where=` and `where_args=` parameters to that `.search()` method - updated documentation is here: https://sqlite-utils.datasette.io/en/latest/python-api.html#searching-with-table-search | { "total_count": 0, "+1": 0, "-1": 0, "laugh": 0, "hooray": 0, "confused": 0, "heart": 0, "rocket": 0, "eyes": 0 } |
1257724585 |