oracle view
视图 视图具有以下优点 1、限制用户只能通过视图检索数据。这样就可以对最终用户屏蔽创建视图所基于的底层基表。 2、可以将复杂查询编写为视图。这样可以对最终用户屏蔽一定的复杂性。 3、限制某个视图只能访问基表中的部分数据,这样可以实现另外一层安全性
视图视图具有以下优点
1、限制用户只能通过视图检索数据。这样就可以对最终用户屏蔽创建视图所基于的底层基表。
2、可以将复杂查询编写为视图。这样可以对最终用户屏蔽一定的复杂性。
3、限制某个视图只能访问基表中的部分数据,这样可以实现另外一层安全性,并且可以对最终用户屏蔽部分行。
CREATE [OR REPLACE] VIEW [ { FORCE | NOFORCE }] view_name
[ (alias_name[,alias_name ...])] AS subquery
[ WITH { CHECK OPTION | READ ONLY } CONSTRAINT constraint_name];
其中OR REPLACE 说明如果视图已经存在,就替换现有视图。
FROCE 说明即使基表不存在,也要创建视图,
NOFORCE 说明如果基表不存在,就不创建视图,NOFORCE是默认值。
subquery指定一个子查询。
WIHT CHECK OPTION 说明只有子查询检索的行才能被插入,修改、删除。默认情况下,在插入、修改、删除行之前不会检索这些行是否被子查询检索
WIHT READ ONLY 说明只能对基表中的行进行只读访问。
--简单视图
CREATEVIEW v_cheap_products1
AS
SELECT *
FROM products
WHERE price15;
CREATE VIEW v_employees
AS
SELECTemployee_id,manager_id,first_name,last_name,title
FROM employees;
--对视图执行insert操作
INSERTINTO v_cheap_products1 (
product_id,product_type_id,name,price
) values (
12,1,'Western Front',13.50
);
/**注意:只能对简单视图执行DML操作;复杂视图不支持DML操作.*****************/
--由于v_cheap_products没有使用WITH CHECK OPTION,因此可以插入、修改、删除那些子查询不能检索的行。
INSERTINTO v_cheap_products1 (
product_id,product_type_id,name,price
) values (
14,1,'Eastern Front',16.5
);
--以上插入了子查询不能检索的行,因此以下检索不到数据
SELECT *
FROMv_cheap_products
WHEREproduct_id =14;
--创建具有CHECK OPTION约束的视图:通过为视图添加CHECK OPTION约束,可以指定对视图执行DML操作必须满足子查询的条件。
CREATEVIEW v_cheap_products2
AS
SELECT *
FROM products
WHERE price
WITH CHECK OPTION CONSTRAINT cheap_products_v2_price;
--插入以下数据会报错
INSERTINTOv_cheap_products (
product_id,product_type_id,name,price
) values (
14,1,'Eastern Front',16.5
);
--创建只读视图:对于只读视图,不能对其执行DML操作
CREATEVIEW v_cheap_products3
AS
SELECT *
FROM products
WHERE price
WITH READ ONLY CONSTRAINT cheap_products_v3_price;
--创建复杂视图
CREATEVIEWv_products_and _types
AS
SELECT p.name product_name,pt.nameproduct_type_name,p.price
FROM products p FULL OUTER JOIN product_types pt
USING(product_type_id)
CREATEVIEWv_employee_salary_grades
AS
SELECT e.first_name, e.last_name, e.title, e.salary, sa.salary_grade_id
FROM employees e INNER JOINsalary_grades sg ON e.salary BETWEEN sg.low_salary AND sg.high_salary;
--下面这个例子创建视图v_product_average,子查询使用
/*WHERE 子句对products表中的行进行过滤,只保留那些价格低于$15的记录
GROUP BY子句对剩余的行根据product_type_id列进行分组
HAVING 子句对分组进行过滤,只保留那些平均价格低于$13的分组*/
CREATEVIEWv_product_average
AS
SELECTproduct_type_id,AVG(price) average_price
FROM products
WHERE price
GROUPBYproduct_type_id
HAVINGAVG(price) >13;
--修改视图CREATE OR REPLACE,使用ALTER VIEW可以修改视图的约束
CREATE OR REPLACE VIEW v_product_average
AS
SELECTproduct_type_id,AVG(price) average_price
FROM products
WHERE price
GROUPBYproduct_type_id
HAVINGAVG(price) >11;
--获取视图定义信息describe
DESC v_cheap_products3
--获取用户所创建的视图信息
select * from user_views;
--获取可以访问的视图信息
select * from all_views;
--获取有关视图的约束信息
select constraint_name,constraint_type,status
from user_constraints
where table_name in ('V_CHEAP_PRODUCTS1','V_CHEAP_PRODUCTS2');

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Oracle Tablespaceサイズを照会するには、次の手順に従ってください。クエリを実行して、TableSpace名を決定します。DBA_TABLESPACesからTableSpace_Nameを選択します。クエリを実行してテーブルスペースのサイズをクエリします:sum(bytes)をtotal_size、sum(bytes_free)asavail_space、sum(bytes) - sum(bytes_free)as sum(bytes_free)as dba_data_files from tablespace_

Oracleで時間を取得するには、次の方法があります。Current_Timestamp:現在のシステム時間を秒に正確に返します。 systimestamp:current_timestampよりも正確で、ナノ秒。 sysdate:時間部分を除く現在のシステム日付を返します。 to_char(sysdate、 'yyy-mm-dd hh24:mi:ss'):現在のシステムの日付と時刻を特定の形式に変換します。抽出:1年、月、時間など、時間の値から特定の部分を抽出します。

Oracleでインスタンス名を表示するには3つの方法があります。「sqlplus」と「v $ instanceからselect instance_name;」を使用します。」コマンドラインのコマンド。 「show instance_name;」を使用しますSQL*Plusのコマンド。オペレーティングシステムのタスクマネージャー、Oracle Enterprise Manager、またはオペレーティングシステムを介して、環境変数(LinuxのOracle_Sid)を確認してください。

Oracle View暗号化により、ビュー内のデータを暗号化でき、それにより機密情報のセキュリティが強化されます。手順には以下が含まれます。1)マスター暗号化キー(MEK)の作成。 2)暗号化されたビューを作成し、暗号化されるビューとMEKを指定します。 3)暗号化されたビューにアクセスすることをユーザーに許可します。暗号化されたビューがどのように機能するか:ユーザーが暗号化されたビューを求めてクエリをするとき、OracleはMEKを使用してデータを復号化し、認定ユーザーのみが読み取り可能なデータにアクセスできるようにします。

Oracleインストール障害のためのアンインストールメソッド:Oracleサービスを閉じ、Oracleプログラムファイルとレジストリキーを削除し、Oracle環境変数をアンインストールし、コンピューターを再起動します。アンインストールが失敗した場合、Oracle Universal Uninstallツールを使用して手動でアンインストールできます。

Oracle無効な数値誤差は、データ型の不一致、数値オーバーフロー、データ変換エラー、またはデータの破損によって引き起こされる場合があります。トラブルシューティング手順には、データ型のチェック、デジタルオーバーフローの検出、データ変換のチェック、データの破損のチェック、nls_numeric_charactersパラメーターの構成、データ検証ロギングの有効化など、他の可能なソリューションの調査が含まれます。

Oracleでユーザーを作成するには、次の手順に従ってください。Createユーザーステートメントを使用して新しいユーザーを作成します。助成金ステートメントを使用して必要な権限を付与します。オプション:リソースステートメントを使用してクォータを設定します。デフォルトの役割や一時テーブルスペースなど、他のオプションを構成します。

Oracle Cursorの閉鎖問題を解決する方法には、次のものが含まれます。 Scopeが終了した後に自動的に閉じるように、for update句のカーソルを宣言します。使用句のカーソルを宣言して、関連するPL/SQL変数が閉じられたときに自動的に閉じるようにします。例外処理を使用して、例外の状況でカーソルが閉じていることを確認します。接続プールを使用して、カーソルを自動的に閉じます。自動送信を無効にし、カーソルの閉鎖を遅延させます。
