一、pgsql里面的数据类型不再介绍:https://www.runoob.com/postgresql/postgresql-data-type.html

二、常用基本语句

2.1、CREATE DATABASE dbname;   创建数据库

create database  Demo1;

          注意:createdb 命令位于 PostgreSQL安装目录/bin 下,执行创建数据库的命令:

        $ cd /Library/PostgreSQL/11/bin/
        $ createdb -h localhost -p 5432 -U postgres Demo1
        password ******

2.2、DROP DATABASE [ IF EXISTS ] dbname;   删除数据库

drop database  Demo1;

注意: dropdb 名位于 PostgreSQL安装目录/bin 下,执行删除数据库的命令:

          $ cd /Library/PostgreSQL/11/bin/
          $ dropdb -h localhost -p 5432 -U postgres runoobdb
          password ******

2.3、DROP TABLE 语句来删除表格,包含表格数据、规则、触发器
DROP TABLE Demo1; 或者 drop table department, company;

2.4、PostgreSQL 模式(SCHEMA)可以看着是一个表的集合, 一个模式可以包含视图、索引、数据类型、函数和操作符

      相同的对象名称可以被用于不同的模式中而不会出现冲突,

      例如 schema1 和 myschema 都可以包含名为 mytable 的表。

      使用模式的优势:1、允许多个用户使用一个数据库并且不会互相干扰。

2、将数据库对象组织成逻辑组以便更容易管理。

3、第三方应用的对象可以放在独立的模式中,这样它们就不会与其他对象的名称发生冲突。

2.4.1、 创建 语法:# create schema myschema;

# create table myschema.company(

                          ID INT NOT NULL,

                          NAME VARCHAR (20) NOT NULL,

                          AGE INT NOT NULL,

                          ADDRESS CHAR (25),

                          SALARY DECIMAL (18, 2),

                          PRIMARY KEY (ID)

                                 );

       2.4.2、删除语法:

        删除一个为空的模式(其中的所有对象已经被删除):

          DROP SCHEMA myschema;

        删除一个模式以及其中包含的所有对象:

          DROP SCHEMA myschema CASCADE;

2.5、插入语句:INSERT INTO TABLE_NAME (column1, column2, column3,...columnN)
VALUES (value1, value2, value3,...valueN);

所有字段插入值或者 INSERT INTO TABLE_NAME
VALUES (value1,value2,value3,...valueN);
案例:# INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY,JOIN_DATE)
           VALUES (1, 'Paul', 32, 'California', 20000.00,'2001-07-13');

所有字段插入值或者 INSERT INTO COMPANY
           VALUES (1, 'Paul', 32, 'California', 20000.00,'2001-07-13');


2.6、查询语句:SELECT column1, column2,...columnN FROM table_name;
案例:SELECT * FROM company;
SELECT * FROM COMPANY
WHERE SALARY > 50000;
                              =或!=或 >=、IS NOT NULL;
案例2:
        # SELECT (17 + 6) AS ADDITION ;
# SELECT COUNT(*) AS "RECORDS" FROM COMPANY;

PostgreSQL 还内置了一些数学函数,如:
        1、avg() : 返回一个表达式的平均值
        2、sum() : 返回指定字段的总和
        3、count() : 返回查询的记录总数

      2.7、更新数据库表中数据
语法:UPDATE table_name SET column1 = value1,
column2 = value2...., columnN = valueN WHERE [condition];
案例:# UPDATE COMPANY SET SALARY = 15000 WHERE ID = 3;

2.8、DELETE 语句来删除 PostgreSQL 表中的数据
DELETE FROM table_name WHERE [condition];
案例:DELETE FROM table_name WHERE [condition];

2.9、查询数据 limit 或 OFFSET
案例:=# SELECT * FROM COMPANY LIMIT 4;
偏移 offset
# SELECT * FROM COMPANY LIMIT 3 OFFSET 2;

2.10、DISTINCT 关键字与 SELECT 语句一起使用,用于去除重复记录,只获取唯一的记录
案例:SELECT DISTINCT name FROM COMPANY;


2.11、PostgreSQL 约束用于规定表中的数据规则。
PostgreSQL 中常用的约束。
1、
NOT NULL:指示某列不能存储 NULL 值。
2、UNIQUE:确保某列的值都是唯一的。
          3、PRIMARY Key:NOT NULL 和 UNIQUE 的结合。
确保某列(或两个列多个列的结合)有唯一标识,有助于更容易更快速地找到表中的一个特定的记录。
4、FOREIGN Key: 保证一个表中的数据匹配另一个表中的值的参照完整性。
5、CHECK: 保证列中的值符合指定的条件。
6、EXCLUSION :排他约束,保证如果将任何两行的指定列或表达式使用指定操作符进行比较,
至少其中一个操作符比较将会返回 false 或空值。
          CREATE TABLE COMPANY3(
          ID INT PRIMARY KEY NOT NULL,
           NAME TEXT NOT NULL,
           AGE INT NOT NULL UNIQUE,
           ADDRESS CHAR(50),
           SALARY REAL DEFAULT 50000.00
           );

2.12、删除约束
     ALTER TABLE table_name DROP CONSTRAINT some_name;

三、PostgreSQL 高级
 
   3.1、别名

SELECT C.ID, C.NAME, C.AGE, D.DEPT FROM COMPANY AS C, DEPARTMENT AS D WHERE C.ID = D.EMP_ID; 
   3.2、PostgreSQL 触发器是数据库的回调函数,它会在指定的数据库事件发生时自动执行/调用。

          PostgreSQL 触发器可以在下面几种情况下触发:

                      3.2.1、在执行操作之前(在检查约束并尝试插入、更新或删除之前)。

           3.2.2、 在执行操作之后(在检查约束并插入、更新或删除完成之后)。

                      3.2.3、更新操作(在对一个视图进行插入、更新、删除时)

语法:1、创建触发器时的基础语法如下

CREATE TRIGGER trigger_name [BEFORE|AFTER|INSTEAD OF]

event_name ON table_name

[

-- 触发器逻辑....

];

   
案例:
关键字 触发器名字
# CREATE TRIGGER example_trigger AFTER INSERT ON COMPANY FOR EACH ROW EXECUTE PROCEDURE auditlogfunc();

CREATE OR REPLACE FUNCTION auditlogfunc() RETURNS TRIGGER AS $example_table$
BEGIN
INSERT INTO AUDIT(EMP_ID, ENTRY_DATE) VALUES (new.ID, current_timestamp);
RETURN NEW;
END;
$example_table$ LANGUAGE plpgsql;

列出触发器:


# SELECT * FROM pg_trigger;


列举出特定表的触发器,语法如下:


# SELECT tgname FROM pg_trigger, pg_class WHERE tgrelid=pg_class.oid AND relname='company';

删除触发器

# drop trigger example_trigger on company;
 
 
3.3、索引 # \d company 命令列出 COMPANY 表的所有索引:
# CREATE INDEX salary_index ON COMPANY (salary);

使用索引时,需要考虑下列准则:

    1、索引不应该使用在较小的表上。

    2、索引不应该使用在有频繁的大批量的更新或插入操作的表上。

    3、索引不应该使用在含有大量的 NULL 值的列上。

4、索引不应该使用在频繁操作的列上。



3.4、PostgreSQL 中,ALTER TABLE 命令用于添加,修改,删除一张已经存在表的列。

   3.4.1、用 ALTER TABLE 在一张已存在的表上添加列的语法如下:

       ALTER TABLE table_name ADD column_name datatype;

    3.4.2、在一张已存在的表上 DROP COLUMN(删除列),语法如下:

      ALTER TABLE table_name DROP COLUMN column_name;

   3.4.3、修改表中某列的 DATA TYPE(数据类型),语法如下:

      ALTER TABLE table_name ALTER COLUMN column_name TYPE datatype;
案例:# ALTER TABLE COMPANY ADD GENDER char(1);  添加列
# ALTER TABLE COMPANY DROP GENDER; 删除列

3.5、PostgreSQL 中 TRUNCATE TABLE 用于删除表的数据,但不删除表结构。
TRUNCATE TABLE 与 DELETE 具有相同的效果,但是由于它实际上并不扫描表,所以速度更快。
语法:TRUNCATE TABLE table_name;
案例:TRUNCATE TABLE COMPANY;

3.6、PostgreSQL 视图是只读的,因此可能无法在视图上执行 DELETE、INSERT 或 UPDATE 语句。
但是可以在视图上创建一个触发器,当尝试 DELETE、INSERT 或 UPDATE 视图时触发,需要做的动作在触发器内容中定义。

   3.6.1、用户或用户组认为更自然或直观查找结构数据的方式。

   3.6.2 、限制数据访问,用户只能看到有限的数据,而不是完整的表。

   3.6.3、汇总各种表中的数据,用于生成报告。

语法:

CREATE [TEMP | TEMPORARY] VIEW view_name AS
SELECT column1, column2.....
FROM table_name
WHERE [condition];

案例:

CREATE VIEW COMPANY_VIEW AS
SELECT ID, NAME, AGE
FROM COMPANY; --创建

DROP VIEW view_name;--删除
3.7、TRANSACTION(事务)是数据库管理系统执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成。
事务具有以下四个标准属性,通常根据首字母缩写为 ACID:
  • 原子性(Atomicity):事务作为一个整体被执行,包含在其中的对数据库的操作要么全部被执行,要么都不执行。
  • 一致性(Consistency):事务应确保数据库的状态从一个一致状态转变为另一个一致状态。一致状态的含义是数据库中的数据应满足完整性约束。
  • 隔离性(Isolation):多个事务并发执行时,一个事务的执行不应影响其他事务的执行。
  • 持久性(Durability):已被提交的事务对数据库的修改应该永久保存在数据库中。

BEGIN TRANSACTION:开始一个事务。
COMMIT:事务确认,或者可以使用 END TRANSACTION 命令。
ROLLBACK:事务回滚。

回滚:
# BEGIN;
DELETE FROM COMPANY WHERE AGE = 25;
ROLLBACK;


提交:
# BEGIN;
DELETE FROM COMPANY WHERE AGE = 25;
COMMIT;

3.8、子查询
SELECT * FROM COMPANY WHERE ID IN (SELECT ID FROM COMPANY  WHERE SALARY > 45000) ;

3.9、权限

https://www.runoob.com/postgresql/postgresql-privileges.html

3.10、常用函数

https://www.runoob.com/postgresql/postgresql-functions.html

PGSQL基础语句汇总的更多相关文章

  1. SQL基础语句汇总

    连接数据库 1 mysql -h10.20.66.32 -uroot -p123456 -h后面是mysqlServer所在地址,-u后面是用户名,-p后面是密码 查看数据库 1 show datab ...

  2. Oracle知识梳理(三)操作篇:SQL基础操作汇总

    Oracle知识梳理(三)操作篇:SQL基础操作汇总 一.表操作 1.表的创建(CREATE TABLE): 基本语句格式:       CREATE TABLE  table_name ( col_ ...

  3. SQL基础操作汇总

    SQL基础操作汇总 一.表操作 1.表的创建(CREATE TABLE): 基本语句格式:    CREATE TABLE  table_name ( col_name    datatype, -- ...

  4. 沉淀,再出发:Java基础知识汇总

    沉淀,再出发:Java基础知识汇总 一.前言 不管走得多远,基础知识是最重要的,这些知识就是建造一座座高楼大厦的基石和钢筋水泥.对于Java这门包含了编程方方面面的语言,有着太多的基础知识了,从最初的 ...

  5. ORACLE| ORACLE基础语法汇总

    创 ORACLE| ORACLE基础语法汇总 2018-07-18 16:47:34 YvesHe 阅读数 9141更多 分类专栏: [数据库]   版权声明:本文为博主原创文章,遵循CC 4.0 B ...

  6. MySQL 基础语句

    MySQL 基础语句 多个知识点 ----------------------------------------------------------------------------------- ...

  7. jquery基础知识汇总

    jquery基础知识汇总 一.简介 定义 jQuery创始人是美国John Resig,是优秀的Javascript框架: jQuery是一个轻量级.快速简洁的javaScript库.源码戳这 jQu ...

  8. MySQL基础语句与其在Python中的使用

    一.MySQL基础语句 $ mysql -u root -p (有密码时) $ mysql -u root     (无密码时) QUIT (or \q)  退出 查看当前所有数据库 show dat ...

  9. T——SQL基础语句(定义变量,赋值,取值,分支,循环,存储过程)

    T--SQL基础语句 1.定义变量: declare @变量名 数据类型 ; declare @a int ; declare @b  nvarchar(10) ; 2.赋值: 法1:set @变量名 ...

随机推荐

  1. idea自动更新代码

    如何开启或关闭idea的自动更新代码? File-Setting-Appearance&Beha-System Setting-Updates 选中或取消勾选Automatically che ...

  2. centos7安装JDK、CentOS

    1.安装JDK 1.1查看系统是否已有自带的JDK rpm -qa |grep java rpm -qa |grep jdk rpm -qa |grep gcj 1.2卸载已有安装 如果没有输出信息, ...

  3. 『无为则无心』Python基础 — 12、Python运算符详细介绍

    目录 1.表达式介绍 2.运算符 (1)运算符的分类 (2)算数运算符 (3)赋值运算符 (4)复合赋值运算符 (5)比较运算符 3.逻辑运算符 拓展1:数字之间的逻辑运算 拓展2:Python中逻辑 ...

  4. 解放生产力,自动化生成vue组件文档

    一.现状 Vue框架在前端开发中应用广泛,当一个多人开发的Vue项目经过长期维护之后往往会沉淀出很多的公共组件,这个时候经常会出现一个人 开发了一个组件而其他维护者或新接手的人却不知道这个组件是做什么 ...

  5. 数据权限筛选(RLS)的两种实现介绍

    在应用程序中,尤其是在统计的时候, 需要使用数据权限来筛选数据行. 简单的说,张三看张三部门的数据, 李四看李四部门的数据:或者员工只能看自己的数据, 经理可以看部门的数据.这个在微软的文档中叫Row ...

  6. 2021年Wordpress手把手教你做个独立站——部署篇

    2021年Woocommerce电商主题的安装部署教程 Woocommerce是一个Wordpress的一个流行的电商插件.完成Wordpress的安装即已完成80%.剩下的便是去寻找一款合适的自己喜 ...

  7. 17、mysql主从同步Last_IO_Errno错误代码说明

    登录mysql从库:mysql> show slave status\G; Last_IO_Errno:1005:创建表失败 1006:创建数据库失败 1007:数据库已存在,创建数据库失败 1 ...

  8. Gym 100169E Tetrahedron Inequality

    大致题意: 给出六条边,判断是否能组成四面体 分析: 四面体由四个三角形组成,所以每一条边肯定要符合三角形的任意两边大于第三边的性质.一开始以为这样判断就可以了,然而这题并没有这么简单. 如右图,有四 ...

  9. Redis 底层数据结构之压缩列表

    文章参考:<Redis 设计与实现>黄建宏 压缩列表 压缩列表 ziplist 是列表键和哈希键的底层实现之一.当一个列表键只包含少量列表项,并且每个列表项要么就是小整数值,要么就是长度比 ...

  10. VMware-克隆虚拟机(CentOS7)

    采用克隆完整克隆 修改系统参数,除了IP和主机名以外. 第一步 修改mac地址 在虚拟机还未启动之前,先修改该系统的mac地址,如下操作所示. 生成新的mac地址 修改主机名(reboot后生效) $ ...