Atitit.code base view 視圖的實現原理

来源:http://www.cnblogs.com/attilax/archive/2016/02/27/5223403.html
-Advertisement-
Play Games

Atitit.code base view 視圖的實現原理 1. 視圖的執行演算法:1 2. 不可更新的視圖:1 3. 關於視圖的可插入性:insert2 4. 視圖定義3 5. 調用3 1. 視圖的執行演算法: 存在兩種執行演算法: 1、 Merge:合併的執行方式,每當執行的時候,先將我們視圖的sql


Atitit.code base view 視圖的實現原理

 

1視圖的執行演算法:1

2不可更新的視圖:1

3關於視圖的可插入性:insert2

4視圖定義3

5調用3

 

1. 視圖的執行演算法:

存在兩種執行演算法:

1  Merge:合併的執行方式,每當執行的時候,先將我們視圖的sql語句與外部查詢視圖的sql語句,混合在一起,最終執行;

2  Temptable:臨時表模式,每當查詢的時候,將視圖所使用的select語句生成一個結果的臨時表,再在當前的臨時表內進行查詢。

指的是一個視圖是在什麼時候執行,依據哪些方式執行;

對於MERGE,會將引用視圖的語句的文本與視圖定義合併起來,使得視圖定義的某一部分取代語句的對應部分。

 

對於TEMPTABLE,視圖的結果將被置於臨時表中,然後使用它執行語句。

 

對於UNDEFINEDMySQL將選擇所要使用的演算法。如果可能,它傾向於MERGE而不是TEMPTABLE,這是因為MERGE通常更有效,而且如果使用了臨時表,視圖是不可更新

 

當用戶創建視圖時,mysql預設使用一種undefine的處理演算法,就是會自動在合併和臨時表內進行選擇。

 

作者:: 綽號:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿爾 拉帕努伊 ) 漢字名:艾龍,  EMAIL:[email protected]

轉載請註明來源: http://www.cnblogs.com/attilax/

 

2. 不可更新的視圖:

某些視圖是可更新的。也就是說,可以在諸如UPDATEDELETEINSERT等語句中使用它們,以更新基表的內容。對於可更新的視圖,在視圖中的行和基表中的行之間必須具有一對一的關係。還有一些特定的其他結構,這類結構會使得視圖不可更新。更具體地講,如果視圖包含下述結構中的任何一種,那麼它就是不可更新的:

 

·         聚合函數(SUM(), MIN(), MAX(), COUNT()等)。

 

·         DISTINCT

 

·         GROUP BY

 

·         HAVING

 

·         UNIONUNION ALL

 

·         位於選擇列表中的子查詢

 

·         Join

 

·         FROM子句中的不可更新視圖

 

·         WHERE子句中的子查詢,引用FROM子句中的表。

 

·         僅引用文字值(在該情況下,沒有要更新的基本表)。

 

·         ALGORITHM = TEMPTABLE(使用臨時表總會使視圖成為不可更新的)。

3. 關於視圖的可插入性:insert

如果視圖滿足關於視圖列的下述額外要求,可更新的視圖也是可插入的:

·         不得有重覆的視圖列名稱。

·         視圖必須包含沒有預設值的基表中的所有列。

·         視圖列必須是簡單的列引用而不是導出列。導出列不是簡單的列引用,而是從表達式導出的。下麵給出了一些導出列示例:

·                3.14159

·                col1 + 3

·                UPPER(col2)

·                col3 / col4

·                (subquery)

混合了簡單列引用和導出列的視圖是不可插入的,但是,如果僅更新非導出列,視圖是可更新的。

4. 視圖定義

wxb_order

#left join tabxxx on order_id=order_id

wxb_order_count,order_id=order_id

 

 

5. 調用

 

public List<String> insertSql(Map m) {

List<String> li = Lists.newArrayList();

if (m.get("$tabletype") != null && m.get("$tabletype").equals("view")) {

String[] tabs = new View(m.get("$table"), m.get("$view_store_path"))

.getTables();

for (String tab : tabs) {

Map m2 = MapX.clone(m);

m2.put("$table"tab);

String s = get_insert_singleTable_sql(m2);

li.add(s);

}

 

return li;

}

return li;

}

 

 

package com.attilax.orm;

 

import java.util.Map;

 

import com.attilax.io.filex;

import com.attilax.io.pathx;

import com.attilax.sql.SqlJoinAst;

import com.attilax.sql.SqlJoinParser;

 

public class View {

 

private Object obj;

private Object viewStorePath;

 

public View(String viewName) {

// TODO Auto-generated constructor stub

}

 

public View(Object objectName) {

this.obj = objectName;

}

 

public View(Object objectName, Object viewStorePath) {

this.obj = objectName;

this.viewStorePath = viewStorePath;

}

 

public String[] getTables() {

String f = pathx.classPath() + "/" + this.viewStorePath + "/"

+ obj.toString() + ".txt";

// String t=filex.read(f);

SqlJoinAst ast = new SqlJoinParser().parse(f);

String tabs = ast.table;

for (Map join_tab : ast.joinTables) {

tabs = tabs + "," + join_tab.get("joinTable");

}

return tabs.split(",");

}

 

}

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 機器學習 視頻教程 數據挖掘 實戰 開發 應用 演算法 案例 R語言 Hadoop、Redis、Memcached、MongoDB、Spark、Storm、雲計算、R語言、機器學習、Nginx、Linux、MySQL、Java EE、.NET、PHP
  • Hadoop、Redis、Memcached、MongoDB、Spark、Storm、雲計算、R語言、機器學習、Nginx、Linux、MySQL、Java EE、.NET、PHP Hadoop 視頻教程 大數據 高性能 集群 NoSQL 實戰 權威 入門 安裝
  • SQL優化的最終目的是用戶體驗-在最短時間內讓用戶在頁面數據。因此,執行時間是SQL優化的重要指標。在SQL查詢中,I/O操作最占系統性能的。I/O操作量越大,時間越久。減少I/O操作量是優化SQL的目標。同時,CPU,緩存命中率也很重要。 並不是所有SQL都需要被優化,使用頻率高,性能差的SQL語
  • 關於sqlnet.ora的參數SQLNET.INBOUND_CONNECT_TIMEOUT,它表示等待用戶認證超時的時間,單位是秒,預設值是60秒,如果用戶認證超時了,伺服器日誌alert.log顯示出錯信息"WARNING: inbound connection timed out (ORA-31...
  • Hadoop安裝 Hadoop安裝 Hive元數據三種存儲方式 Derby:hive預設的存儲模式,不可以併發調用hive 本地MySQL 遠程MySQL 採用第二種方式,安裝MySQL,啟動並創建Hive用戶,創建Hive元資料庫 insert into mysql.user(Host,User,...
  • 我們開發了一個會員管理系統,隨著使用的人越來越多,異地備份資料庫就顯得十分重要,萬一硬碟出問題了怎麼辦呢.所以就著手做這個工作. 首先呢,找到了幾個專門用來提供備份資料庫的網站,一年好幾百,好貴.放棄這個方案. 然後想到了辦法,如果備份到百度雲上是不是就很好呢.超大的空間.嘗試了一下,需要分三步:
  • ORACLE的執行計劃分為預估執行計劃和實際執行計劃。其中,你用Toad、PL/SQL Developer、SQL Developer、EXPLAIN PLAN FOR或者SET ATUOTRACE TRACEONLY等獲取的執行計劃都是預估的執行計劃。有時候預估執行計劃和實際執行計劃有很大的差別,...
  • atitit.atiOrmStoreService 框架的原理與設計 part1 概述與新特性 1. 新特性如下 支持生成sql在無資料庫連接的情況下 2. Orm設計 主要的倆個以來service如下 @Inject Dsl2sqlService dsl2sqlSvr; @Inject DBX d
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...