日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

数据库中的基础知识

發布時間:2025/3/21 数据库 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数据库中的基础知识 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1.觸發器 理解:對于某個表,觸發某種條件而執行的一段SQL代碼,?常見的觸發器有三種:分別應用于Insert?,?Update?,?Delete?事件。 觸發器是一中特殊的存儲過程,主要是通過事件來觸發而被執行的。它可以強化約束,來維護數據的完整性和一致性,可以跟蹤數據庫內的操作從而不允許未經許可的更新和變化。可以聯級運算。如,某表上的觸發器上包含對另一個表的數據操作,而該操作? ? ? ? ? ? 又會導致該表觸發器被觸發。 實例:1先建兩張數據表:Users表,Students表 2創建觸發器

CREATE TABLE [dbo].[Users](
[StudentID] [INT] IDENTITY(1,1) NOT NULL,
[Name] [VARCHAR](50) NULL,
CONSTRAINT [PK_Users] PRIMARY KEY CLUSTERED
(
[StudentID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]

GO

CREATE TABLE [dbo].[Students](
[id] [INT] IDENTITY(1,1) NOT NULL,
[Name] [VARCHAR](50) NULL,
CONSTRAINT [PK_Students] PRIMARY KEY CLUSTERED
(
[id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]

--創建觸發器 Insert?
CREATE trigger tg_InsertStudent
on Students --更新Students時
for INSERT --觸發insert方法
as
INSERT dbo.Users(Name)VALUES ( (SELECT TOP 1 Name FROM dbo.Students ORDER BY id desc) ) --更新Students,所觸發執行SQL

--當在Students表中添加數據時觸發觸發器,同時Users標也會更新 (向student表中添加數據時,users中也會添加數據)
INSERT dbo.Students
( Name )
VALUES ( '大雪' -- Name - varchar(50)
)

--創建觸發器 Delete

CREATE TRIGGER tg_DeleteStudent
ON Students
FOR DELETE
AS
SELECT Name from deleted

Students表中數據:

刪除students表數據,觸發器中執行查詢刪除數據,結果:

?

--創建觸發器Update
CREATE TRIGGER tg_UpdateStudent
ON Students
FOR UPDATE
AS
IF UPDATE(Name)
BEGIN
PRINT '修改的Name'
END;

Students表中數據:

修改students表數據,觸發器中打印print,結果:

UPDATE dbo.Students SET Name='修改' WHERE id=14

?

2。存儲過程 理解:存儲過程是一個預編譯的SQL語句,優點是允許模塊化的設計,就是說只需創建一次,以后在該程序中就可以調用多次。如果某次操作需要執行多次SQL,使用存儲過程比單純SQL語句執行要快。可以用一個命令對象來調用存儲過程。用分頁實例說明:

ALTER?PROC [dbo].[proc_PageData]? --創建存儲
( --聲明參數
@pageIndex INT = 1,
@pageSize INT = 10,
@icount INT = 0 OUTPUT --輸出參數符合條件總記錄數
)
AS
BEGIN
DECLARE @pageCount INT;
DECLARE @straccount NVARCHAR(4000);
SET @pageCount=(@pageIndex-1)*@pageSize;

WITH tt AS (
SELECT ROW_NUMBER() OVER(ORDER BY CreateDate ASC) RowId,* FROM dbo.test
)
SELECT TOP (@pageSize) * FROM tt WHERE RowId>@pageCount;

SELECT @icount=COUNT(1) FROM dbo.test;
END;
GO

https://www.cnblogs.com/doudouxiaoye/p/5804467.html

對于使用存儲過程封裝業務邏輯的好處,歸納起來有以下幾點:

1、執行速度快。因為存儲過程不需要解析。預先編譯了

2、安全性。避免了sql注入(不是絕對的),避免了暴露表結構和字段

3。索引的作用?和它的優點缺點是什么? 理解:索引就一種特殊的查詢表,數據庫的搜索引擎可以利用它加速對數據的檢索。它很類似與現實生活中書的目錄,不需要查詢整本書內容就可以找到想要的數據。索引可以是唯一的,創建索引允許指定單個列或者是多個列。缺點是它減慢了數據錄入的速度,同時也增加了數據庫的尺寸大小。

創建表(沒有主鍵):

CREATE TABLE [dbo].[userT](
[ID] [INT] IDENTITY(1,1) NOT NULL,
[name] [NCHAR](10) NULL,
[userid] [INT] NULL
) ON [PRIMARY]

造數據1000000條

DECLARE @i INT = 0
DECLARE @name VARCHAR(50) = '第'
WHILE @i<1000000
BEGIN
SET @i=@i+1
INSERT INTO dbo.userT
( name, userid )
VALUES ( '第'+CONVERT(VARCHAR(50),@i), -- name - nchar(10)
@i -- userid - int
)
END

數據庫中現在沒有索引

創建索引

CREATE INDEX userid_Index
ON dbo.userT(userid)

表中userid上建立了索引,所以執行計劃中是索引查找:

?

4。什么是事務?什么是鎖? 答:事務就是被綁定在一起作為一個邏輯工作單元的SQL語句分組,如果任何一個語句操作失敗那么整個操作就被失敗,以后操作就會回滾到操作前狀態,或者是上有個節點。為了確保要么執行,要么不執行,就可以使用事務。要將有組語句作為事務考慮,就需要通過ACID測試,即原子性,一致性,隔離性和持久性。 鎖:在DBMS中,鎖是實現事務的關鍵,鎖可以保證事務的完整性和并發性。與現實生活中鎖一樣,它可以使某些數據的擁有者,在某段時間內不能使用某些數據或數據結構。當然鎖還分級別的。 5。什么叫視圖?游標是什么? 答:視圖是一種虛擬的表,具有和物理表相同的功能。可以對視圖進行增,改,查,操作,視圖通常是有一個表或者多個表的行或列的子集。對視圖的修改不影響基本表。它使得我們獲取數據更容易,相比多表查詢。 游標:是對查詢出來的結果集作為一個單元來有效的處理。游標可以定在該單元中的特定行,從結果集的當前行檢索一行或多行。可以對結果集當前行做修改。一般不使用游標,但是需要逐條處理數據的時候,游標顯得十分重要。

轉載于:https://www.cnblogs.com/xiasy-bk/p/10365997.html

總結

以上是生活随笔為你收集整理的数据库中的基础知识的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。