sql server相關學習sql語句

来源:https://www.cnblogs.com/kk-ss/archive/2023/03/28/17264836.html
-Advertisement-
Play Games

sql腳本 表結構設置 點擊查看代碼 if exists(select * from sys.objects where name='Department' and type='U') drop table Department create table Department ( --id iden ...


  • sql腳本 ---表結構設置
點擊查看代碼
if exists(select * from sys.objects where name='Department' and type='U')
	drop table Department
create table Department
(
	--id identity(x,y) 初始x 自增y,primary key 主鍵
	DepartmentId int primary key identity(1,1),
	--名稱
	DepartmentName nvarchar(50) not null,
	--描述
	DepartmentRemark text


)
--字元串
--char(x)  占用x個位元組 ‘ab’=>x個位元組
--varchar(x) 最多占用x個位元組  ‘ab’=>2個(x>2)
--text 長文本
--char text varchar 前面加n;存儲unicode 對中文友好
--例子
--varchar(100) 100個字母或者50個漢字
--nvarchar(100) 100個字母或者100個漢字

--Rank是關鍵字了,所以加上[]
create table [Rank]
(
	--id identity(x,y) 初始x 自增y,primary key 主鍵
	RankId int primary key identity(1,1),
	--名稱
	RankName nvarchar(50) not null,
	--描述
	RankRemark text


)

if exists(select * from sys.objects where name='People' and type='U')
	drop table People

create table People(
	--id identity(x,y) 初始x 自增y,primary key 主鍵
	PeopleId int primary key identity(1,1),
	--部門 references 引用外鍵 引用在部門表的id範圍之內
	DepartmentId int references Department(DepartmentId)not null ,
	--職員
	RankId int references [Rank](RankId)not null,
	--名稱
	PeopleName nvarchar(50) not null,
	--性別 加上約束(check) 預設
	PeopleSex nvarchar(1)default('男') check(PeopleSex='男' or PeopleSex='女')not null,
	--老版本date 新版本有time 加上samll就是表示現在時間 不能表示未來
	PeopleBirth smalldatetime not null,
	--小數的使用 float 可能有誤差 decimal(x,y) 長度x,小數y位
	PeopleSalary decimal(12,2) check(PeopleSalary>=1000 and PeopleSalary<=100000)not null,
	--電話 約束unique 唯一 電話是唯一的
	PeoplePhone varchar(20)unique not null,
	--地址
	PeopleAddress varchar(300),
	--添加時間,獲取當前時間預設值,有一個函數 getdate()
	PeopleAddTime smalldatetime default(getdate()) not null
)

--修改表結構---

--(1)CRUD列
--alter table 表名 add 新列名 數據類型
--添加列 員工表添加郵箱列
alter table People add Mail varchar(200)
--alter table 表名 drop column 列名 
--刪除列 員工表刪除郵箱列
alter table People drop column Mail
--alter table 表名 alter column 列名 數據類型
--修改地址為 200
alter table People alter column PeopleAddress varchar(200)

--維護約束---(刪除 添加)
--刪除約束
--alter table 表名 drop constraint 約束名
--alter table People drop constraint xxx
--添加約束
--alter table 表名 add constraint 約束名 check(表達式)
--alter table People add constraint psadad check(PeopleSex='男' or PeopleSex='女')
--添加主鍵 唯一 預設 外鍵
--alter table 表名 add constraint 約束名 primary key (列名)


insert into Department(DepartmentName,DepartmentRemark)
values('市場部','..........')

insert into Department(DepartmentName,DepartmentRemark)
values('軟體部','..........')

insert into Department(DepartmentName,DepartmentRemark)
values('企劃部','..........')

insert into Department(DepartmentName,DepartmentRemark)
values('銷售部','..........')
--最好一一對應 如果列順序改變就回值出問題
--一次性插入多行數據

  • 表內容 crud
點擊查看代碼
use Mytest
select *from Department
select * from [Rank]
select * from People


--數據crud
--修改
--update 表名 set 列名='xxx' where 條件
--update 表名 set 列名='xxx', 列名='yyy' where 條件

update Department set DepartmentName='經理部' where DepartmentId=8
update People set PeopleSalary=PeopleSalary+1000 

update People set PeopleSalary=15000 where RankId=3 and PeopleSalary<=15000
update People set PeopleSalary=PeopleSalary*2,PeopleAddress='西京' where PeopleName='關羽7'

--delete drop truncate區別
--drop table xxx 刪除表對象xxx
--delete from xxx 刪除表xxx的數據, 即表對象和結構都存在
--truncate table xxx 刪除數據(清空數據)即表對象和結構都存在

--truncate 清空所有數據,不能有數據。 delete 可以刪除所有數據也可以帶條件刪除符合條件的數據
--自動編號 1,2,3,4,5
--truncate 編號為:1,2,3,4,5 (重頭開始)
--delete   編號將為6,7,8,9,10(繼續)
--查詢 as可省略 ,distinct()去重,
select PeopleName 姓名 from People
select distinct(PeopleAddress) from People
select PeopleSalary*1.2 加薪後,PeopleSalary 加薪前 from People
--按照 名字長度的前5個查詢
select top 5 PeopleName from People order by len(PeopleName)
--按照 名字長度的前25%查詢
select top 25 percent PeopleName from People order by len(PeopleName)
--按照 名字長度的後25%查詢
select top 25 percent PeopleName from People order by len(PeopleName) desc
--查詢為null的值的單位
select *from People where PeopleAddress is null;
--查詢非空的值 和‘ ’區別 null就是沒填  ‘ ’insert 有欄位但是空白
select *from People where PeopleAddress is not null;
--查詢時間的 1988到2000的
select * from People where PeopleBirth>'1988-8-7' and PeopleBirth<'2000-3-1'

select * from People where PeopleBirth between '1988-8-8'and '2000-3-1'

select * from People where year(PeopleBirth) between 1988  and 2000
--查詢年紀在多少歲的
select PeopleName,year(GETDATE())-YEAR(PeopleBirth) 年齡 from People
--查詢年紀在35歲以下的
select PeopleName,year(GETDATE())-YEAR(PeopleBirth) 年齡 from People where year(GETDATE())-YEAR(PeopleBirth)<35 and PeopleSalary >5000
select* from People where (MONTH(PeopleBirth)=11 and DAY(PeopleBirth)<=22) or (MONTH(PeopleBirth)=12 and DAY(PeopleBirth)<=31)
--子查詢
select *from People where PeopleAddress=
(select PeopleAddress from People where PeopleName='關羽')
--龍 8
--鼠 4
--

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

-Advertisement-
Play Games
更多相關文章
  • 操作系統 移動端 安卓 iOS 鴻蒙 其他工業系統 桌面端 Windows MaciOS Unix Linux 伺服器 Unix Linux 購買主機 阿裡雲 騰訊雲 華為雲 其他雲平臺 虛擬機 宿主主機 物理硬體 CPU 記憶體 硬碟 操作系統 Mac Windows 虛擬機 Virtual Box ...
  • 一·依賴包以及下載地址 本文使用到的離線包: apr-1.7.0.tar.gz apr-util-1.6.1.tar.gz pcre2-10.40.tar.gz expat-2.1.0-14.el7_9.x86_64.rpm expat-devel-2.1.0-14.el7_9.x86_64.rpm ...
  • SFTP 常用命令 通過堡壘機進入的 Linux 操作系統,無法直接使用 WinSCP 等工具進行文件的上傳下載。 可使用 SecureCRT 先進入命令行模式 ...
  • 1. 概述 1.1. SQL-92標準裡加入的最有用的特性 1.2. 寫法 1.2.1. 簡單CASE表達式 CASE sex WHEN '1' THEN ’男’ WHEN '2' THEN ’女’ ELSE ’其他’ END 1.2.1.1. 寫法簡單,但能實現的事情比較有限 1.2.2. 搜索C ...
  • 背景 早上收到某系統的告警tidb節點掛掉無法訪問,情況十萬火急。登錄中控機查了一下display信息,4個TiDB、Prometheus、Grafana全掛了,某台機器hang死無法連接,經過快速重啟後集群恢復,經排查後是昨天上線的某個SQL導致頻繁OOM。 於是開始亡羊補牢,來一波近期慢SQL巡 ...
  • 超詳細【入門精講】數據倉庫原理&實戰 一步一步搭建數據倉庫 內附相應實驗代碼和鏡像數據和腳本,參考B站up主哈嘍鵬程視頻撰寫而成,感謝!!! ...
  • 存儲引擎 一. MySQL體繫結構 MySQL Server 連接層:連接的處理、認證授權、安全方案、檢查是否超過最大連接數等。 服務層:SQL介面、解析器、查詢優化器、緩存 引擎層:引擎是數據存儲和提取的方式,引擎層有許多引擎可供使用,也可以自定義引擎。索引是在存儲引擎層實現的。 存儲層:存儲數據 ...
  • ##【問題描述】 開發有天碰到一個很奇怪的問題,他的場景是這樣子的: 通過Canal來訂閱MySQL的binlog, 當捕獲到有數據變化時,回到資料庫,反查該數據的明細,然後做進一步處理。 有一次,他碰到一個詭異的現象: 1. Canal收到消息,有一條主鍵id=31019319的數據插入 2. 1 ...
一周排行
    -Advertisement-
    Play Games
  • Timer是什麼 Timer 是一種用於創建定期粒度行為的機制。 與標準的 .NET System.Threading.Timer 類相似,Orleans 的 Timer 允許在一段時間後執行特定的操作,或者在特定的時間間隔內重覆執行操作。 它在分散式系統中具有重要作用,特別是在處理需要周期性執行的 ...
  • 前言 相信很多做WPF開發的小伙伴都遇到過表格類的需求,雖然現有的Grid控制項也能實現,但是使用起來的體驗感並不好,比如要實現一個Excel中的表格效果,估計你能想到的第一個方法就是套Border控制項,用這種方法你需要控制每個Border的邊框,並且在一堆Bordr中找到Grid.Row,Grid. ...
  • .NET C#程式啟動閃退,目錄導致的問題 這是第2次踩這個坑了,很小的編程細節,容易忽略,所以寫個博客,分享給大家。 1.第一次坑:是windows 系統把程式運行成服務,找不到配置文件,原因是以服務運行它的工作目錄是在C:\Windows\System32 2.本次坑:WPF桌面程式通過註冊表設 ...
  • 在分散式系統中,數據的持久化是至關重要的一環。 Orleans 7 引入了強大的持久化功能,使得在分散式環境下管理數據變得更加輕鬆和可靠。 本文將介紹什麼是 Orleans 7 的持久化,如何設置它以及相應的代碼示例。 什麼是 Orleans 7 的持久化? Orleans 7 的持久化是指將 Or ...
  • 前言 .NET Feature Management 是一個用於管理應用程式功能的庫,它可以幫助開發人員在應用程式中輕鬆地添加、移除和管理功能。使用 Feature Management,開發人員可以根據不同用戶、環境或其他條件來動態地控制應用程式中的功能。這使得開發人員可以更靈活地管理應用程式的功 ...
  • 在 WPF 應用程式中,拖放操作是實現用戶交互的重要組成部分。通過拖放操作,用戶可以輕鬆地將數據從一個位置移動到另一個位置,或者將控制項從一個容器移動到另一個容器。然而,WPF 中預設的拖放操作可能並不是那麼好用。為瞭解決這個問題,我們可以自定義一個 Panel 來實現更簡單的拖拽操作。 自定義 Pa ...
  • 在實際使用中,由於涉及到不同編程語言之間互相調用,導致C++ 中的OpenCV與C#中的OpenCvSharp 圖像數據在不同編程語言之間難以有效傳遞。在本文中我們將結合OpenCvSharp源碼實現原理,探究兩種數據之間的通信方式。 ...
  • 一、前言 這是一篇搭建許可權管理系統的系列文章。 隨著網路的發展,信息安全對應任何企業來說都越發的重要,而本系列文章將和大家一起一步一步搭建一個全新的許可權管理系統。 說明:由於搭建一個全新的項目過於繁瑣,所有作者將挑選核心代碼和核心思路進行分享。 二、技術選擇 三、開始設計 1、自主搭建vue前端和. ...
  • Csharper中的表達式樹 這節課來瞭解一下表示式樹是什麼? 在C#中,表達式樹是一種數據結構,它可以表示一些代碼塊,如Lambda表達式或查詢表達式。表達式樹使你能夠查看和操作數據,就像你可以查看和操作代碼一樣。它們通常用於創建動態查詢和解析表達式。 一、認識表達式樹 為什麼要這樣說?它和委托有 ...
  • 在使用Django等框架來操作MySQL時,實際上底層還是通過Python來操作的,首先需要安裝一個驅動程式,在Python3中,驅動程式有多種選擇,比如有pymysql以及mysqlclient等。使用pip命令安裝mysqlclient失敗應如何解決? 安裝的python版本說明 機器同時安裝了 ...