pg_sql | Unsorted

Telegram-канал pg_sql - PostgreSQL

2806

English speaking PostgreSQL public chat. This group is for discussions on PostgreSQL-related topics and strives to provide best-effort support as well.

Subscribe to a channel

PostgreSQL

ok thank. that part show on PGDATA by default

Читать полностью…

PostgreSQL

Yes, you can usually find it:
SHOW data_directory;

Читать полностью…

PostgreSQL

Effectively a Tablespace in PG is just a folder.
When that device fills up, you are cooked.

Unlike Oracle (where you can add additional "files" to a tablespace, that can be on any or many different drives)...
This is one of the limitations of PG.
When you start running out of space. You need to create a new tablespace somewhere else (on a new drive).
And start moving things to be stored there.
Or you need to use a type of storage that allows you to add to the filesystem.

HTH

Читать полностью…

PostgreSQL

anyone experience on that pls help clearify me or provide support document.thank q

Читать полностью…

PostgreSQL

Hello team,
I wonder one thing on postgres regrading with Posgres tablespace.

by default is will using pg_default for all database creation .

Читать полностью…

PostgreSQL

SELECT *
FROM (
SELECT product, year, sales
FROM sales_data
)
PIVOT (
SUM(sales)
FOR year IN (2021 AS year_2021, 2022 AS year_2022)
);

Читать полностью…

PostgreSQL

Oracle has something, I believe. But I don't know how they make it work.

Читать полностью…

PostgreSQL

Said another way, introducing a new SQL construct because it doesn't feel right to you might actually be a great idea, but not if the new thing also doesn't feel right....

Читать полностью…

PostgreSQL

I could live with that. It's also probably not worth introducing a whole new SQL construct just because I don't like the way passing queries as strings "feels." :-)

Читать полностью…

PostgreSQL

To be more clear. You would use the (...) to define the columns returned.

That's interesting. But that would create a rather specific object that needs to be destroyed/recreated as the years would change in the future?

CREATE CROSSTAB mycrosstab(product TEXT, year_2021 int, year_2023 int) AS SELECT …

Читать полностью…

PostgreSQL

I was thinking of something like view syntax:

CREATE CROSSTAB mycrosstab(...) AS SELECT …

Читать полностью…

PostgreSQL

Today in idle wishes for PostgreSQL features: A version of tablefunc's crosstab that takes an actual query rather than a string. I dunno, the "pass a query as a string" thing always feels a bit unfinished to me.

Читать полностью…

PostgreSQL

Yes, so it was WHAT I was suspecting... You fixed it by using an Aggregate type query in the WITH () section.

Читать полностью…

PostgreSQL

It is so hard query for me

Читать полностью…

PostgreSQL

Thank you! I can use English with no problem. Amm, I resolved it.

Читать полностью…

PostgreSQL

remember, you can run out of diskspace for 2 reasons. WAL (logging), and DATA (tables,rows, etc).

Читать полностью…

PostgreSQL

ok noted, base on default_tablespace it's will base on on PGDATA , and PGDATA will depend on disk drive i am correct?

Читать полностью…

PostgreSQL

do you have any recommendation to share about geojson
is possible to save it from a POST api rest and save it in a postgres db

sample something like this
https://gist.github.com/rogergcc/913dee43310d35cda9a3383e094bed1b

or a simple crud project about this

Читать полностью…

PostgreSQL

my question is the pg_default tablespace is auto growth base on filesystem ?

Читать полностью…

PostgreSQL

A while ago, I was editing this PostgreSQL wiki page:

https://wiki.postgresql.org/wiki/Count_estimate

The function count_estimate has the same issue; it accepts a query as text.

I spent a little time playing around but couldn't figure out how to pass an actual query to it, thus ended up adding a warning:

Do not pass an unsanitized query to this function, as it is subject to SQL injection.

Читать полностью…

PostgreSQL

Oracle uses a PIVOT syntax and simple sub-query logic. No strings required.

Читать полностью…

PostgreSQL

Yeah, that kind of dynamic column list was something SQL didn't have a design item, and it pops up once in a while.

Читать полностью…

PostgreSQL

I think there's something weird about the way it works right now, and not in a good way. It is unclear to me what would be better, though.

Читать полностью…

PostgreSQL

We both said the same thing at basically the same time. Jinx! LOL

Читать полностью…

PostgreSQL

A tricky point about this is that in a crosstab, you don't know what the output column labels should be until you see what rows you get. But that means you don't know it until execution time. Which is a problem because the plan needs to contain that information. So maybe your CREATE CROSSTAB mycrosstab syntax would have to include a column list.

Читать полностью…

PostgreSQL

I am curious... Exactly how do you pass a query? Would it be an open cursor? Or the name of the prepared statement to be executed?

Читать полностью…

PostgreSQL

Here is a SIMPLE TRICK for the future. Aggregations can cause confusion.
So, I recommend you remove ANY Aggregation, and run the query for a limited set of data.
This will help you discover things like "statuses" or other tables that reference the same package more than once.

Keep in mind, if I join Cars, with Color_Options (by allowed_for_car_id, for example). I expect to see the SAME Car_ID for each color that is allowed. (Joining is like multiplying!) [Matrix Multiplying is one way to think of it]

But we live in a world where we think we are joining just "one" attribute (status), and if there are multiple, then we get multiple answers... (it happens all of the time).

Читать полностью…

PostgreSQL

Whole day I was trying resolved it

Читать полностью…

PostgreSQL

Now my query looks like that and it is working well for me

    query = """
WITH aggregated_packages AS (
SELECT order_id,
COUNT(id) AS package_count,
SUM(weight) AS package_weight
FROM cdek_package
GROUP BY order_id
),
order_status AS (
SELECT order_id,
MIN(name) AS status_name_last
FROM cdek_statuses
GROUP BY order_id
)
SELECT co.id AS cart_order_id,
co.status AS cart_order_status,
COALESCE(ap.package_count, 0) AS package_count,
COALESCE(ap.package_weight, 0) AS package_weight,
coe.id AS cdek_order_id,
coe.phones,
coe.cdek_number,
coe.address,
coe.name,
coe.total_sum,
coe.date_time,
os.status_name_last,
fo.address AS free_order_address,
fo.phone AS free_order_phone,
fo.buyer AS free_order_buyer,
osh.data AS order_status_data,
sp.place_weight
FROM cart_order AS co
LEFT JOIN cdek_order AS coe ON co.id = coe.external_order_id
LEFT JOIN aggregated_packages AS ap ON coe.id = ap.order_id
LEFT JOIN order_status AS os ON coe.id = os.order_id
LEFT JOIN free_order AS fo ON co.id = fo.external_order_id
LEFT JOIN order_status_history AS osh ON fo.external_order_id = osh.order_id AND osh.status = 9
LEFT JOIN store_places AS sp ON co.id = sp.order_id
WHERE co.status = 6
GROUP BY co.id, co.status, coe.id, coe.phones, coe.cdek_number, coe.address, coe.name, coe.total_sum,
coe.date_time, fo.address, fo.phone, fo.buyer, osh.data, sp.place_weight, ap.package_count, ap.package_weight, os.status_name_last
ORDER BY co.id DESC;
"""

Читать полностью…

PostgreSQL

First, please use English here, there is a Russian group out there.

Second, I would DEBUG this by adding to the query:
min(p.weight), max(p.weight).

I would also add COUNT(p.id) as "record_count"

This will tell you how to find the problems. you could have an extra record somewhere (from the joins).
And it is basically bringing that base record in twice.

Imagine there are 2 statuses. Back-ordered and Shipped. Because this package WAS back-ordered.
Those 2 records both apply to this p.id so the COUNT (with distinct) shows a 1, but the weight is doubled.
My count, min(), max() will give you enough detail to debug this better.

HTH.
Also, I hope you use the desktop version (like I do) so you can Translate this to Russian, if you need that!

Кроме того, я надеюсь, что вы используете настольную версию (как и я), чтобы вы могли перевести это на русский язык, если вам это нужно!

Читать полностью…
Subscribe to a channel