SQL Server【四】

identity

主鍵自動增長,用戶不需要為identity修飾的主鍵賦值

create table student
(std_id int primary key identity(10,5),--(10,5)可以省略,默認為(1,1)std_name nvarchar(200) not null
)
select * from student
insert into student values ('張三')	--不需要為主鍵賦值
insert into student values ('李四')
insert into student values ('王麻子')

在這里插入圖片描述

delete from student where std_name='李四'

在這里插入圖片描述

insert into student values ('李四')

在這里插入圖片描述
即刪除以后不會前移,而是繼續增長
但是主鍵是否連續增長不是十分重要

如果使用identity以后就不能手動設置主鍵,如果一定要設置可以進行如下操作


SET identity_insert Test.dbo.student on	--注意下劃線insert into student(std_id, std_name) values (15, '王五')	--不可以省略(std_id, std_name)set identity_insert Test.dbo.student off

視圖

視圖是select語句
邏輯上相當于一個臨時表、虛擬表
但是庫里面并不存在真正的表

格式:

create view vi_name
as select 語句

視圖定義的前后不能加beginend

如果不使用視圖

--求出平均工資最高的部門名稱和部門的平均工資select dept.dname as "部門名稱", tmp.avg_sal as "最高平均工資"from deptjoin (select top 1 avg(sal) as avg_sal, deptnofrom empgroup by deptnoorder by AVG(sal) desc) "tmp"on dept.deptno = tmp.deptno--Oracle不支持top,如果不使用rownum,使用下面復雜寫法
select dept.dname as "部門名稱", tmp.avg_sal as "最高平均工資"from (select AVG(sal) as avg_sal, deptno from emp group by deptno) as "tmp"join depton dept.deptno=tmp.deptnowhere (select MAX(t.avg_sal)from (select AVG(sal) as avg_sal, deptno from emp group by deptno) as "t")= tmp.avg_sal;

如果使用視圖

create view vi_emp1 as select AVG(sal) as avg_sal, deptno from emp group by deptnoselect dept.dname as "部門名稱", vi_emp1.avg_sal as "最高平均工資"from vi_emp1join depton dept.deptno=vi_emp1.deptnowhere (select MAX(tmp.avg_sal) from vi_emp1 as "tmp")= vi_emp1.avg_sal;

視圖的優點:

  • 視圖可以簡化查詢,方便地創建一個臨時表,避免代碼冗余.
  • 可以增加視圖的保密性

使用視圖一般用于查詢,很少用于增刪改查。有時會出錯。

視圖的缺點:

  • 增加了數據庫維護的成本(可能不會自動更新)
  • 視圖只是簡化了代碼,并沒有加快查詢的速度。

注意事項:

  • 創建視圖的select語句必須為所有的計算列指定別名
  • 視圖不是物理表,是虛擬表
  • 不建議通過視圖更新視圖所依附的原始表的數據或結果

事務

事務主要保證數據的合理性和并發處理能力

可以避免數據處于一種不合理的中間狀態,例如轉賬
利用事務可以實現多個用戶對共享資源的同時訪問,使得呈現給用戶的數據是合理的

事務和線程的關系:
事務也是通過鎖來解決很多問題

事務運行的三種模式:

  • 自動提交事務
  • 顯式事務
  • 隱性事務

事務的四大特性:

  • 原子性
  • 一致性
  • 隔離性
  • 持久性

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/383633.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/383633.shtml
英文地址,請注明出處:http://en.pswp.cn/news/383633.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

TCP服務器/客戶端實例(C/C )

1.1、Linux下的TCP服務器&#xff1a; #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <arpa/inet.h> #include <sys/types.h> #include <sys/socket.h>void error_handling(char *mess…

pip代理解決pip下載失敗問題

在用pip下載各種庫的時候發現速度實在是太慢了&#xff0c;還會有各種奇奇怪怪的問題&#xff0c;動不動就玄學失敗。 在網上找來找去找到知乎上一位大佬的回答&#xff1a;傳送門&#xff0c;用了豆瓣的代理。哇咔咔&#xff0c;媽媽再也不用擔心我下載失敗了。 代理&#x…

實現Linux select IO復用C/S服務器代碼

服務器端#include<stdio.h> #include<unistd.h> #include<stdlib.h> #include<string.h> #include<sys/socket.h> #include<sys/stat.h> #include<arpa/inet.h> #include <sys/select.h>#define MAXBUF 256 #define MAXLISTEN…

Bellman-Ford算法和SPFA算法

Belloman-Ford算法 算法介紹 Dijkstra可以解決單源無負邊最短路徑問題。但是當遇到含有負邊的單源最短路徑問題就需要使用Bellman-Ford算法來解決。Bellman-Ford算法還可以檢測出負環。 算法步驟 源點s,數組d[u]d[u]d[u]表示s到u的最短距離初始化&#xff1a;d[s]0d[s]0d[s…

C語言實現單鏈表操作

SLIST_H #ifndef __SLIST_H__ #define __SLIST_H__ #include<cstdio> #include<malloc.h> #include<assert.h> typedef int ElemType; typedef struct Node { //定義單鏈表中的結點信息 ElemType data; //結點的數據域 struct Node *next; //結點的指針…

計算機網絡【4】傳輸層

概述 傳輸層是只有主機才有的層次 傳輸層的功能&#xff1a; 傳輸層提供進程和進程之間的邏輯通信&#xff08;網絡層提供主機與主機之間的邏輯通信&#xff09;復用和分用傳輸層對收到的報文進行差錯檢測 傳輸層有兩個協議&#xff1a; 面向連接的傳輸層控制協議TCP&…

Plotly繪圖

在做Python數據分析實驗的時候發現使用Plotly庫繪圖比較漂亮&#xff0c;在網上找到了一個比較好的教程&#xff0c;這里記錄一下&#xff0c;方便以后查找。 傳送門

計算機網絡【0】概述

計算機網絡概念和功能 概念 是一個將分散的、具有獨立功能的計算機系統&#xff0c;通過通信設備與線路連接起來&#xff0c;由功能完善的軟件實現資源共享和信息傳遞的系統。 計算機網絡是互連的、自治&#xff08;無主從關系&#xff09;的計算機集合。 功能 數據通信&am…

計算機網絡【1】物理層

物理層解決如何在連接各種計算機的傳輸媒體上傳輸數據比特流&#xff0c;而不是指具體的傳輸媒體。 確定與傳輸媒體接口有關的特性 機械特性&#xff1a;定義物理連接的特性&#xff0c;如規格、接口形狀、引線數目、引腳數目、排列電氣特性&#xff1a;規定傳輸二進制位時的電…

計算機網路【2】數據鏈路層

結點&#xff1a;主機、路由器 鏈路&#xff1a;兩個節點的物理通道 數據鏈路&#xff1a;邏輯通道&#xff0c;把實現 控制數據傳輸協議的硬件和軟件加到鏈路上就構成數據鏈路 幀&#xff1a;鏈路層的協議數據單元&#xff0c;封裝網絡層數據報 數據鏈路層在物理層提供服務的…

計算機網絡【5】應用層

應用層對應用程序的通信提供服務 應用層協議定義&#xff1a; 應用層的功能&#xff1a; 文件傳輸、訪問和管理電子郵件虛擬終端查詢服務和遠程作業登錄 重要協議&#xff1a;FTP、SMTP、POP3、HTTP、DNS 網絡應用模型 客戶/服務器模型&#xff08;Client/Server&#x…

操作系統【八】文件管理

文件&#xff1a;一組有意義的信息/數據集合 文件的屬性&#xff1a; 文件名&#xff1a;由創建文件的用戶決定文件名&#xff0c;主要是為了方便用戶找到文件。同一個目錄下不允許有重名文件標識符&#xff1a;一個系統內的個文件標識符唯一&#xff0c;對用戶來說毫無可讀性…

數據庫原理及應用【六】數據庫設計

數據依賴 函數依賴FD&#xff1a;一個屬性或者一組屬性的值可以決定另一個屬性的值 多值依賴MVD&#xff1a;一個屬性或者一組屬性的值可以決定另一個屬性的值的集合。FD是MVD的特例 符號表示&#xff1a;Name->->Course&#xff0c;課程多值依賴于姓名 連接依賴&#x…

數據可視化【一】JavaScript學習

本博客是我學習Curran Kelleher老師數據可視化課程的筆記&#xff0c;感興趣的小伙伴可以點擊這里學習。 three cores of data visualization: analysisdesignconstruction 推薦書籍《visualization analysis & design》 使用https://vizhub.com/進行編程學習&#xff…

數據庫原理及應用【二】數據模型

層次模型 tree Record and fieldParent-Child relationship(PCR) 每個記錄類型只有一個父節點 無法表達多對多信息 采用虛記錄解決多對多 網狀數據模型 系&#xff1a;主記錄->屬記錄 主記錄和屬記錄都可以有好多個 關系模型 表&#xff1a;table/relation 擁有更高的…

數據可視化【二】HTML+CSS+SVG+D3

HTML、CSS和SVG學習實現代碼&#xff1a;https://vizhub.com/Edward-Elric233/89185eb96bc64a9d81777873a0ccd0b9 index.html <!DOCTYPE html> <html><head><title>Shapes with SVG and CSS</title><link rel"stylesheet" href&qu…

數據可視化【三】基本概念

Visualization is suitable when there is a need to augment human capabilities rather than replace people with computational decision-making methods. 當可以信賴的智能化的解決方案存在的時候&#xff0c;可視化是不必要的。 當不知道需要分析的問題是什么的時候&…

數據可視化【四】Bar Chart

Make a Bar Chart Representing a data table in JavaScriptCreating rectangles for each rowUsing linear and band scalesThe margin conventionAdding axes 以下學習內容參考博客&#xff1a;傳送門 select()選擇所有指定元素的第一個 selectAll()選擇指定元素的全部 上…

數據庫原理及應用【三】DBMS+SQL

DBMS Query LanguagesInterface and maintaining tools(GUI)APIsClass Library QL 不是圖靈完備的&#xff0c;不是一種編程語言。 QL SQL是一種非過程化的查詢語言。 DDL數據定義語言&#xff1a;表&#xff0c;視圖QL 查詢語言DML 數據操縱語言DCL 數據控制語言 Base t…

數據可視化【五】 Scatter Plot

Scatter Plot vizhub上實現的代碼&#xff1a; https://vizhub.com/Edward-Elric233/53807a1b35d94329b3689081cd2ea945 https://vizhub.com/Edward-Elric233/b9647d50899a4a0e8e917f913cd0a53a https://vizhub.com/Edward-Elric233/8c6b50cd81a04f048f490f48e4fe6264 由前…