第十二單元 `T-SQL` 編程

来源:https://www.cnblogs.com/xuyubing/archive/2023/12/19/17914369.html
-Advertisement-
Play Games

create database step2_unit12; go use step2_unit12; go -- 部門表 CREATE TABLE [dbo].[Department]( [Id] [int] PRIMARY KEY IDENTITY(1,1) NOT NULL, [Name] [v ...


create database step2_unit12;
go
use step2_unit12;
go
-- 部門表
CREATE TABLE [dbo].[Department](
    [Id] [int] PRIMARY KEY IDENTITY(1,1) NOT NULL,
    [Name] [varchar](20) NULL
);
-- 職位表
CREATE TABLE [dbo].[Job](
    [Id] [int] PRIMARY KEY IDENTITY(1,1) NOT NULL,
    [Name] [varchar](20) NULL
);
-- 人員表
CREATE TABLE [dbo].[person](
    [Id] [int] PRIMARY KEY IDENTITY(1,1) NOT NULL,
    [Name] [varchar](50) NULL,
    [Sex] [varchar](10) NULL,
    [Age] [int] NULL
);
-- 工資表
CREATE TABLE [dbo].[Salary](
    [Id] [int] PRIMARY KEY IDENTITY(1,1) NOT NULL,
    [Sal] [money] NULL,
    [Comm] [money] NULL,
    [StaffId] [int] NULL
);
-- 員工表
CREATE TABLE [dbo].[Staff](
    [Id] [int] PRIMARY KEY IDENTITY(1,1) NOT NULL,
    [Name] [varchar](20) NOT NULL,
    [Hiredate] [datetime] NOT NULL,
    [DepartmentId] [int] NULL,
    [JobId] [int] NULL
);
SET IDENTITY_INSERT [dbo].[Department] ON 
​
INSERT [dbo].[Department] ([Id], [Name]) VALUES (1, N'技術部')
INSERT [dbo].[Department] ([Id], [Name]) VALUES (2, N'人資部')
INSERT [dbo].[Department] ([Id], [Name]) VALUES (3, N'市場部')
SET IDENTITY_INSERT [dbo].[Department] OFF
SET IDENTITY_INSERT [dbo].[Job] ON 
​
INSERT [dbo].[Job] ([Id], [Name]) VALUES (1, N'經理')
INSERT [dbo].[Job] ([Id], [Name]) VALUES (2, N'組長')
INSERT [dbo].[Job] ([Id], [Name]) VALUES (3, N'員工')
SET IDENTITY_INSERT [dbo].[Job] OFF
SET IDENTITY_INSERT [dbo].[person] ON 
​
INSERT [dbo].[person] ([Id], [Name], [Sex], [Age]) VALUES (1, N'高圓圓', N'', 28)
INSERT [dbo].[person] ([Id], [Name], [Sex], [Age]) VALUES (2, N'王佳佳', N'', 32)
INSERT [dbo].[person] ([Id], [Name], [Sex], [Age]) VALUES (3, N'楊碩', N'', 25)
SET IDENTITY_INSERT [dbo].[person] OFF
SET IDENTITY_INSERT [dbo].[Salary] ON 
​
INSERT [dbo].[Salary] ([Id], [Sal], [Comm], [StaffId]) VALUES (1, 15000.0000, 10000.0000, 1)
INSERT [dbo].[Salary] ([Id], [Sal], [Comm], [StaffId]) VALUES (2, 15000.0000, 9000.0000, 2)
INSERT [dbo].[Salary] ([Id], [Sal], [Comm], [StaffId]) VALUES (3, 12000.0000, 8000.0000, 3)
INSERT [dbo].[Salary] ([Id], [Sal], [Comm], [StaffId]) VALUES (4, 8000.0000, 6000.0000, 4)
INSERT [dbo].[Salary] ([Id], [Sal], [Comm], [StaffId]) VALUES (5, 4000.0000, 3000.0000, 5)
INSERT [dbo].[Salary] ([Id], [Sal], [Comm], [StaffId]) VALUES (6, 9000.0000, 8000.0000, 6)
INSERT [dbo].[Salary] ([Id], [Sal], [Comm], [StaffId]) VALUES (7, 15000.0000, 12000.0000, 7)
INSERT [dbo].[Salary] ([Id], [Sal], [Comm], [StaffId]) VALUES (8, 12000.0000, 9000.0000, 7)
INSERT [dbo].[Salary] ([Id], [Sal], [Comm], [StaffId]) VALUES (9, 7000.0000, 2000.0000, 9)
INSERT [dbo].[Salary] ([Id], [Sal], [Comm], [StaffId]) VALUES (10, 9000.0000, 8000.0000, 10)
SET IDENTITY_INSERT [dbo].[Salary] OFF
SET IDENTITY_INSERT [dbo].[Staff] ON 
​
INSERT [dbo].[Staff] ([Id], [Name], [Hiredate], [DepartmentId], [JobId]) VALUES (1, N'王鑫', CAST(N'2014-02-01 00:00:00.000' AS DateTime), 1, 1)
INSERT [dbo].[Staff] ([Id], [Name], [Hiredate], [DepartmentId], [JobId]) VALUES (2, N'張磊', CAST(N'2015-09-03 00:00:00.000' AS DateTime), 2, 1)
INSERT [dbo].[Staff] ([Id], [Name], [Hiredate], [DepartmentId], [JobId]) VALUES (3, N'李鵬', CAST(N'2016-08-01 00:00:00.000' AS DateTime), 3, 2)
INSERT [dbo].[Staff] ([Id], [Name], [Hiredate], [DepartmentId], [JobId]) VALUES (4, N'王洋', CAST(N'2019-02-03 00:00:00.000' AS DateTime), 1, 3)
INSERT [dbo].[Staff] ([Id], [Name], [Hiredate], [DepartmentId], [JobId]) VALUES (5, N'吳潘', CAST(N'2018-10-01 00:00:00.000' AS DateTime), 2, 3)
INSERT [dbo].[Staff] ([Id], [Name], [Hiredate], [DepartmentId], [JobId]) VALUES (6, N'賈丹', CAST(N'2018-07-01 00:00:00.000' AS DateTime), 2, 2)
INSERT [dbo].[Staff] ([Id], [Name], [Hiredate], [DepartmentId], [JobId]) VALUES (7, N'李露', CAST(N'2016-09-01 00:00:00.000' AS DateTime), 3, 1)
INSERT [dbo].[Staff] ([Id], [Name], [Hiredate], [DepartmentId], [JobId]) VALUES (8, N'楊騰', CAST(N'2018-11-08 00:00:00.000' AS DateTime), 1, 2)
INSERT [dbo].[Staff] ([Id], [Name], [Hiredate], [DepartmentId], [JobId]) VALUES (9, N'孫藝', CAST(N'2018-12-26 00:00:00.000' AS DateTime), 3, 3)
INSERT [dbo].[Staff] ([Id], [Name], [Hiredate], [DepartmentId], [JobId]) VALUES (10, N'趙帥', CAST(N'2019-01-03 00:00:00.000' AS DateTime), 1, 3)
SET IDENTITY_INSERT [dbo].[Staff] OFF
 

 

1. T-SQL 命名規則

1,開頭不能是數字,空格或特殊字元

2,首字元後可以包含 字母 數字 漢字 _ @ #

3,不能是系統保留字(關鍵字)

 

2. 變數

全局變數

整個系統都可以使用

@@ERROR   返回執行的上一個T-SQL語句的錯誤號,0 代表沒有錯誤,非0 代表有錯誤
begin tran
    declare @a int = 1; 
    select @a/0
    select @@ERROR
commit

@@IDENTITY 返回插入到表的IDENTITY列的最後一個值
@@LANGUAGE返回當前所用語言的名稱
@@MAX_CONNECTIONS返回Sql Server實例允許同時進行的最大用戶連接數
@@ROWCOUNT返回上一次語句影響的數據行的行數
@@SERVERNAME返回運行Sql Server的本地伺服器的名稱
@@SERVICENAME返回Sql Server正在其下運行的註冊表項的名稱
@@TIMETICKS返回每個時鐘周期的微秒數
@@TRANCOUNT返回當前連接的活動事務數
@@VERSION 返回當前安裝的日期、版本和處理器類型

 

局部變數

註意:定義局部變數必須以@開頭。只能在當前連接(會話)下使用

定義變數

--declare @變數名 變數類型= 變數值; 
--如
declare @name varchar(20)= '任我行';

 

局部變數賦值

  • select 賦值
    
    declare @age int= 0; -- 定義變數
    
    -- 直接賦值
    select @age = 20;
    
    -- 也可通過查詢語句進行賦值
    select @age=Age from person where Name='高圓圓';
    set 賦值
    
    set @age = 20; -- 不可通過查詢語句進行賦值
    declare @username nvarchar(50)='任我行'; --定義局部變數,並賦初始值
    set @username='張三'; --通過set賦值
    select @username='aaa'; --通過select 賦值
    select @username as 用戶名; --通過select 輸出並取別名
    print @username; --print 列印輸出

     

案例

-- 查詢高圓的年齡,如果年齡是1-10歲,則輸出兒童,10-25 輸出少年,25-40輸出青年,40-60輸出中年,其他老年
​
declare @age int=0;
select @age=Age from person where Name='高圓圓';
set @age=30; --給局部變數賦值
​
if @age<10
begin
    print '兒童';
end;
else if  @age<25
begin
    print '少年'
end;
else if  @age<40
begin
    print '青年'
end;
else if  @age<60
begin
    print '中年'
end;
else 
begin
    print '老年'
end;
 

 

3. 運算符

1. 算術運算符

運算符名稱
+ 加法運算符
- 減法運算符
* 乘法運算符
/ 除法運算符
% 求餘運算符

 

 

2. 比較運算符

運算符名稱
= 等於
> 大於
< 小於
>= 大於等於
<= 小於等於

 

 

3. 邏輯運算符

運算符含義
ALL 如果一組比較都為true,那麼就為true
AND 如果兩個布爾表達式都為true,那就為true
Any 兩個任意一個布爾表達式為true即為true
Between 如果操作數在這個範圍,則為true
exists 如果查詢包含一些行,則為true
in 如果表達式等於表達式中的某一個,則為true
like 如果操作數與一種模式想匹配則為true
not 對任何一個布爾運算符取反
or 兩個布爾表達式一個為true,則為true
some 在一組比較中,有些為true, 那麼就為true

 

4. 連接運算符

是連接運算符,可以將兩個及以上個字元串拼接到一起

select 'abc'+'bdc';

select '10'+'10'; -- sqlserver 中沒有隱式轉換
-- 輸出結果:1010


select 10+'10'; -- sqlserver 中沒有隱式轉換
-- 輸出結果:20


select 10+'10a'; -- 報錯,還是因為沒有隱式轉換

 

 

5. 運算符優先順序

級別運算符
1 ~(位非)
2 *(乘 )、/ (除)、%(求餘)
3 +(正)、-(負)、+(加),-(減),+(連接)、^(位異或)、&(位與)、|(位或)
4 =(等於)、>、< 、>=、<= 、!=、<>(不等於)、!>(不小於)、!<(不大於)
5 not
6 and
7 all、any、between、in、like、or、some
8 =(賦值)

 

  1. 查詢出人員表中總的記錄數給@MyCount局部變數賦值並輸出

    declare @mycount int;
    select @mycount=count(Id) from person;
    select @mycount;

     

  2. 求出高圓圓與王佳佳的年齡總和

    declare @age1 int,@age2 int,@sum int;
    --declare @age2 int;
    --declare @sum int;
    select @age1 = Age from person where Name='高圓圓';
    select @age2 = Age from person where Name='王佳佳';
    
    
    set @sum=@age1+@age2;
    --select @sum=@age1+@age2;
    select @sum;
     

     

  3. 輸出出“高圓圓 VIP”這樣一條信息

    select Name,'VIP' as 等級 from person where Name='高圓圓'
    
    select Name+'     VIP' as VIP from person where Name='高圓圓'
     

     

  1. 查詢出年齡大於25歲的人員信息

    Select * from person where age>25

     

     

  2. 查詢出年齡大於25歲或者性別為女的人員信息

    Select * from person where age>25 or Sex=''

     

 

6. 作業

  1. T-SQL編程實現123%7後得結果

  2. 題目2

    T-sql語句進行如下編程

    (1) 定義一個整形變數age

    (2) 給變數age賦值為10

    (3) 定義一個不超過8字元的變數name

    (4) 給name變數賦值為”張三”

    (5) 調用變數,輸出最終結果 張三的年齡是10歲

 

配套視頻鏈接:1. 索引的概述_嗶哩嗶哩_bilibili

 

海闊平魚躍,天高任我行,給我一片藍天,讓我自由翱翔。
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 原文: https://openaigptguide.com/ai-picture-generator/ 在人工智慧(AI)圖像生成技術的推動下,各類AI圖片生成網站如雨後春筍般涌現,為我們的日常生活提供了豐富多彩的視覺體驗。 AI圖片生成技術原理 人工智慧(AI)圖片生成技術原理是通過電腦程式使 ...
  • 背景及問題 如下程式所示: #include<iostream> class MyString { public: MyString() = default; MyString(const char* data) { printf("%s", "MyString Constructed!!\n"); ...
  • 引言 在ChatGpt火了這麼久,他的那種單字單字返回的格式可能讓很多朋友感到好奇,在之前我用c#寫了一個版本的,同時支持IAsyncEnumerable以及SSE,今天把之前寫的Java版本的也發出來,和大家一起學習,有不對的地方,歡迎各位大佬指正。 Code 我這邊用的是JDK21版本,可以看到 ...
  • 需求 有些應用每次啟動都需要用管理員許可權運行,比如Python註入dll時,編輯器或cmd就需要以管理員許可權運行,不然註入就會失敗。 這篇文章用編程怎麼修改配置實現打開某個軟體都是使用管理員運行,就不用每次都右鍵點擊以管理員身份運行此程式。主要是給小白配置,防止他忘了以管理員許可權運行,又跑過來問我為 ...
  • Qt 是一個跨平臺C++圖形界面開發庫,利用Qt可以快速開發跨平臺窗體應用程式,在Qt中我們可以通過拖拽的方式將不同組件放到指定的位置,實現圖形化開發極大的方便了開發效率,本章將重點介紹`TableWidget`表格組件的常用方法及靈活運用。`QTableWidget` 是 Qt 中用於顯示表格數據... ...
  • QMdiArea(Multiple Document Interface Area)是Qt中用於創建多文檔界面的組件。它提供了一種在單個視窗中管理多個文檔的方式,每個文檔通常是一個子視窗(`QMdiSubWindow`)。該組件主要用於設計多文檔界面應用程式,具備有多種窗體展示風格,實現了在父窗體中... ...
  • 代理在電腦網路很常見,比如伺服器群組內部通常只會開一個口進行對外訪問,就可以通過內網代理來進行處理,從而更好的保護內網伺服器。代理讓我們網路更安全,但是警惕非正規的代理可能會竊取您的數據。請用HTTPS內容訪問更安全。 ...
  • 1. 選擇結構 If(...) Begin ​ 語句塊 ​ End ​ else if(...) Begin ​ 語句塊 ​ End ​ Else ​ Begin ​ 語句塊 ​ End; 註意事項 語法中begin..end相當於C#中的{} 執行語句只有一條時,begin..end可以省略 () ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...