Reputation: 1394
For Postgres, I keep getting this error multiple times even though I have already set the location of the bin
folder to the path variable in Windows 8. Is there something else I'm missing?
Upvotes: 137
Views: 339041
Reputation: 2787
This answer has been added to the documentation, but in case you are still looking.
An update because I was trying it on Windows 10 you do need to set the path to the following:
;C:\Program Files\PostgreSQL\14\bin ;C:\Program Files\PostgreSQL\9.5\lib
PS : 14 is the current version, check whatever version you are on.
You can do that either through the CMD by using set PATH [the path]
or from my
computer => properties => advanced system settings=> Environment Variables => System Variables
Then search for path.
Important: don't replace the PATHs that are already there just add one beside them as follows ;C:\Program Files\PostgreSQL\9.5\bin ;C:\Program Files\PostgreSQL\9.5\lib
Please note: On windows 10, if you follow this: computer => properties => advanced system settings=> Environment Variables => System Variables> select PATH, you actually get the option to add new row. Click Edit, add the /bin and /lib folder locations and save changes.
Then close your command prompt if it's open and then start it again
try psql --version
If it gives you an answer then you are good to go if not try echo %PATH%
and see if the path you set was added or not and if it's added is it added correctly or not.
Replace 9.5 with your current version number. As of 2021, that is 13. For 2022 is 14.
Upvotes: 248
Reputation: 1278
In my case, the error message was caused by the pg_env.bat script extending the path surrounded with "..."
@SET PATH=**"**C:\Program Files\PostgreSQL\14\bin**"**;%PATH%
should be
@SET PATH=C:\Program Files\PostgreSQL\14\bin;%PATH%
Without the ".." it worked for me.
Upvotes: 1
Reputation: 692
Configured everything in the system environment variables PATH but still getting an error via MSSQL stored procedure:
'psql' is not recognized as an internal or external command, operable program or batch file.
So, I Try this and worked for me [Problem Solved]:
SET @v_connect = 'postgresql://' + @v_user_id + ':' + @v_password + '@' + @v_host + ':' + @v_port + '/' + @v_database + ' < "' + @v_server_path + 'CONTROL\'
SET @v_sql = 'cd "C:\Program Files\PostgreSQL\14\bin\" && psql ' + @v_connect + @v_output_sql_script_nm + @v_quote
PRINT ' ** What vSQL Say: ' + @v_sql + ' **'
EXEC @v_cmd_result = XP_CMDSHELL @v_sql
Here I first go into that command location then execute it
Take look at this part of code: 'cd "C:\Program Files\PostgreSQL\14\bin" && psql '
Upvotes: 0
Reputation: 1
You can use psql
on CMD on Windows 11.
First, search and click Edit the system environment variables as shown below:
Then, click Environment Variables as shown below:
Lastly, set C:\Program Files\PostgreSQL\<version>\bin
to Path either in User variables or System variables or both as shown below. *Only the currently logged-in specific user can access User variables while all users can access System variables:
...
C:\Program Files\PostgreSQL\13\bin
C:\Program Files\PostgreSQL\14\bin
C:\Program Files\PostgreSQL\15\bin
Upvotes: 2
Reputation: 181
I kept trying these solutions to no avail, then I realised that my error was that I was adding new environment variables instead of editing the PATH variable. We need to add the
;C:\Program Files\PostgreSQL\9.5\bin;C:\Program Files\PostgreSQL\9.5\lib
to the existing PATH variable, NOT create new variables. Leaving this here in case someone else gets stuck with the same mistake.
Upvotes: 0
Reputation: 780
For Windows 10 and 11 users, here are the steps:
Upvotes: 3
Reputation: 51
Even if it is a little bit late, i solved the PATH problem by removing every space.
;C:\Program Files\PostgreSQL\<installed version>\bin;C:\Program Files\PostgreSQL\<installed version>\lib
works for me now.
Upvotes: 5
Reputation: 20901
You can follow the following steps below.
C:\Program Files\PostgreSQL\yourversion
Upvotes: 18
Reputation: 21
Always better to install a previous version or in the installation make sure you specify the '/data' in a separate directory folder "C:\data"
Upvotes: 0
Reputation: 2211
Find your binaries file where it is saved. get the path in terminal mine is
C:\Users\LENOVO\Documents\postgresql-9.5.21-1-windows-x64-binaries (1)\pgsql\bin
then find your local user data path, it is in mostly
C:\usr\local\pgsql\data
now all we have to hit the following command in the binary terminal path:
C:\Users\LENOVO\Documents\postgresql-9.5.21-1-windows-x64-binaries (1)\pgsql\bin>pg_ctl -D "C:\usr\local\pgsql\data" start
done!
Upvotes: 3
Reputation: 593
Simple solution that hasn't been mentioned on this question: restart your computer after you declare the path variable.
I always have to restart - the path never updates until I do. And when I do restart, the path always is updated.
Upvotes: 3
Reputation: 211
Enter this path in your System environment variable.
C:\Program Files\PostgreSQL\[YOUR PG VERSION]\bin
In this case i'm using version 10. If you check the postgres folder you are going to see your current versions.
In my own case i used the following on separate lines:
C:\Program Files\PostgreSQL\10\bin
C:\Program Files\PostgreSQL\10\lib
Upvotes: 20
Reputation: 770
Windows 10
It could be that your server doesn't start automatically on windows 10 and you need to start it yourself after setting your Postgresql path using the following command in cmd:
pg_ctl -D "C:\Program Files\PostgreSQL\11.4\data" start
You need to be inside "C:\Program Files\PostgreSQL\11.4\bin" directory to execute the above command.
EX:
You still need to be inside the bin directory to work with psql
Upvotes: 12
Reputation: 51
Make sure that the path actually leads to the executables. I'm using version 11 and it did not work until this was set as the path:
C:\Program Files\PostgreSQL\11\bin\bin
Maybe this is how version 11 is structured or I somehow botched the installation but I haven't had a problem since.
Upvotes: 5
Reputation: 81
If you tried all the answers and still spinning your heads, don't forget to change the version with your one which you downloaded.
For example, don't simply copy paste
;C:\Program Files\PostgreSQL\9.5\bin ;C:\Program Files\PostgreSQL\9.5\lib
More clearly,
;C:\Program Files\PostgreSQL\[Your Version]\bin ;C:\Program Files\PostgreSQL\[Your Version]\lib
I was spinning my heads. Hope this helps.
Upvotes: 7
Reputation: 420
I had your issue and got it working again (on windows 7).
My setup had actually worked at first. I installed postgres and then set up the system PATH variables with C:\Program Files\PostgreSQL\9.6\bin; C:\Program Files\PostgreSQL\9.6\lib
. The psql keyword in the command line gave no errors.
I deleted the PATH variables above one at a time to test if they were both really needed. Psql continued to work after I deleted the lib path, but stopped working after I deleted the bin path. When I returned bin, it still didn't work, and the same with lib. I closed and reopened the command line between tries, and checked the path. The problem lingered even though the path was identical to how it had been when working. I re-pasted it.
I uninstalled and reinstalled postgres. The problem lingered. It finally worked after I deleted the spaces between the "; C:..." in the paths and re-saved.
Not sure if it was really the spaces that were the culprit. Maybe the environment variables just needed to be altered and refreshed after the install.
I'm also still not sure if both lib and bin paths are needed since there seems to be some kind of lingering memory for old path configurations. I don't want to test it again though.
Upvotes: 6