我有一個可以使用(sql ddl)創建數據庫的安裝腳本create database if not exist。由于 Postgres 的工作方式不同,因此腳本不起作用。所以我為 Postgres 構建了一個特例,并使用(命令行)createdb -U ...命令生成數據庫。到目前為止它工作正常,但 Postgres 再次請求密碼。在這個線程之后我發現我可以使用 var PGPASSWORD 提供密碼在這個線程之后我想出了一個解決方案:(php)exec(' set PGPASSWORD=$password && createdb -U "$username" -h "$host" "$dbname" ')(簡化轉義)但這會返回一個錯誤:createdb: could not connect with template1: FATAL: Password authentication for user ?postgres? failed (translated)我不熟悉命令行及其特性 ->我不確定我是否在那里犯了一個嚴重的未被注意到的錯誤,如果我犯了,我很抱歉我現在將實現一個 Postgres 再次詢問用戶的版本,但如果你找到一個用戶不必輸入兩次密碼的解決方案,那就太酷了
1 回答

慕工程0101907
TA貢獻1887條經驗 獲得超5個贊
為什么要使用操作系統命令?你可以用 SQL 做同樣的事情:只需連接到postgres
數據庫(或任何其他數據庫)并運行
CREATE DATABASE dbname
- 1 回答
- 0 關注
- 119 瀏覽
添加回答
舉報
0/150
提交
取消