bitsCN.com
MSSQL中视图的架构绑定(SCHEMABINGDING)与视图批量更新
CREATE VIEW 的语法如下
CREATE VIEW [ schema_name . ] view_name [ (column [ ,...n ] ) ]
[ WITH
AS select_statement
[ WITH CHECK OPTION ] [ ; ]
{
[ ENCRYPTION ]
[ SCHEMABINDING ]
[ VIEW_METADATA ] }
其中 SCHEMABINDING表示对基表进行修改时不能影响到该视图的定义,若对基本的修改影响力该视图的定义,则要求先删除该视图。
使用 SCHEMABINDING要求视图的定义中不能进行 SELECT * 查询,而且基表名称必须包含架构名称(两部分命名).
下面进行样例解释了架构绑定与非架构绑定的区别.
首先创造基表,语句如下:
CREATE TABLE T1
(
Id int primary key,
Name nvarchar(200),
Address nvarchar(200)
)
CREATE TABLE T2
(
Id int primary key,
Name nvarchar(200),
Address nvarchar(200)
)
然后创建两个视图,一个进行架构绑定,另一个不进行架构绑定
CREATE VIEW v_T1
AS
SELECT Id, Name, Address FROM T1;
GO
CREATE VIEW v_T2
WITH SCHEMABINDING
AS
SELECT Id, Name, Address FROM dbo.T2;
GO
此时我要对基表的结构进行修改,例如删除字段Address,删除T1的Address字段是可以的,但删除T2的Address字段是不允许的。
下面我们还用T1作为基表使用SELECT * 语法创建视图
CREATE VIEW v_T1
AS
SELECT * FROM T1;
GO
创建视图后再对基表进行修改,添加了字段Email,如下
ALTER TABLE T1 ADD Email nvarchar(20)
但此时对视图v_T1进行查询,Email列是不显示的
必须对视图v_T1进行更新后,才能显示Email列,我们可以对v_T1删除后重建
IF OBJECT_ID('v_T1') IS NOT NULL
DROP VIEW v_T1
GO
CREATE VIEW v_T1
AS
SELECT * FROM T1;
GO
或者使用 sp_refreshview 系统存储过程,代码如下
sp_refreshview 'v_T1'
若系统中有大量的视图需要更新,则下面的代码可以对所有没有进行架构绑定的视图进行批量更新
DECLARE @sql AS nvarchar(max)
SET @sql = ''
SELECT @sql = @sql + 'exec sp_refreshview' + QUOTENAME(TABLE_NAME, '''')+ '; '
FROM INFORMATION_SCHEMA.VIEWS
WHERE OBJECTPROPERTY(OBJECT_ID(TABLE_NAME), 'IsSchemaBound') = '0'
EXEC sp_executesql @sql
bitsCN.com

MySQLは、初心者がデータベーススキルを学ぶのに適しています。 1.MySQLサーバーとクライアントツールをインストールします。 2。selectなどの基本的なSQLクエリを理解します。 3。マスターデータ操作:テーブルを作成し、データを挿入、更新、削除します。 4.高度なスキルを学ぶ:サブクエリとウィンドウの関数。 5。デバッグと最適化:構文を確認し、インデックスを使用し、選択*を避け、制限を使用します。

MySQLは、テーブル構造とSQLクエリを介して構造化されたデータを効率的に管理し、外部キーを介してテーブル間関係を実装します。 1.テーブルを作成するときにデータ形式と入力を定義します。 2。外部キーを使用して、テーブル間の関係を確立します。 3。インデックス作成とクエリの最適化により、パフォーマンスを改善します。 4.データベースを定期的にバックアップおよび監視して、データのセキュリティとパフォーマンスの最適化を確保します。

MySQLは、Web開発で広く使用されているオープンソースリレーショナルデータベース管理システムです。その重要な機能には、次のものが含まれます。1。さまざまなシナリオに適したInnodbやMyisamなどの複数のストレージエンジンをサポートします。 2。ロードバランスとデータバックアップを容易にするために、マスタースレーブレプリケーション機能を提供します。 3.クエリの最適化とインデックスの使用により、クエリ効率を改善します。

SQLは、MySQLデータベースと対話して、データの追加、削除、変更、検査、データベース設計を実現するために使用されます。 1)SQLは、ステートメントの選択、挿入、更新、削除を介してデータ操作を実行します。 2)データベースの設計と管理に作成、変更、ドロップステートメントを使用します。 3)複雑なクエリとデータ分析は、ビジネス上の意思決定効率を改善するためにSQLを通じて実装されます。

MySQLの基本操作には、データベース、テーブルの作成、およびSQLを使用してデータのCRUD操作を実行することが含まれます。 1.データベースの作成:createdatabasemy_first_db; 2。テーブルの作成:createTableBooks(idintauto_incrementprimarykey、titlevarchary(100)notnull、authorvarchar(100)notnull、published_yearint); 3.データの挿入:InsertIntoBooks(タイトル、著者、公開_year)VA

WebアプリケーションにおけるMySQLの主な役割は、データを保存および管理することです。 1.MYSQLは、ユーザー情報、製品カタログ、トランザクションレコード、その他のデータを効率的に処理します。 2。SQLクエリを介して、開発者はデータベースから情報を抽出して動的なコンテンツを生成できます。 3.MYSQLは、クライアントサーバーモデルに基づいて機能し、許容可能なクエリ速度を確保します。

MySQLデータベースを構築する手順には次のものがあります。1。データベースとテーブルの作成、2。データの挿入、および3。クエリを実行します。まず、createdAtabaseおよびcreateTableステートメントを使用してデータベースとテーブルを作成し、InsertINTOステートメントを使用してデータを挿入し、最後にSelectステートメントを使用してデータを照会します。

MySQLは、使いやすく強力であるため、初心者に適しています。 1.MYSQLはリレーショナルデータベースであり、CRUD操作にSQLを使用します。 2。インストールは簡単で、ルートユーザーのパスワードを構成する必要があります。 3.挿入、更新、削除、および選択してデータ操作を実行します。 4. Orderby、Where and Joinは複雑なクエリに使用できます。 5.デバッグでは、構文をチェックし、説明を使用してクエリを分析する必要があります。 6.最適化の提案には、インデックスの使用、適切なデータ型の選択、優れたプログラミング習慣が含まれます。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

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

WebStorm Mac版
便利なJavaScript開発ツール

Dreamweaver Mac版
ビジュアル Web 開発ツール

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