PostgreSql详细介绍(一)

一、表的定义: 
 
对于任何一种关系型数据库而言,表都是数据存储的最核心、最基础的对象单元。现在就让我们从这里起步吧。    

1. 创建表:    

CREATE TABLE products (        

product_no integer,        

name text,        

price numeric    

);          

2. 删除表:    

DROP TABLE products;          

3. 创建带有缺省值的表:    

CREATE TABLE products (        

product_no integer,        

name text,        

price numeric DEFAULT 9.99 --DEFAULT 是关键字,其后的数值 9.99 是字段 price 的默认值。
 );          

CREATE TABLE products (        

product_no SERIAL,            --SERIAL 类型的字段表示该字段为自增字段,完全等同于 Oracle 中的 Sequence。        

name text, 

price numeric DEFAULT 9.99    

);    

输出为:     NOTICE:  CREATE TABLE will create implicit sequence "products_product_no_seq" for serial column "products.product_no"          

4. 约束:    

检查约束是表中最为常见的约束类型,它允许你声明在某个字段里的数值必须满足一个布尔表达式。不仅如此,我们也可以声明表 级别的检查约束。    

CREATE TABLE products (        

product_no integer,        

name text,        

--price 字段的值必须大于 0 ,否则在插入或修改该字段值是,将引发违规错误。还需要说明的是,该检查约束
--是匿名约束,即在表定义时没有显 示命名该约束,这样 PostgreSQL 将会根据当前的表名、字段名和约束类型,
--为该约束自动命名,如: products_price_check 。
price numeric CHECK (price > 0)      

);        

CREATE TABLE products (        

product_no integer,        

name text,        

--该字段的检查约束被显示命名为 positive_price 。

--这样做好处在于今后 维护该约束时,可以根据该名进行直接操作。 
price numeric CONSTRAINT positive_price CHECK (price > 0)      

);    

下面的约束是非空约束,即约束的字段不能插入空值,或者是将已有数据更新为空值。    

CREATE TABLE products (        

product_no integer NOT NULL,        

name text NOT NULL,        

price numeric    

);    

如果一个字段中存在多个约束,在定义时可以不用考虑约束的声明顺序。    

CREATE TABLE products (        

product_no integer NOT NULL,        

name text NOT NULL,        

price numeric NOT NULL CHECK (price > 0)    

);    

唯一性约束,即指定的字段不能插入重复值,或者是将某一记录的值更新为当前表中的已有值。    

CREATE TABLE products (        

product_no integer UNIQUE,        

name text,        

price numeric    

); 
 
CREATE TABLE products (        

product_no integer,        

name text,          

price numeric,        

UNIQUE (product_no)    

);    

为表中的多个字段定义联合唯一性。    

CREATE TABLE example (        

a integer,        

b integer,        

c integer,        

UNIQUE (a, c)    

);    

为唯一性约束命名。    

CREATE TABLE products (        

product_no integer CONSTRAINT must_be_different UNIQUE,        

name text,        

price numeric    

);    

在插入数据时,空值(NULL)之间被视为不相等的数据,因此对于某一唯一性字段,可以多次插入空值。然而需要注意的是,这一 规则并不是被所有数据库都遵守,因此在进行数据库移植时可能会造成一定的麻烦。        

 5. 主键和外键:     从技术上来讲,主键约束只是唯一约束和非空约束的组合。    

CREATE TABLE products (        

product_no integer PRIMARY KEY,  --字段 product_no 被定义为该表的唯一主键。
name text,       

price numeric 
);    

和唯一性约束一样,主键可以同时作用于多个字段,形成联合主键:    

CREATE TABLE example (        

a integer,        

b integer,        

c integer,        

PRIMARY KEY (b, c)    

);    

外键约束声明一个字段(或者一组字段)的数值必须匹配另外一个表中某些行出现的数值。 我们把这个行为称做两个相关表之间 的参考完整性。    

CREATE TABLE orders (        

order_id integer PRIMARY KEY, --该表也可以有自己的主键。
--该表的 product_no 字段为上面 products 表主键 (product_no) 的外键。
product_no integer REFERENCES products(product_no),        

quantity integer    

);          

CREATE TABLE t1 (        

a integer PRIMARY KEY,        

b integer,        

c integer,        
--该外键的字段数量和被引用表中主键的数量必须保持一致。
 FOREIGN KEY (b, c) REFERENCES example (b, c)    

);        
当多个表之间存在了主外键的参考性约束关系时,如果想删除被应用表(主键表)中的某行记录,由于该行记录的主键字段值可能正 在被其引用表(外键表)中某条记录所关联,所以删除操作将会失败。如果想完成此操作,一个显而易见的方法是先删除引用表中和该 记录关联的行,之后再删除被引用表中的该行记录。然而需要说明的是,PostgreSQL 为我们提供了更为方便的方式完成此类操作。    
CREATE TABLE products (        

product_no integer PRIMARY KEY,        

name text,        

price numeric    

);          

CREATE TABLE orders (        

order_id integer PRIMARY KEY,          

shipping_address text    

);          

CREATE TABLE order_items (        

product_no integer REFERENCES products ON DELETE RESTRICT, -限制选项
order_id integer REFERENCES orders ON DELETE CASCADE, -级联删除选项
quantity integer,        

PRIMARY KEY (product_no, order_id)    

);    

限制和级联删除是两种最常见的选项。RESTRICT 禁止删除被引用的行。 NO ACTION 的意思是如果在检查约束的时候,如果 还存在任何引用行,则抛出错误; 如果你不声明任何东西,那么它就是缺省的行为。(这两个选择的实际区别是,NO ACTION 允许 约束检查推迟到事务的晚些时候,而 RESTRICT 不行。) CASCADE 声明在删除一个被引用的行的时候,引用它的行也会被自动删 除掉。 在外键字段上的动作还有两个选项: SET NULL 和 SET DEFAULT。 这样会导致在被引用行删除的时候,引用它们的字段 分别设置为空或者缺省值。 请注意这些选项并不能让你逃脱被观察和约束的境地。比如,如果一个动作声明 SET DEFAULT,但是 缺省值并不能满足外键,那么动作就会失败。类似 ON DELETE,还有 ON UPDATE 选项,它是在被引用字段修改(更新)的时候调用 的。可用的动作是一样的。 
 
二、系统字段: 
 
       PostgreSQL 的每个数据表中都包含几个隐含定义的系统字段。因此,这些名字不能用于用户定义的字段名。这些系统字段的功能 有些类似于 Oracle 中的 rownum 和 rowid 等。    

oid: 行的对象标识符(对象 ID)。这个字段只有在创建表的时候使用了 WITH OIDS,或者是设置了配置参数 default_with_oids 时出现。这个字段的类型是 oid(和字段同名)。      

tableoid: 包含本行的表的 OID。这个字段对那些从继承层次中选取的查询特别有用,因为如果没有它的话,我们就很难说明一 行来自哪个独立的表。tableoid 可以和 pg_class 的 oid 字段连接起来获取表名字。      

xmin: 插入该行版本的事务的标识(事务 ID)。    

cmin: 在插入事务内部的命令标识(从零开始)。      

xmax: 删除事务的标识(事务 ID),如果不是被删除的行版本,那么是零。    

cmax: 在删除事务内部的命令标识符,或者是零。      

ctid: 一个行版本在它所处的表内的物理位置。请注意,尽管 ctid 可以用于非常快速地定位行版本,但每次 VACUUM FULL 之后, 一个行的 ctid 都会被更新或者移动。因此 ctid 是不能作为长期的行标识符的。        

OID 是 32 位的量,是在同一个集群内通用的计数器上赋值的。对于一个大型或者长时间使用的数据库,这个计数器是有可能重叠 的。因此,假设 OID 是唯一的是非常错误的,除非你自己采取了措施来保证它们是唯一的。如果你需要标识表中的行,我们强烈建议 使用序列号生成器。           
三、表的修改: 
 
1. 增加字段:    

ALTER TABLE products ADD COLUMN description text;    

新增的字段对于表中已经存在的行而言最初将先填充所给出的缺省值(如果你没有声明 DEFAULT 子句,那么缺省是空值)。    

在新增字段时,可以同时给该字段指定约束。    

ALTER TABLE products ADD COLUMN description text CHECK(description <> '');          

2. 删除字段:    

ALTER TABLE products DROP COLUMN description;    

如果该表为被引用表,该字段为被引用字段,那么上面的删除操作将会失败。如果要想在删除被引用字段的同时级联的删除其所有 引用字段,可以采用下面的语法形式。    

ALTER TABLE products DROP COLUMN description CASCADE;          

3. 增加约束:    

ALTER TABLE products ADD CHECK(name <> '');  -增加一个表级约束
ALTER TABLE products ADD CONSTRAINT some_name UNIQUE(product_no);-增加命名的唯一性约束。
ALTER TABLE products ADD FOREIGN KEY(pdt_grp_id) REFERENCES pdt_grps; -增加外键约束。
ALTER TABLE products ALTER COLUMN product_no SET NOT NULL; -增加一个非空约束。
4. 删除约束:    

ALTER TABLE products DROP CONSTRAINT some_name;    

对于显示命名的约束,可以根据其名称直接删除,对于隐式自动命名的约束,可以通过 psql 的\d tablename 来获取该约束的名 字。和删除字段一样,如果你想删除有着被依赖关系地约束,你需要用 CASCADE。一个例子是某个外键约束依赖被引用字段上的唯 一约束或者主键约束。如:    

MyTest=# \d products www.linuxidc.com
         Table "public.products"        

Column     |  Type   | Modifiers      

------------+---------+-----------      

product_no | integer |      

name          | text    |      

price           | numeric |      

Check constraints:        

"positive_price" CHECK (price > 0::numeric)    

和其他约束不同的是,非空约束没有名字,因此只能通过下面的方式删除:    

ALTER TABLE products ALTER COLUMN product_no DROP NOT NULL;          

5. 改变字段的缺省值:  在为已有字段添加缺省值时,不会影响任何表中现有的数据行,它只是为将来 INSERT 命令改变缺省值。  ALTER TABLE products ALTER COLUMN price SET DEFAULT 7.77;    

下面为删除缺省值:    

ALTER TABLE products ALTER COLUMN price DROP DEFAULT          

6. 修改字段的数据类型:     只有在字段里现有的每个项都可以用一个隐含的类型转换转换成新的类型时才可能成功。比如当前的数据都是整型,而转换的目标 类型为 numeric 或 varchar,这样的转换一般都可以成功。与此同时,PostgreSQL 还将试图把字段的缺省值(如果存在)转换成 新的类型, 还有涉及该字段的任何约束。但是这些转换可能失败,或者可能生成奇怪的结果。 在修改某字段类型之前,你最好删除 那些约束,然后再把自己手工修改过的添加上去。      

ALTER TABLE products ALTER COLUMN price TYPE numeric(10,2);            

7. 修改字段名:    

ALTER TABLE products RENAME COLUMN product_no TO product_number;          

8. 修改表名:    

ALTER TABLE products RENAME TO items;       
四、权限: 
 
    只有表的所有者才能修改或者删除表的权限。要赋予一个权限,我们使用 GRANT 命令,要撤销一个权限,使用 REVOKE 命令。
     需要指出的是,PUBLIC 是特殊"用户"可以用于将权限赋予系统中的每一个用户。在声明权限的位置写 ALL 则将所有的与该对象 类型相关的权限都赋予出去。    

GRANT UPDATE ON table_name TO user;  -将表的更新权限赋予指定的 user 。
GRANT SELECT ON table_name TO GROUP group; -将表的 select 权限赋予指定的组。
REVOKE ALL ON table_name FROM PUBLIC; -将表的所有权限从 Public 撤销。
     最初,只有对象所有者(或者超级用户)可以赋予或者撤销对象的权限。但是,我们可以赋予一个"with grant option"权限,这 样就给接受权限的人以授予该权限给其它人的权限。如果授予选项后来被撤销,那么所有那些从这个接受者接受了权限的用户(直接或 者通过级连的授权)都将失去该权限。 







 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值