一、数据库逻辑结构介绍

数据库:应用连接到一个数据库时,一般不能访问其它数据库,除非使用dblink等其他手段。

表、索引:postgresql中标的术语为relation,其它数据库中成为table。

数据行:每张表有多行数据,postgresql中称为tuple,其它数据库称row。

注意:在postgresql中,一个数据库(实例)下可以有多个数据库,而一个数据库不能属于多个实例。这跟oracle数据库不同。

二、数据库基本操作。

1.1  创建数据库:

create database name

  [ [with]  [owner [=] user_name ]  //  指定新建的数据库属于哪个用户,不指定使用当前用户。

    [template [=] template]      //  模板名(从哪个模板创建,不指定使用默认template1)

    [encoding [=] encoding ]  // 字符集编码    

    [lc_collate [=] lc_ctype]

    [tablespace [=] tablespace ]      // 指定的新数据库关联 表空间 的名字

    [connection limit [=] connlimit]   // 数据库可以接受多少并发连接,默认-1(无限制)

[]  中的参数都可省略为create database db_name;

1.2  修改数据库的方法:

alter database name [  [with]  option  [...]  ]

option 可以是:

  connection limit connlimit

  alter database name rename to new_name;

  alter database name owner to new_owner;

  alter database name set tablespace new_tablespace;

  alter database name set configuration_parameter from current;

  alter database name reset configuration_paramter;

  alter database name reset all

eg: 修改数据库的最大连接数

testdb=# alter database testdb connection limit 10;
ALTER DATABASE
Time: 6.557 ms

  eg: 修改数据库名称

testdb=# alter database test rename to testdb1;
ALTER DATABASE
Time: 9.537 ms

  eg:关闭在数据库testdb上的默认索引扫描

testdb=# alter database testdb set enable_indexscan to off;
ALTER DATABASE
Time: 12.012 ms

  

1.3  删除数据库

drop database [if exists] name;

注意:如果有人连接这个数据库,则不能删除;

不能再事物块中删除数据库;可以修改。

三、模式schema

1.1 定义:模式可以理解为一个命名空间或者目录。不同模式下可以有相同名称的表,函数等对象且互相不冲突。每个模式的对象可以相互调用。

一个数据库可以包含多个模式,一个模式中可以包含表、函数以及数据库对象。

postgresql中,不能同时访问不同数据库中的对象,而模式没有此限制。schema的这点概念类似于mysql中的database。

使用schema的原因:
  允许多个用户在使用同一个数据库时互不干扰。

  把数据库对象放在不同的模式下,然后组成逻辑组,让他们更便于管理。

  第三方应用可以放在不同的模式中,这样就不会和其它对象的名字冲突了。

2.1 模式的使用

create schema schemaname [ authorization username ] [ schema_elemane [...]]

2.1.1 创建、查看、删除一个schema

testdb=# create schema osdba;
CREATE SCHEMA
Time: 4.575 ms
testdb=# \dn
List of schemas
+--------+----------+
| Name | Owner |
+--------+----------+
| osdba | postgres |
| public | postgres |
+--------+----------+
(2 rows) testdb=# drop schema osdba;
DROP SCHEMA
Time: 7.558 ms
testdb=#

2.1.2 为repl用户创建模式repl;

postgres=# create schema authorization repl;
CREATE SCHEMA
postgres=#

2.1.3   创建模式的同时,在这个模式下创建一些表的视图:

postgres=# create schema osdba
create table t1 (id int, title text)
create table t2 (id int, content text)
create view v1 as
select a.id,a.title,b.content from t1 a,t2 b where a.id=b.id;
CREATE SCHEMA

  可以修改名称和owner,语法同数据库

testdb=#
alter schema osdba rename to osdbaold;
ALTER SCHEMA

  修改拥有者

testdb=# alter schema osdbaold owner to repl;
ALTER SCHEMA

  

2.2 模式的搜索路径

testdb=# show search_path;
search_path
-----------------
"$user", public
(1 row)

  

postgresql逻辑结构(一)的更多相关文章

  1. [转]PostgreSQL 逻辑结构 和 权限体系 介绍

    摘要: 本文旨在帮助用户理解PostgreSQL的逻辑结构和权限体系,帮助用户快速的理解和管理数据库的权限. 逻辑结构 最上层是实例,实例中允许创建多个数据库,每个数据库中可以创建多个schema,每 ...

  2. postgresql逻辑结构--表(二)

    一.创建表 语法: create table table_name( col01_name data_type, col02_name data_type, col03_name data_type, ...

  3. postgresql逻辑结构--用户及权限管理(七)

    一.用户和角色 二.创建用户和角色 三.权限管理 四.

  4. postgresql逻辑结构--索引(六)

    一.索引简介 二.索引分类 三.创建索引 四.修改索引 五.删除索引

  5. postgresql逻辑结构--视图(五)

    定义 一.创建视图 1.语法 create [or replace ]  [ temp |  temporary ]  view name [(column_name [,...])]  as que ...

  6. postgresql逻辑结构--表空间(四)

    一.创建表空间 1. 语法:create tablespace tablespace_name [owner user_name] location 'directory' postgres=# cr ...

  7. postgresql逻辑结构--触发器(三)

    触发器(tigger)是一种由事物自动触发执行的特殊存储过程,这些事件可以是对一个表进行INSERT.UPDATE.DELETE等操作. 一.创建触发器 create   [ constraint ] ...

  8. 学习推荐-Postgresql学习手册

    Postgresql之旅: http://www.cnblogs.com/stephen-liu74/archive/2012/06/08/2315679.html postgresql逻辑结构+权限 ...

  9. 浅谈PostgreSQL用户权限

    问题 经常在PG群里看到有人在问“为什么我对表赋予了权限:但是还是不能访问表” 解析 若你看懂德哥这篇文章PostgreSQL逻辑结构和权限体系介绍:上面对你就不是困扰你的问题 解决这个问题很简单:在 ...

随机推荐

  1. bzoj2004(矩阵快速幂,状压DP)

    每个长度为p的区间都必须出现k次1,数据又很小,我们使用状压. dp[i][j]->dp[i+1][j'],dp[i][j]表示当前考虑到了第i个车站,包括第i个其后的p个的状态(有车停或没车停 ...

  2. 使用Windows 8 Pro密钥光盘安装Windows 8.1 Pro

    在Windows 8.1发布接近半年的时候,自己终于腾出来了时间,准备升级一下自己的系统.作为一名极度强迫症患者,加上校园网的悲剧网速,最后决定使用光盘镜像全新安装而不是通过应用商店的升级. Figu ...

  3. Codeforces Round #264 (Div. 2) D. Gargari and Permutations 多序列LIS+dp好题

    http://codeforces.com/contest/463/problem/D 求k个序列的最长公共子序列. k<=5 肯定 不能直接LCS 网上题解全是图论解法...我就来个dp的解法 ...

  4. SRM387 div1

    250pt: 题目:有一些盒子(不大于50个),每个盒子里有一些大理石(最多50种颜色),然后给定每个盒子里每种颜色大理石的个数(没有为0),求最少操作几步满足: 1:最多只能一个盒子里有多种颜色,叫 ...

  5. Android学习之可滑动当前的Activity视图看见上一个活动的视图

    先看一下我的效果图吧: 好大的图啊!!! 百度音乐由一个很酷的功能,当前的UI可以滑动,然后看见上一个活动的UI,当时顿时觉得百度的牛人好多啊,能将如此前沿的技术应用到app上.当然如果你熟悉了And ...

  6. CSS 基础 例子 最小高度和最大高度设置

    最小高度,无论什么时候,高度不会小于该值,即使内容很少,不限制高度最大值,超出时候,按照实际内容来决定高度 最大高度,无论什么时候,高度不会大于该值,即使内容很多,不限制最小高度,超出时候,多出部分会 ...

  7. centos下网口vlan设置

    如果要使vlan之间进行通信,我们通常会使用三层交换机或者路由器子接口模式来做.Linux上关于VLAN与Cisco交换机中继连接,也是可以实现其互相之间的通信的. 环境:RHEL 5.2 最小化安装 ...

  8. Windows核心编程:第6章 线程基础

    Github https://github.com/gongluck/Windows-Core-Program.git //第6章 线程基础.cpp: 定义应用程序的入口点. // #include ...

  9. node.js实现WebSocket

    最近在学习“HTML5游戏开发实战”,其中第8章内容是使用WebSocket来构建多人游戏---<你画我猜>.然而在实现过程中,却一直出错: 客户端请求时,服务器端会报错并终止: 而浏览器 ...

  10. webpack安装整理

    早上有点时间大概安装一下webpack,操作一下顺便把步骤记一下,乱乱的,还是记录一下吧! webpack安装步骤:1. 2. 3.一直回车,出现如下图: 4.创建src和dist文件 5.需要在np ...