-
-
Notifications
You must be signed in to change notification settings - Fork 59
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Stripe FDW randomly returns no data #237
Comments
What happens if you run the following query directly in the database: select p.name, p.id as product_id, q.id as price_id, (q.unit_amount / 100.0)::real as price
from stripe.products p
left join stripe.prices q on p.id = q.product
where p.active and q.active; Does it also produce results intermittently? What about even simpler queries like: select q.id, q.unit_amount, q.product, q.active from stripe.prices; Or select p.id, p.name, p.active from stripe.products p; |
If I run the full query (or the simple query) in the console, it always
works correctly.
If I run the simple query from the client, it also fails about half the
time.
It's possible I am not able to run the console queries fast enough so I
don't think one can conclude conclusively that that points to a permission
issue. When the query runs in the app, it is called twice in quick
succession. Sometimes both fail, sometimes one fails, sometimes both
succeed.
Matt
…On Fri, Feb 9, 2024 at 2:05 AM Raminder Singh ***@***.***> wrote:
What happens if you run the following query directly in the database:
select p.name, p.id as product_id, q.id as price_id, (q.unit_amount / 100.0)::real as pricefrom stripe.products pleft join stripe.prices q on p.id = q.productwhere p.active and q.active;
Does it also produce results intermittently? What about even simpler
queries like:
select q.id, q.unit_amount, q.product, q.active from stripe.prices;
Or
select p.id, p.name, p.active from stripe.products p;
—
Reply to this email directly, view it on GitHub
<#237 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AGGVYL2IUSRFSLNOTKYKMADYSXDDVAVCNFSM6AAAAABDAADSUOVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSMZVGQZDSNRTGM>
.
You are receiving this because you authored the thread.Message ID:
***@***.***>
|
This issue looks very similar to mine and is pointing to a rate limit
(possibly on the stripe side):
#234
Matt
…On Fri, Feb 9, 2024 at 7:31 AM Matt Calder ***@***.***> wrote:
If I run the full query (or the simple query) in the console, it always
works correctly.
If I run the simple query from the client, it also fails about half the
time.
It's possible I am not able to run the console queries fast enough so I
don't think one can conclude conclusively that that points to a permission
issue. When the query runs in the app, it is called twice in quick
succession. Sometimes both fail, sometimes one fails, sometimes both
succeed.
Matt
On Fri, Feb 9, 2024 at 2:05 AM Raminder Singh ***@***.***>
wrote:
> What happens if you run the following query directly in the database:
>
> select p.name, p.id as product_id, q.id as price_id, (q.unit_amount / 100.0)::real as pricefrom stripe.products pleft join stripe.prices q on p.id = q.productwhere p.active and q.active;
>
> Does it also produce results intermittently? What about even simpler
> queries like:
>
> select q.id, q.unit_amount, q.product, q.active from stripe.prices;
>
> Or
>
> select p.id, p.name, p.active from stripe.products p;
>
> —
> Reply to this email directly, view it on GitHub
> <#237 (comment)>,
> or unsubscribe
> <https://github.com/notifications/unsubscribe-auth/AGGVYL2IUSRFSLNOTKYKMADYSXDDVAVCNFSM6AAAAABDAADSUOVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTSMZVGQZDSNRTGM>
> .
> You are receiving this because you authored the thread.Message ID:
> ***@***.***>
>
|
This looks like a bug in wrappers. If I run a query directly, e.g. |
I analyzed further and this bug is more involved than I thought. If the function with the query is called after To reproduce run the following: create or replace function public.get_products()
returns table (
product_id text
)
language plpgsql as
$$
begin
return query
select p.id as product_id from stripe.products p;
end
$$;
select * from public.get_products();
select * from stripe.products;
select * from public.get_products();--ERROR: required option 'object' is not specified The error occurs because the code assumes that a foreign table will only ever have one |
When 1st time calling the function, postgres will cache the execution plan to improve query performance. So for the following calls, the For short-term solution, we can use dynamic query in the function to prevent postgres from using execution plan cache and re-create create or replace function public.get_products()
returns table (
product_id text
)
language plpgsql as
$$
begin
return query
execute 'select p.id as product_id from stripe.products p'; -- use dynamic query here
end
$$; For long-term solution, we might need to find a good way to reuse |
The dynamic query is indeed working. Thank you. For me this is closed, but I'll leave it to you to decide whether to keep it open to track the long-term issue. Thanks for this, looks like it took some serious work. |
Although we have a good workaround (using a dynamic query), reopening this to track the use-after-free bug that we still need to fix. |
[supabase#218] Fixes 218, adds human readable explanation
I am querying stripe FDW tables using an rpc call using supabase-js from my web app. About half the time, the query returns no results. It should return 2 rows, and does so about half the time. I can reproduce it reliably by just refreshing the page. It is not obvious when it will return results and when not. It may be a function of how quickly I refresh, but isn't always. I can refresh after waiting several minutes, get no results, refresh again and get results as well as vice-versa. There isn't any rhyme or reason to it as far as I can tell. When it returns no results, it does not have an error, just an empty result:
{data: [], error: null}
.Supabase support is telling me to use pg_cron and to build what is effectively a materialized view of the stripe FDW data within supabase. If that is the recommended workflow, I think it should be documented as such.
Here is the rpc call with the query, it joins the product and price tables. There are two products, and those were populated once a while ago and have not changed.
The text was updated successfully, but these errors were encountered: