Yeah I understood you Evan. Thanks man !
I asked about any other risks, in case all values in my col are capable to be inside an int column.
בתאריך יום ה׳, 1 בנוב׳ 2018 ב-15:52 מאת Evan Bauer <evanbauer@xxxxxxx>:
Mariel,My suggestion was that you have confidence that you don’t find yourself 90% through the shrink process and unexpectedly find that it fails on an "integer out of range error” like this:ares_net=# create table test_int (test_big bigint, test_int int);CREATE TABLEares_net=# insert into test_int values (5000000000, 0);INSERT 0 1ares_net=# select * from test_int;test_big | test_int------------+----------5000000000 | 0(1 row)ares_net=# update test_int set test_int = test_big;ERROR: integer out of rangeares_net=#If you already know (because of domain knowledge or because of constraints on how the data was loaded an updated) that all of your values are in the INT range, then this is unnecessary. If you aren’t sure and you need to check the value of unindexed columns (which would require a full table scan), then do the update in a procedure that checks that the 8-byte value value will fit into 4-byte int — and does appropriate things should it not fit.Cheers,- EvanOn Nov 1, 2018, at 08:54, Mariel Cherkassky <mariel.cherkassky@xxxxxxxxx> wrote:I want to do it on a very big tables(100M records). Do you think that it will be slow ? I mean if I have an AccessExclusiveLock for a lot of time I cant just run a query and take my time until it finishes..בתאריך יום ה׳, 1 בנוב׳ 2018 ב-13:55 מאת Evan Bauer <evanbauer@xxxxxxx>:Mariel,Just run a query and make certain that all values currently stored in the column fit in 4 bytes (+/- 2,147,483,648) before doing the ALTER.Cheers,EvanSent from my iPhoneHi,I want to change the column type from bigint to int to save space. By doing so, does it include some risks ? As I see it, I should only run vacuum full afterwards if I want to return space to the os right ?