SQLServer之修改視圖

来源:https://www.cnblogs.com/vuenote/archive/2018/10/29/9869227.html
-Advertisement-
Play Games

修改視圖註意事項 修改先前創建的視圖。 其中包括索引視圖。 ALTER VIEW不影響相關的存儲過程或觸發器,並且不會更改許可權。 如果原來的視圖定義是使用 WITH ENCRYPTION 或 CHECK OPTION創建的,則只有在 ALTER VIEW 中也包含這些選項時,才會啟用這些選項。 如果 ...


修改視圖註意事項

修改先前創建的視圖。 其中包括索引視圖。 ALTER VIEW不影響相關的存儲過程或觸發器,並且不會更改許可權。

如果原來的視圖定義是使用 WITH ENCRYPTION 或 CHECK OPTION創建的,則只有在 ALTER VIEW 中也包含這些選項時,才會啟用這些選項。

如果當前所用的視圖使用 ALTER VIEW 來修改,則資料庫引擎使用對該視圖的排他架構鎖。 在授予鎖時,如果該視圖沒有活動用戶,則資料庫引擎將從過程緩存中刪除該視圖的所有副本。 引用該視圖的現有計劃將繼續保留在緩存中,但一旦被調用就會重新編譯。

ALTER VIEW可應用於索引視圖,但是,ALTER VIEW會無條件地刪除視圖的所有索引。

若要執行 ALTER VIEW,至少需要具有對 OBJECT 的 ALTER 許可權。

使用SSMS資料庫管理工具修改視圖

1、連接資料庫,選擇資料庫,展開資料庫-》展開視圖-》選擇要修改的視圖-》選擇設計。

2、在關係圖窗格中-》修改視圖-》修改完成,點擊保存。

3、使用修改的視圖。

使用T-SQL腳本修改視圖

語法:

--聲明資料庫引用
use 資料庫名;
go

--修改視圖
alter view [架構名][.]視圖名
with encryption,schemabinding,view_metadata
as
select_statement
[check option];
go

語法解析:

schema_name
視圖所屬架構的名稱。

view_name
要更改的視圖。

column
將成為指定視圖的一部分的一個或多個列的名稱(以逗號分隔)。

encryption
適用範圍: SQL Server 2008 到 SQL Server 2017 和 Azure SQL Database。

加密 sys.syscomments 中包含 ALTER VIEW 語句文本的項。 WITH ENCRYPTION 可防止視圖作為 SQL Server 複製的一部分進行發佈。

schemabinding
將視圖綁定到基礎表的架構。 如果指定了 SCHEMABINDING,則不能以可影響視圖定義的方式來修改基表。 必須首先修改或刪除視圖定義本身,然後才能刪除要修改的表的相關性。 使用 SCHEMABINDING 時,select_statement 必須包含所引用的表、視圖或用戶定義函數的兩部分名稱 (schema.object)。 所有被引用對象都必須在同一個資料庫內。

不能刪除參與使用 SCHEMABINDING 子句創建的視圖的表或視圖,除非該視圖已被刪除或更改,而不再具有架構綁定。 否則, 資料庫引擎將引發錯誤。 另外,如果對參與具有架構綁定的視圖的表執行 ALTER TABLE 語句,而這些語句又會影響視圖定義,則這些語句將會失敗。

view_metadata
指定為引用視圖的查詢請求瀏覽模式的元數據時, SQL Server 實例將向 DB-Library、ODBC 和 OLE DB API 返回有關視圖的元數據信息,而不返回基表的元數據信息。 瀏覽模式的元數據是 資料庫引擎實例返回到客戶端 DB-Library、ODBC 和 OLE DB API 的額外元數據。 如果使用此元數據,客戶端 API 將可以實現可更新客戶端游標。 瀏覽模式的元數據包含結果集中的列所屬的基表的相關信息。

對於使用 VIEW_METADATA 創建的視圖,瀏覽模式的元數據在描述結果集內視圖中的列時,將返回視圖名,而不返回基表名。

使用 WITH VIEW_METADATA 創建視圖時,如果該視圖具有 INSERT 或 UPDATE INSTEAD OF 觸發器,則視圖的所有列(timestamp 列除外)都可更新。 有關詳細信息,請參閱 CREATE VIEW (Transact-SQL) 中的“註釋”部分。

as
視圖要執行的操作。

select_statement
定義視圖的 SELECT 語句。

with check option
要求對該視圖執行的所有數據修改語句都必須符合 select_statement 中所設置的條件。

示例:

--聲明資料庫引用
use testss;
go

--修改視圖
alter view dbo.view1
with encryption,schemabinding,view_metadata
as
select a.id,a.name,a.sex,a.height,b.id as classid
from dbo.test1 as a
inner join dbo.test3 as b on a.classid=b.id;
go

使用修改後的視圖

 


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

-Advertisement-
Play Games
更多相關文章
  • 1.查看資料庫歸檔和閃回狀態,及環境準備SQL> archive log list;SQL> select flashback_on from v$database;關閉資料庫,啟動歸檔和閃回SQL> shutdown immediate;啟動到mount模式SQL> startup mount;開 ...
  • 一. 概述 在上一篇中,搭建了一主一從的複製架構,這篇通過一些診斷方法來瞭解複製的運行狀態和一些選項參數說明。上次mysql主從服務關機,今天在打開mysql服務,出現了錯誤信息。 1.首先 啟動主從mysql服務 2.在從庫上執行START SLAVE, 開始複製。 3.在從庫上執行SHOW PR ...
  • 註意:本地MySQL服務要開啟 更新整個資料庫 1、將正式伺服器上的資料庫做備份 登錄到正式伺服器,執行如下命令:(註意空格) mysqldump -uroot –p密碼 資料庫名 -P 介面 --default-character-set=gbk --opt -Q -R --skip-lock-t ...
  • 介紹 這篇隨筆主要介紹MySQL的基礎API的使用姿勢 基本使用姿勢: 第一步:登陸資料庫 第二步:建立MySqlCommand對象然後進行增刪改查 建立MySqlDataReader對象-讀取查詢結果 使用: 註釋:(為了放置SQL註入,可以使用參數的方式進行傳參,執行上沒有差別) SQL可以查詢 ...
  • 前言 只有光頭才能變強 最近在學Redis,我相信只要是接觸過Java開發的都會聽過Redis這麼一個技術。面試也是非常高頻的一個知識點,之前一直都是處於瞭解階段。秋招過後這段時間是沒有什麼壓力的,所以打算系統學學Redis,這也算是我從零學習Redis的筆記吧。 本文 力求講清每個知識點 ,希望大 ...
  • Storm學習筆記 消息容錯機制 文章來自「隨筆」 http://jsynk.cn/blog/articles/153.html 1. Storm消息容錯機制概念 一個提供了可靠的處理機制的spout需要記錄自己emit(發射)的tuple(消息元祖),當下游bolt處理tuple或者子tuple失 ...
  • 目錄 簡介 安裝啟動 許可權 事務 臟讀、不可重覆讀、幻讀 MVCC 複製 非同步複製 半同步複製 GTID複製 集群(Galera) 配置 監控(Zabbix) 簡介 環境: CentOS 7.4.1708 MariaDB 10.3.9 簡介: MySQL 由 MySQLAB 公司開發。 MariaD ...
  • 零基礎的同學學習大數據開發不能急於求成,要分階段分步驟來一步步完成,科多大數據給大家來分享一下大數據的學習路線是什麼?小白該怎麼學習大數據呢,大概可以分為四步:第一個階段:瞭解大數據的基本概念 首先,學習一門課程的時候,要對這門課程有一個簡單的瞭解,比如說,要先學習這門課程的 一些專業的術語,學習一 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...