postgres 登录及常用命令

登陆

输入以下命令,尝试登录psql:

psql -U postgres

报告以下错误:
psql: error: connection to server on socket "/var/run/postgresql/.s.PGSQL.5432" failed: FATAL: Peer authentication failed for user "postgres"

换成下面这个命令可以:

sudo -u postgres psql

#PostgreSQL默认会创建一个postgres的数据库用户作为数据库的管理员

解决方法参考如下:

https://stackoverflow.com/questions/69676009/psql-error-connection-to-server-on-socket-var-run-postgresql-s-pgsql-5432

https://cloud.tencent.com/developer/ask/sof/107553576

登录命令:

psql -h hostname -p portnumber -U username -d databasename

复制代码
其中:

-h 指定数据库服务器的主机名或IP地址。
-p 指定数据库服务器的端口号。默认端口号为5432。
-U 指定要登录的数据库用户的用户名。
-d 指定要连接的数据库名。

导入SQL脚本 示例:

psql -U postgres -d database -f sqlScript.sql

将sqlScript.sql导入到名为database的数据库中

常用命令

sql 复制代码
# 创建新表 
CREATE TABLE user_tbl(name VARCHAR(20), signup_date DATE);
# 插入数据 
INSERT INTO user_tbl(name, signup_date) VALUES('张三', '2013-12-22');
# 选择记录 
SELECT * FROM user_tbl;
# 更新数据 
UPDATE user_tbl set name = '李四' WHERE name = '张三';
# 删除记录 
DELETE FROM user_tbl WHERE name = '李四' ;
# 添加栏位 
ALTER TABLE user_tbl ADD email VARCHAR(40);
# 更新结构 
ALTER TABLE user_tbl ALTER COLUMN signup_date SET NOT NULL;
# 更名栏位 
ALTER TABLE user_tbl RENAME COLUMN signup_date TO signup;
# 删除栏位 
ALTER TABLE user_tbl DROP COLUMN email;
# 表格更名 
ALTER TABLE user_tbl RENAME TO backup_tbl;
# 删除表格 
DROP TABLE IF EXISTS backup_tbl;
# 修改数据库的名字
ALTER DATABASE oldName RENAME to newName

其他控制台命令

sql 复制代码
\h:查看SQL命令的解释,比如\h select。
\?:查看psql命令列表。
\l:列出所有数据库。
\c [database_name]:连接其他数据库。
	\c 可选参数 dbname [ username ] [ host ] [ port ] eg:
	\c postgres
	或者
	\c postgres username localhost 5432
\d:列出当前数据库的所有表格。
\d [table_name]:列出某一张表格的结构。
\du:列出所有用户。
\e:打开文本编辑器。
\conninfo:列出当前数据库和连接的信息。
\dn:展示当前数据库下所有schema信息
\q:断开数据库连接
相关推荐
2401_8762213410 分钟前
数据库系统概论(第6版)模拟题2
数据库
爱学习的小可爱卢25 分钟前
数据库MySQL——MySQL 可重复读隔离级别:Read View 底层原理与幻读问题深度剖析(面试必知)
数据库·mysql
lifewange1 小时前
数据库索引里面的游标是什么?
数据库·oracle
PhDTool1 小时前
计算机化系统验证(CSV)的前世今生
数据库·安全·全文检索
banpu1 小时前
Spring相关
数据库·spring·sqlserver
老年DBA2 小时前
Ora2Pg 迁移Oracle至 PostgreSQL 之实战指南
数据库·postgresql·oracle
我是苏苏2 小时前
MSSQL04: SQLserver的用户权限管理
数据库
l1t2 小时前
达梦数据库和Oracle兼容性和性能比较
数据库·sql·oracle·达梦
lkbhua莱克瓦242 小时前
基础-事务
开发语言·数据库·笔记·mysql·事务
weixin_436525072 小时前
NestJS-TypeORM QueryBuilder 常用 SQL 写法
java·数据库·sql