| From: | Marco Beri <marcoberi(at)gmail(dot)com> | 
|---|---|
| To: | Daniele Varrazzo <daniele(dot)varrazzo(at)gmail(dot)com> | 
| Cc: | psycopg(at)postgresql(dot)org | 
| Subject: | Re: Executing on the connection? | 
| Date: | 2020-12-02 13:41:43 | 
| Message-ID: | CAN1J36hNU0upVw-wdz5jT-RJqHKEV1H-jtQdbVkZ85gz4V9oFg@mail.gmail.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | psycopg | 
On Wed, 2 Dec 2020 at 12:20, Daniele Varrazzo <daniele(dot)varrazzo(at)gmail(dot)com>
wrote:
> One little change I've made to psycopg3 cursors is to make it return
> "self" on execute() (it currently returns None, so it's totally
> unused). This allows chaining a fetch operation right after execute,
> so the pattern above can be reduced to:
>
>     conn = psycopg3.connect(dsn)
>     cur = conn.cursor()
>     record = cur.execute(query, params).fetchone()
>     # or
>     for record in cur.execute(query, params):
>         ... # do something
> I'm toying with the idea of adding a 'connection.execute(query,
> [params])' methd, which would basically just create a cursor
> internally, query on it, and return it. No parameter could be passed
> to the cursor() call, so it could only create the most standard,
> client-side cursor (or whatever the default for the connection is, if
> there is some form of cursor_factory, which hasn't been implemented in
> psycopg3 yet). For anything more fancy, cursor() should be called
> explicitly.
>
> As a result people could use:
>
>     conn = psycopg3.connect(dsn)
>     record = conn.execute(query, params).fetchone()
>     # or
>     for record in conn.execute(query, params):
>         ... # do something
>
> No other methods bloating the connection interface: no executemany(),
> copy(), callproc (actually there will be no callproc at all in
> psycopg3: postgres has no fast path for function call and too much
> semantics around stored procedure that a single callproc() couldn't
> cover).
>
> Being the cursor client-side, its close() doesn't actually do anythin
> apart from making it unusable, so just disposing of it without calling
> close() is totally safe.
>
> Thoughts?
I like it a lot!
Ciao.
Marco.
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Daniele Varrazzo | 2020-12-02 13:56:31 | Re: Executing on the connection? | 
| Previous Message | Rory Campbell-Lange | 2020-12-02 12:48:07 | Re: Executing on the connection? |