Home Database Mysql Tutorial 用规则在PostgreSQL中创建可查询插入修改删除的表视图

用规则在PostgreSQL中创建可查询插入修改删除的表视图

Jun 07, 2016 pm 05:01 PM
postgresql

具体内容如下:要注意 new.attribute和old.attribute 与源表、视图属性之间的关系[root@me root]# su postgresbash-2.05b$ psql

具体内容如下:
要注意 new.attribute和old.attribute 与源表、视图属性之间的关系
[root@me root]# su postgres
bash-2.05b$ psql -E -h me.linux.edu.cn mydb1
********* QUERY **********
BEGIN; SELECT usesuper FROM pg_catalog.pg_user WHERE usename = 'postgres'; COMMIT
**************************

欢迎来到 psql 7.3.2, PostgreSQL 的交互终端.

键入:  \copyright 获取发布信息
       \h 获取 SQL 命令的帮助
       \? 获取内部反斜扛命令的帮助
       \g 或者以分号结尾执行查询
       \q 退出

mydb1=# \help
Available help:
  ABORT                     CREATE TABLE              EXECUTE
  ALTER DATABASE            CREATE TABLE AS           EXPLAIN
  ALTER GROUP               CREATE TRIGGER            FETCH
  ALTER TABLE               CREATE TYPE               GRANT
  ALTER TRIGGER             CREATE USER               INSERT
  ALTER USER                CREATE VIEW               LISTEN
  ANALYZE                   DEALLOCATE                LOAD
  BEGIN                     DECLARE                   LOCK
  CHECKPOINT                DELETE                    MOVE
  CLOSE                     DROP AGGREGATE            NOTIFY
  CLUSTER                   DROP CAST                 PREPARE
  COMMENT                   DROP CONVERSION           REINDEX
  COMMIT                    DROP DATABASE             RESET
  COPY                      DROP DOMAIN               REVOKE
  CREATE AGGREGATE          DROP FUNCTION             ROLLBACK
  CREATE CAST               DROP GROUP                SELECT
  CREATE CONSTRAINT TRIGGER DROP INDEX                SELECT INTO
  CREATE CONVERSION         DROP LANGUAGE             SET
  CREATE DATABASE           DROP OPERATOR CLASS       SET CONSTRAINTS
  CREATE DOMAIN             DROP OPERATOR             SET SESSION AUTHORIZATION
  CREATE FUNCTION           DROP RULE                 SET TRANSACTION
  CREATE GROUP              DROP SCHEMA               SHOW
  CREATE INDEX              DROP SEQUENCE             START TRANSACTION
  CREATE LANGUAGE           DROP TABLE                TRUNCATE
  CREATE OPERATOR CLASS     DROP TRIGGER              UNLISTEN
  CREATE OPERATOR           DROP TYPE                 UPDATE
  CREATE RULE               DROP USER                 VACUUM
  CREATE SCHEMA             DROP VIEW
  CREATE SEQUENCE           END
mydb1=# select * from table_tamplate ;
sname  |    sadds     |    sphon     |      semail
--------+--------------+--------------+------------------
小布时 | 纽约州纽约镇 | 010-84452484 | 小布时@美国.纽约
普京   | 莫斯科镇     | 020-12345678 | 普京@俄国.莫斯科
布莱尔 | 伦敦镇       | 030-12345678 | 布莱尔@英国.伦敦
希拉克 | 巴黎镇       | 040-12345678 | 希拉克@法国.巴黎
(4 行)

mydb1=# create table president() inherits(table_tamplate);
CREATE TABLE
mydb1=# select * from president ;
sname | sadds | sphon | semail
-------+-------+-------+--------
(0 行)

mydb1=# \help create view
命令:     CREATE VIEW
描述:     define a new view
语法:
CREATE [ OR REPLACE ] VIEW view [ ( column name list ) ] AS SELECT query

mydb1=# create view v_president(name,adds,phon,email) as select p.sname,p.sadds,p.sphon,p.semail from president p;
CREATE VIEW
mydb1=# select * from v_president ;
name | adds | phon | email
------+------+------+-------
(0 行)

mydb1=# insert into v_president values ('金大中','汉城','050-12345678','金大中@韩国.汉城');
错误:  Cannot insert into a view
        You need an unconditional ON INSERT DO INSTEAD rule
mydb1=# 呵呵,,看来视图目前是不能插入数据的,那么,只好用规则了!;

mydb1=# create rule r_insert_v_president AS ON insert TO v_president do instead
mydb1-# insert into president(sname,sadds,sphon,semail) values(new.name,new.adds,new.phon,email);
错误:  Attribute "email" not found
mydb1=# create rule r_insert_v_president AS ON insert TO v_president do instead
mydb1-# insert into president(sname,sadds,sphon,semail) values(new.name,new.adds,new.phon,new.email);
CREATE RULE
mydb1=# insert into v_president values ('金大中','汉城','050-12345678','金大中@韩国.汉城');
INSERT 17287 1
mydb1=# select * from v_president ;
  name  | adds |     phon     |      email
--------+------+--------------+------------------
金大中 | 汉城 | 050-12345678 | 金大中@韩国.汉城
(1 行)

mydb1=# select * from president ;
sname  | sadds |    sphon     |      semail
--------+-------+--------------+------------------
金大中 | 汉城  | 050-12345678 | 金大中@韩国.汉城
(1 行)

mydb1=# 呵呵,现在可以插入数据了!再来改写、删除!

mydb1=# create rule r_delete_v_president AS ON delete TO v_president do instead
mydb1-# delete from president where sname=old.name;
CREATE RULE
mydb1=# delete from v_president where name ~ '^金';
DELETE 1
mydb1=# select * from v_president ;
name | adds | phon | email
------+------+------+-------
(0 行)

mydb1=# select * from president ;
sname | sadds | sphon | semail
-------+-------+-------+--------
(0 行)

mydb1=# 看来删除是没有问题了!来更新!
mydb1=# create rule r_update_v_president AS ON update TO v_president do instead
mydb1-# update president set sname=new.name,sadds=new.adds,sphon=new.phon,semail=new.email
mydb1-# where sname=new.name;
CREATE RULE
mydb1=# insert into v_president values ('金大中','汉城','050-12345678','金大中@韩国.汉城');
INSERT 17290 1
mydb1=# select * from v_president ;
  name  | adds |     phon     |      email
--------+------+--------------+------------------
金大中 | 汉城 | 050-12345678 | 金大中@韩国.汉
(1 行)

mydb1=# select * from president ;
sname  | sadds |    sphon     |      semail
--------+-------+--------------+------------------
金大中 | 汉城  | 050-12345678 | 金大中@韩国.汉
(1 行)

mydb1=# update v_president set email='金大中@汉城.韩国' where;
UPDATE 1
mydb1=# select * from v_president ;
  name  | adds |     phon     |      email
--------+------+--------------+------------------
金大中 | 汉城 | 050-12345678 | 金大中@汉城.韩国
(1 行)

mydb1=# select * from president ;
sname  | sadds |    sphon     |      semail
--------+-------+--------------+------------------
金大中 | 汉城  | 050-12345678 | 金大中@汉城.韩国
(1 行)

mydb1=# 好了,现在我们的视图 v

mydb1=# 好了,现在我们的视图可以查询、插入、修改、删除数据了!用规则还可以做触发器!;
mydb1=#

linux

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1664
14
PHP Tutorial
1268
29
C# Tutorial
1246
24
MySQL and PostgreSQL: Performance comparison and optimization tips MySQL and PostgreSQL: Performance comparison and optimization tips Jul 13, 2023 pm 03:33 PM

MySQL and PostgreSQL: Performance Comparison and Optimization Tips When developing web applications, the database is an indispensable component. When choosing a database management system, MySQL and PostgreSQL are two common choices. They are both open source relational database management systems (RDBMS), but there are some differences in performance and optimization. This article will compare the performance of MySQL and PostgreSQL and provide some optimization tips. Performance comparison comparing two database management

MySQL and PostgreSQL: Best Practices in Web Development MySQL and PostgreSQL: Best Practices in Web Development Jul 14, 2023 pm 02:34 PM

MySQL and PostgreSQL: Best Practices in Web Development Introduction: In the modern world of web development, databases are an essential component. When choosing a database, common choices are MySQL and PostgreSQL. This article will cover best practices for using MySQL and PostgreSQL in web development and provide some code examples. 1. Applicable scenarios MySQL is suitable for most web applications, especially those that require high performance, scalability and ease of use.

MySQL and PostgreSQL: Data Security and Backup Strategies MySQL and PostgreSQL: Data Security and Backup Strategies Jul 13, 2023 pm 03:31 PM

MySQL and PostgreSQL: Data Security and Backup Strategies Introduction: In modern society, data has become an indispensable part of business and personal life. For database management systems, data security and backup strategies are crucial, both to protect data from loss or damage and to ensure the reliability and integrity of recovered data. This article will focus on the data security and backup strategies of two mainstream relational database systems, MySQL and PostgreSQL. 1. Data security: (1) User rights

Learn database functions in Go language and implement addition, deletion, modification and query operations of PostgreSQL data Learn database functions in Go language and implement addition, deletion, modification and query operations of PostgreSQL data Jul 31, 2023 pm 12:54 PM

Learn the database functions in the Go language and implement the addition, deletion, modification, and query operations of PostgreSQL data. In modern software development, the database is an indispensable part. As a powerful programming language, Go language provides a wealth of database operation functions and toolkits, which can easily implement addition, deletion, modification and query operations of the database. This article will introduce how to learn database functions in Go language and use PostgreSQL database for actual operations. Step 1: Install the database driver in Go language for each database

MySQL and PostgreSQL: How to optimize database query performance? MySQL and PostgreSQL: How to optimize database query performance? Jul 12, 2023 pm 03:15 PM

MySQL and PostgreSQL: How to optimize database query performance? Overview: Database query performance is an important consideration when developing applications. Good query performance improves application responsiveness and user experience. This article will introduce some methods to optimize database query performance, focusing on two commonly used databases, MySQL and PostgreSQL. Optimization of database indexes: Database indexes are an important factor in improving query performance. Indexes can speed up data search and reduce query scanning time.

How to use PostgreSQL database in PHP programming? How to use PostgreSQL database in PHP programming? Jun 12, 2023 am 09:27 AM

With the development of database technology, database management systems also present a variety of choices. Developers can choose the most suitable database according to their needs and preferences. As an advanced open source relational database system, PostgreSQL is attracting more and more attention and use by developers. So, how to use PostgreSQL database in PHP programming? 1. Install and configure the PostgreSQL database. Before using PostgreSQL, you need to install and configure it. first

Database capacity planning and scaling: MySQL vs. PostgreSQL Database capacity planning and scaling: MySQL vs. PostgreSQL Jul 12, 2023 pm 01:43 PM

Database capacity planning and expansion: MySQL vs. PostgreSQL Introduction: With the rapid development of the Internet and the advent of the big data era, database capacity planning and expansion has become increasingly important. MySQL and PostgreSQL are two popular relational database management systems (RDBMS). They have different characteristics and applicable scenarios in database capacity planning and expansion. This article will compare the two databases and give some code examples to demonstrate their differences. 1. MySQ

Using PostgreSQL in Go: The Complete Guide Using PostgreSQL in Go: The Complete Guide Jun 18, 2023 am 09:28 AM

Go language is a fast and efficient programming language suitable for building web services and back-end applications. PostgreSQL is an open source relational database management system that promises to provide higher reliability, scalability and data security. In this article, we’ll take a deep dive into using PostgreSQL with Go and provide some practical code examples and tips. Installing and setting up PostgreSQL First, we need to install and set up PostgreSQL. Can be found on the official website

See all articles