1. 创建数据库:
  1)登录bin目录,createdb.exe -U postgres -e mydb;
  -U 表示本次操作的登录用户名,如果不写会取windows登录的账户,如Administrator;会提示无创建权限;

2. 登录数据库:
  1)用postgre自带的sql shell,登录时选择数据库为创建库

3. CRUD
  书写习惯:SQL语句大写,其他小写
  3.1)创建表:
    CREATE TABLE users( username char(20) PRIMARY KEY, password char(20));
  3.2) 插入数据:
    INSERT INTO users(username, password) VALUES('fredric','fredric'),('sinny','sinny');
  3.4) 查询数据:
    SELECT * FROM users;

    SELECT * FROM users WHERE username LIKE ’fred%‘;//模糊查找
  3.5) 删除数据:

    DELETE FROM users WHERE username = "fredric";

  3.6) 更新数据:

    UPDATE emps SET salary = 8000.0 WHERE userid = 10;

4. JOIN
  准备:
  CREATE TABLE clubs(clubname char(20) PRIMARY KEY, note text);
  CREATE TABLE customers( username char(20) PRIMARY KEY, clubname char(20),FOREIGN KEY(clubname) REFERENCES clubs(clubname));

  INSERT INTO clubs(clubname, note) VALUES('myclub','good clubs');
  INSERT INTO clubs(clubname, note) VALUES('myclub1','good clubs');
  INSERT INTO customers(username, clubname) VALUES('fredric', 'myclub');

  4.1) INNER JOIN
    SELECT * FROM clubs INNER JOIN customers ON clubs.clubname = customers.clubname;
    返回数据 myclub
  4.2) OUTTER JOIN(例如 LEFT JOIN)
    SELECT * FROM clubs LEFT JOIN customers ON clubs.clubname = customers.clubname;
  返回数据 myclub 和 myclub1

5. 索引
  5.1) 创建索引
    CREATE INDEX clubs_index ON clubs USING hash(clubname);
    CREATE INDEX clubs_index ON clubs USING btree(clubname);//B树类型的索引支持多字段
    CREATE UNIQUE INDEX clubs_index ON clubs;//唯一索引,postgre默认在主键上生成唯一索引
  5.2) 删除索引
    DROP INDEX clubs_index;

6. 聚合函数
  6.1) COUNT
    SELECT COUNT(*) FROM clubs;
  6.2) MIN/MAX
    SELECT MIN(clubname) FROM clubs; //输出myclub
    SELECT MAX(clubname) FROM clubs; //输出myclub1

7. GROUP BY
  SELECT * FROM clubs GROUP By(clubname);
  SELECT COUNT(*) FROM clubs GROUP By(note);//1,2
  SELECT COUNT(*) FROM clubs GROUP By(note) HAVING COUNT(*) > 1;//2
  备注:SQL执行顺序 FROM -> WHERE -> 聚合函数-> GROUP BY -> HAVING -> ORDER BY -> SELECT;

8. 事务
  BEGIN TRANSACTION;
  DELETE FROM customers WHERE clubname = 'myclub';
  DELETE FROM clubs WHERE clubname = 'myclub';
  COMMIT; //执行删除
  ROLLBACK; //回滚操作

  SAVEPOINT;为保存点,回滚的位置
  例如:
    SAVEPOINT mypoint;
    ROLLBACK TO mypoint;

PostgreSQL基础整理(一)的更多相关文章

  1. PostgreSQL基础整理(三)

    1.触发器 有更新操作时记录一条日志 DROP FUNCTION IF EXIST log_test(); CREATE OR REPLACE FUNCTION log_test() RETURNS ...

  2. PostgreSQL基础整理(二)

    存储过程 实现功能:针对工资表30岁以下,工资提升10% 30至40提升20% 40以上提升30% + 奖金(入参)返回平均薪酬 创建表: DROP TABLE emps; CREATE TABLE ...

  3. 机器学习 —— 基础整理(六)线性判别函数:感知器、松弛算法、Ho-Kashyap算法

    这篇总结继续复习分类问题.本文简单整理了以下内容: (一)线性判别函数与广义线性判别函数 (二)感知器 (三)松弛算法 (四)Ho-Kashyap算法 闲话:本篇是本系列[机器学习基础整理]在time ...

  4. MySQL基础整理(一)之SQL基础(未完成)

    大家好,我是浅墨竹染,以下是MySQL基础整理(一)之SQL基础 1.SQL简介 SQL(Structure Query Language)是一种结构化查询语言,是使用关系模型的数据库应用语言. 2. ...

  5. nutch的一些基础整理

    nutch的一些基础整理 原创 2015年03月22日 18:18:01 标签: nutch / 240 编辑 删除 一.关于配置文件: nutch-default.xml:爬虫的默认配置.在${nu ...

  6. [转帖]nginx基础整理

    nginx基础整理 https://www.cnblogs.com/guigujun/p/6588545.html 目录结构如下: Nginx基础知识 Nginx HTTP服务器的特色及优点 Ngin ...

  7. JAVA基础整理-集合篇(一)

    集合作为JAVA的基础知识,本来感觉自己理解的很清楚了,但是在最近的一次面试中还是答得不尽如人意!再次做一下整理,以便加深理解以及随时查阅. 首先,java.util包中三个重要的接口及特点:List ...

  8. 关于JAVA面向对象基础整理以及个人的理解(适合初学者阅读)

    JAVA的基础语法等都跟C有很大的相似之处,所以这里就不多啰嗦了.直接从数组开始. 数组: 1.声明 int [] a; 在声明的过程中,并没有分配空间给数组.我们可以在声明的同时,用new来分配相应 ...

  9. C#基础整理

    元旦整理书架发现一本小册子——<C#精髓>中国出版社2001年出版的,粗略翻了下关于C#的知识点挺全的虽然内容谈得很浅也有很多过时的内容(话说这本书是我在旧书店花5块钱淘的)我保留原有章节 ...

随机推荐

  1. prim

    prim算法很难,但是我也把他写出来了.usaco3.1.1 #include <iostream> #include <cstring> using namespace st ...

  2. CSS布局(一)

    本节内容: 没有布局 display属性 margin:auto; max-width 盒模型 没有布局 如果想把所有内容都塞进一栏里,那么不用设置任何布局也是可以的.然而,如果用户把浏览器窗口调整的 ...

  3. MVC 之 WebAPI 系列一

    1. Web API简单说明 近来很多大型的平台都公开了Web API.比如百度地图 Web API,做过地图相关的人都熟悉.公开服务这种方式可以使它易于与各种各样的设备和客户端平台集成功能,以及通过 ...

  4. Oracle 表空间联机(online)与脱机(offline)

    数据库管理员可以在数据库处于开启(open)状态时令除 SYSTEM 表空间(tablespace)之外的任何表空间联机(online)(可访问)或脱机(offline)(不可访问).SYSTEM 表 ...

  5. [转]protobuf-2.5.0.tar.gz的下载与安装

    protobuf-2.5.0.tar.gz的下载与安装 原文地址:http://blog.csdn.net/tdmyl/article/details/31811317 版权声明:本文为博主原创文章, ...

  6. 【转载】PHP 开发者该知道的 5 个 Composer 小技巧

    Composer是新一代的PHP依赖管理工具.其介绍和基本用法可以看这篇<Composer PHP依赖管理的新时代>.本文介绍使用Composer的五个小技巧,希望能给你的PHP开发带来方 ...

  7. 【温故Delphi】双击工程文件打开软件

    问题描述 大部分软件都有鼠标双击文件,就能打开所关联的软件并打开所选工程,这是如何做到的呢? 把文件关联到一个程序中,双击文件来启动程序,那么这个文件名称就是这个程序的命令行的一个参数. 所以要想实现 ...

  8. GPT分区磁盘上优盘安装win10的方法

    刚买的acer笔记本安装的是win8,之后硬盘安装升级到win10.今天想格式化安装win10这样自带的软件可以去除,但是nt6 hdd在win10上无法使用,本来想先安装win7再通过nt6 hdd ...

  9. js基础知识点总结

    如何在一个网站或者一个页面,去书写你的js代码:1.js的分层(功能):jquery(tool) 组件(ui) 应用(app),mvc(backboneJs)2.js的规划():避免全局变量和方法(命 ...

  10. webpack配置

    1.初始化webpack npm install webpack -g   (全局安装) npm init   (初始化packge.json) npm install webpack --save- ...