dropuserは、既存のPostgreSQLのユーザを削除します。 PostgreSQLのユーザを削除することができるのは、スーパーユーザとCREATEROLE権限があるユーザのみです。
dropuserはSQLコマンドDROP ROLEのラッパです。 このユーティリティを使用してユーザを削除しても、この方法以外の方法でサーバでアクセスしてユーザを削除しても特に違いはありません。
dropuserは、下記のコマンドライン引数を受け付けます。
削除するPostgreSQLのユーザ名を指定します。 コマンドラインで指定されず、かつ-i/--interactiveオプションが使用されている場合は、入力を促すプロンプトが表示されます。
dropuserが生成し、サーバに送信するコマンドを表示します。
実際にユーザを削除する前に確認のプロンプトを表示します。 コマンドラインにてユーザ名が指定されなかった場合にユーザ名の入力を促します。
dropuserのバージョンを表示し、終了します。
ユーザが存在しない場合にエラーを発生しません。 この場合は注意が発生します。
dropuserのコマンドライン引数の使用方法を表示し、終了します。
dropuserは以下のコマンドライン引数も接続パラメータとして受け付けます。
サーバが稼働しているマシンのホスト名を指定します。 この値がスラッシュから始まる場合、Unixドメインソケット用のディレクトリとして使用されます。
サーバが接続を監視するTCPポートもしくはUnixドメインソケットのファイル拡張子を指定します。
接続に使用するユーザ名です (削除するユーザ名ではありません)。
パスワードの入力を促しません。 サーバがパスワード認証を必要とし、かつ、.pgpassファイルなどの他の方法が利用できない場合、接続試行は失敗します。 バッチジョブやスクリプトなどパスワードを入力するユーザが存在しない場合にこのオプションは有用かもしれません。
データベースに接続する前に、dropuserは強制的にパスワード入力を促します。
サーバがパスワード認証を要求する場合dropuserは自動的にパスワード入力を促しますので、これが重要になることはありません。 しかし、dropuserは、サーバにパスワードが必要かどうかを判断するための接続試行を無駄に行います。 こうした余計な接続試行を防ぐために-Wの入力が有意となる場合もあります。
デフォルトの接続パラメータです。
また、このユーティリティは、他のほとんどのPostgreSQLユーティリティと同様、libpqでサポートされる環境変数を使用します(項31.14を参照してください)。
問題が発生した場合、考えられる原因とエラーメッセージについてはDROP ROLEとpsqlを参照してください。 データベースサーバは対象ホスト上で稼働していなければなりません。 また、libpqフロントエンドライブラリで使用される、あらゆるデフォルトの設定や環境変数が適用されます。