psql-01基本介绍
安装与启动
- 安装:
apt-get install postgresql / yum install postgresql.XXX
; - 启动:
mac
下直接打开linux
service postgresql status
service postgresql stop
service postgresap start
修改监听Ip和端口
//postgresql.config; 修改并重启
#listen_address = 'localhost'
#port = 5432
关于用户
- 安装postgresql数据库时会建立一个与初始化数据库时的操作系统同名的数据库用户,即为超级用户,在这个用户下登陆数据库是系统默认认证;`
- 可以修改
pg_hna.config
要求输入密码; - 列出数据库中所有用户:
\du / \dg
默认数据库
- 安装后默认有
template0, template1
; - 新创建的数据库默认继承自
template1
,可以对他定义些表和函数; tempalte0
是一个最简化的模版库, 创建数据库时可以指定从此继承;
完整的链接数据库
- 格式:
psql -h <hostname or ip> -p <port> [mydb] [username]
psql -h 192.168.56.11 -p 5432 testdb postgres
- 环境变量: 连接参数可以用环境变量指定
export PGDATABSE=xx
export PGHOST=xx
.....
客户端基本操作
- 显示所有:
\d
;详细信息:\d+
;
\dt //只显示表
\di //只显示索引
\ds //只显示序列
\dv //只显示视图
\df //只显示函数
打开显示SQL执行时间:
\timing on
; 关闭:\timing off
;指定客户端字符编码与服务器一致:
\encoding utf8/gbk
防止乱码;查询结果的边框显示
\pset border 0;
\pset border 1;
\pset border 2;
- 查询结果拆行显示;在单行数据太多的情况下;
\x on
\x off
显示信息:
\echo xxx
执行外部文件脚本
\i a.sql
psql -f a.sql
- psql中事务是自动提交的
//不自动提交
begin;
xxxx;
rollback;/commit;
//直接设定
\set AUTOCOMMIT off //注意一一定要大写
- 获得psql中命令实际执行的sql
- 连接数据库时:
psql -E mydb
; - 设置:
\set echo_hidden on|off
- 连接数据库时:
SQL简介
数据定义语句
- DDL: 创建,修改,删除表;
数据操纵语句
- DML: 插入,更新,删除数据;
数据查询语句
- DQL:
用shell
执行
按外部sql
文件执行
psql database -f test.sql;
连接数据库
- 创建特殊用户
create user username with password 'password';
//指定仅将某个数据库的权限给他
grant all privileges on database db_name to username;
- 登录
psql -h myhost -d mydb -U myuser -W
- 移除权限
drop owned by username
- 创建超级用户
create user admin with superuser password 'admin_pwd';
可能出现的问题
- role "root" does not exist
* key
//可以再创建超级用户root
createuser -d -a -P root
备份与恢复
psql-01基本介绍的更多相关文章
- 《The Linux Command Line》 读书笔记01 基本命令介绍
<The Linux Command Line> 读书笔记01 基本命令介绍 1. What is the Shell? The Shell is a program that takes ...
- 开源Math.NET基础数学类库使用(01)综合介绍
原文:[原创]开源Math.NET基础数学类库使用(01)综合介绍 开源Math.NET基础数学类库使用系列文章总目录: 1.开源.NET基础数学计算组件Math.NET(一)综合介绍 2. ...
- Nmap原理-01选项介绍
Nmap原理-01选项介绍 1.Nmap原理图 Nmap包含四项基本功能:主机发现/端口扫描/版本探测/操作系统探测.这四项功能之间存在大致的依赖关系,比如图片中的先后关系,除此之外,Nmap还提供规 ...
- vue.js 2.0 官方文档学习笔记 —— 01. vue 介绍
这是我的vue.js 2.0的学习笔记,采取了将官方文档中的代码集中到一个文件的形式.目的是保存下来,方便自己查阅. !官方文档:https://cn.vuejs.org/v2/guide/ 01. ...
- 01.课程介绍 & 02.最小可行化产品MVP
01.课程介绍 02.最小可行化产品MVP 产品开发过程 最小化和可用之间找到一个平衡点
- 前端 ----- 01 -html介绍和head标签
01-html介绍和head标签 主要内容 web标准 浏览器介绍 开发工具介绍 HTML介绍 HTML颜色介绍 HTML规范 HTML结构详解 一.web标准 web准备介绍: w3c:万维网联 ...
- 【原创】开源Math.NET基础数学类库使用(01)综合介绍
本博客所有文章分类的总目录:[总目录]本博客博文总目录-实时更新 开源Math.NET基础数学类库使用总目录:[目录]开源Math.NET基础数学类库使用总目录 前言 ...
- Swift开发学习-01 Swift介绍
本教程是笔者在自学IOS/Swift知识的总结,适用于通过对Objictive C编程的运用并需要了解基于iOS程序的iPhone和iPad的程序员.做一个有bigger的’攻城狮‘,有尊严的工作,快 ...
- 《精通并发与Netty》学习笔记(01 - netty介绍及环境搭建)
一.Netty介绍 Netty是由JBOSS提供的一个java开源框架.Netty提供异步的.事件驱动的网络应用程序框架和工具,用以快速开发高性能.高可靠性的网络服务器和客户端程序. ...
- Kubernetes 实战 —— 01. Kubernetes 介绍
简介 P2 Kubernetes 能自动调度.配置.监管和故障处理,使开发者可以自主部署应用,并且控制部署的频率,完全脱离运维团队的帮助. Kubernetes 同时能让运维团队监控整个系统,并且在硬 ...
随机推荐
- CSS3实现圆角效果
利用border-radius属性可以给元素div,input元素等添加圆角效果 后跟 值为这个圆角的半径,即数值越大效果越明显 -webkit-border-top/bottom-left/righ ...
- 【leetcode】Valid Sudoku (easy)
题目:就是判断已有的数字是否冲突无效,若无效返回flase 有效返回true 不要求sudo可解 用了char型的数字,并且空格用‘.'来表示的. 思路:只要分别判断横向 竖向 3*3小块中的数字是否 ...
- Javascript中最常用的55个经典技巧(转)
1. oncontextmenu="window.event.returnValue=false" 将彻底屏蔽鼠标右键 <table border oncontextmenu ...
- 转载_虚拟机下LInux(终端)配置网络的方法
出自: http://www.360doc.com/content/14/1027/11/17496895_420258403.shtml 对文章的重点进行剪贴,方便查看. 这几天在虚拟机vmware ...
- MAC下GitHub命令操作
由于GitHub实在太有用了~~ ,各种源代码,开源工程,经常需要下载下来使用和学习,或者自己的代码需要上传之类的,尽管有"GitHub for Mac"工具,但是作为一名程序猿! ...
- C#资源文件管理
1.右键项目点属性; 2.点资源项,添加资源下拉框的添加现在文件,如下图: 3.直接上代码获取并复制到指定文件夹下: private void button1_Click(object sender, ...
- NYOJ题目57 6174问题
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAscAAAJLCAIAAACE5qzaAAAgAElEQVR4nO3dMXKrutvH8XcT6bOQ1C ...
- React Native实例之房产搜索APP
React Native 开发越来越火了,web app也是未来的潮流, 现在react native已经可以完成一些最基本的功能. 通过开发一些简单的应用, 可以更加熟练的掌握 RN 的知识. 在学 ...
- 一般处理程序获取session值
1.要在一般处理程序中获取其他页面的session值,需要引用名空间: using System.Web.SessionState; 2.然后继承一个接口:IRequiresSessionState, ...
- DOM - 5.事件冒泡 + 6.事件中的this
5.事件冒泡 如果元素A嵌套在元素B中,那么A被点击不仅A的onclick事件会被触发,B的onclick也会被触发.触发的顺序是"由内而外" .验证:在页面上添加一个table. ...