Postgresql命令行工具
psql命令的使用,在控制台运行psql命令就会出现以下错误
原因是因为psql命令运行的默认用户是当前系统登陆的用户(比如我登陆的用户:dagger),而postgresql中可能不存在与它同名的用户,所以需要用-U参数指定用户名
psql -U postgres
今天第一天学习postgresql就遇到的一个坑,先mark一下
查看psql命令帮助信息
PS C:\Users\dagger> psql --help
psql是PostgreSQL 的交互式客户端工具。
使用方法:
psql [选项]... [数据库名称 [用户名称]]
通用选项:
-c,--command=命令 执行单一命令(SQL或内部指令)然后结束
-d, --dbname=数据库名称 指定要连接的数据库 (默认:"dagger")
-f, --file=文件名 从文件中执行命令然后退出
-l, --list 列出所有可用的数据库,然后退出
-v, --set=, --variable=NAME=VALUE
设置psql变量NAME为VALUE
(例如,-v ON_ERROR_STOP=1)
-V, --version 输出版本信息, 然后退出
-X, --no-psqlrc 不读取启动文档(~/.psqlrc)
-1 ("one"), --single-transaction
作为一个单一事务来执行命令文件(如果是非交互型的)
-?, --help[=options] 显示此帮助,然后退出
--help=commands 列出反斜线命令,然后退出
--help=variables 列出特殊变量,然后退出
输入和输出选项:
-a, --echo-all 显示所有来自于脚本的输入
-b, --echo-errors 回显失败的命令
-e, --echo-queries 显示发送给服务器的命令
-E, --echo-hidden 显示内部命令产生的查询
-L, --log-file=文件名 将会话日志写入文件
-n, --no-readline 禁用增强命令行编辑功能(readline)
-o, --output=FILENAME 将查询结果写入文件(或 |管道)
-q, --quiet 以沉默模式运行(不显示消息,只有查询结果)
-s, --single-step 单步模式 (确认每个查询)
-S, --single-line 单行模式 (一行就是一条 SQL 命令)
输出格式选项 :
-A, --no-align 使用非对齐表格输出模式
-F, --field-separator=STRING
为字段设置分隔符,用于不整齐的输出(默认:"|")
-H, --html HTML 表格输出模式
-P, --pset=变量[=参数] 设置将变量打印到参数的选项(查阅 \pset 命令)
-R, --record-separator=STRING
为不整齐的输出设置字录的分隔符(默认:换行符号)
-t, --tuples-only 只打印记录i
-T, --table-attr=文本 设定 HTML 表格标记属性(例如,宽度,边界)
-x, --expanded 打开扩展表格输出
-z, --field-separator-zero
为不整齐的输出设置字段分隔符为字节0
-0, --record-separator-zero
为不整齐的输出设置记录分隔符为字节0
联接选项:
-h, --host=主机名 数据库服务器主机或socket目录(默认:"本地接口")
-p, --port=端口 数据库服务器的端口(默认:"5432")
-U, --username=用户名 指定数据库用户名(默认:"dagger")
-w, --no-password 永远不提示输入口令
-W, --password 强制口令提示 (自动)
更多信息,请在psql中输入"\?"(用于内部指令)或者 "\help"(用于SQL命令),
或者参考PostgreSQL文档中的psql章节.
臭虫报告至 <pgsql-bugs@postgresql.org>.
创建数据库
如果postgresql默认用户和系统用户名一致,就不需要通过-U
来指定用户名了
输入命令之后,在输入密码就创建成功
createdb -U postgres dbtest
查看已有数据库列表
psql -U postgres -l
可以看到dbtest数据库已被创建
进入到指定数据库
在数据库命令行下可以执行任意sql语句
psql -U postgres dbtest
创建表并查看表信息
create table tbtest (id serial, name varchar(64));
输入\dt可以查看表列表
\dt
输入\d 表名
可以查看具体表结构
\d tbtest
删除表
drop table tbtest;
tbtest已被删除,再次查看表列表时,已经没有表了
执行sql文件
通过\i
命令来执行sql文件
创建test.sql,并写入以下sql语句,用来创建tbtest表
create table tbtest (id serial, name varchar(64));
执行sql文件
\i test.sql
查看所有表
\dt
最后通过\q
命令退出数据库命令行
或者ctrl+c也可以