[30分鐘]MSSQL快速入門教程

来源:http://www.cnblogs.com/fenglingyi/archive/2016/08/27/5812207.html
-Advertisement-
Play Games

1.什麼是SQL語句 sql語言:結構化的查詢語言。(Structured Query Language),是關係資料庫管理系統的標準語言。 它是一種解釋語言:寫一句執行一句,不需要整體編譯執行。語法特點:1.沒有“ ”,字元串使用‘ ’包含2.沒有邏輯相等,賦值和邏輯相等都是=3.類型不再是最嚴格 ...


1.什麼是SQL語句

sql語言:結構化的查詢語言。(Structured Query Language),是關係資料庫管理系統的標準語言。

它是一種解釋語言:寫一句執行一句,不需要整體編譯執行。
語法特點:
1.沒有“ ”,字元串使用‘ ’包含
2.沒有邏輯相等,賦值和邏輯相等都是=
3.類型不再是最嚴格的。任何數據都可以包含在‘ ’以內
4.沒有bool值的概念,但是在視圖中可以輸入true/false
5.它也有關係運算符:> < >= <= = <> != ,它返回一個bool值
6.它也有邏輯運算符: !(not) &&(and) ||(or)
7.它不區別大小寫

2.使用sql語句創建資料庫和表

語法:
create database 資料庫名稱
on primary --預設在主文件組上
(
name='邏輯名稱_data' , --當你發現它不是一句完整的sql語句,而僅僅是一個處理結構中的某一句的時候,就需要添加 ,
size=初始大小,--數值不包含在‘’以內
filegrowth=文件增長 ,
maxsize=最大容量,
filename='物理路徑'
)
log on
(
name='邏輯名稱_log' , --當你發現它不是一句完整的sql語句,而僅僅是一個處理結構中的某一句的時候,就需要添加 ,
size=初始大小,--數值不包含在‘’以內
filegrowth=文件增長 ,
maxsize=最大容量, --一般來說日誌文件不限制最大容量
filename='物理路徑'
)

--判斷資料庫文件是否已經存在 :資料庫的記錄都存儲在master庫中的sysdatabases表中
--自動切換當前資料庫
--使用代碼開啟外圍應該配置器
exec sp_configure 'show advanced options' ,1
RECONFIGURE
exec sp_configure 'xp_cmdshell',1
RECONFIGURE
--自定義目錄  xp_cmdshell可以創建出目錄   'mkdir f:\project':指定創建目錄
exec xp_cmdshell 'mkdir f:\project'

use master
--exists 函數判斷()中的查詢語句是否返回結果集,如果返回了結果集則得到true,否則得到false
if exists( select * from sysdatabases where name='School')
    drop database School --刪除當前指定名稱的資料庫
create database School
on primary
(
 name='School_data',--邏輯名稱.說明最多能夠存儲100mb數據,如果沒有限制就可以將硬碟存儲滿
 size=3mb,--初始大小
 maxsize=100mb,--最大容量
 filegrowth=10%,--文件增長一次增長10%
 filename='f:\project\School_data.mdf'    
),
--創建文件組
filegroup mygroup
(
 name='School_data1',--邏輯名稱.說明最多能夠存儲100mb數據,如果沒有限制就可以將硬碟存儲滿
 size=3mb,--初始大小
 maxsize=100mb,--最大容量
 filegrowth=10%,--文件增長一次增長10%
 filename='F:\qiyi\School_data1.ndf'    
)
log on
(
 name='School_log',--邏輯名稱
 size=3mb,--初始大小
 --maxsize=100mb,--最大容量
 filegrowth=10%,--文件增長一次增長10%
 filename='f:\project\School_log.ldf'    
),
(
 name='School_log1',--邏輯名稱
 size=3mb,--初始大小
 --maxsize=100mb,--最大容量
 filegrowth=10%,--文件增長一次增長10%
 filename='F:\qiyi\School_log1.ldf'    
)
View Code

3.創建數據表

語法:
create table 表名
(
欄位名稱 欄位類型 欄位特征(是否為null,預設值 標識列 主鍵 唯一鍵 外鍵 check約束),
欄位名稱 欄位類型 欄位特征(是否為null,預設值 標識列 主鍵 唯一鍵 外鍵 check約束)
)
創建老師表Teacher :Id、Name、Gender、Age、Salary、Birthday

use School
if exists(select * from sysobjects where name='Classes')
  drop table Classes
create table Classes
(
 Classid int identity(1,1),
 ClassName nvarchar(50) not null 
)
if exists(select * from sysobjects where name='teacher')
  drop table teacher
create table Teacher
(
 Id int identity(1,1),--可以同時創建多個特征,用空格 分隔開。 identity是標識列,第一個參數是種子,第二個是增量
Name nvarchar(50)  not null,-- not null標記它的值不能為null--不能不填寫
ClassId int not null,
 Gender bit not null,
Age int   ,
Salary money, --如果不標記為 not null.那麼就相當於標記了null
Birthday datetime  
)

4.數據完整性約束

實體完整性:實體就是指一條記錄。這種完整性就是為了保證每一條記錄不是重覆記錄。是有意義的
-- 主鍵:非空和唯一.一個表只有一個主鍵,但是一個主鍵可以是由多個欄位組成的 組合鍵
-- 標識列:系統自動生成,永遠不重覆
-- 唯一鍵:唯一,但是可以為null,只能null一次

域完整性:域就是指欄位,它是為了保證欄位的值是準和有效,合理值
-- 類型 是否null,預設值,check約束,關係

自定義完整性:
-- check約束 , 存儲過程 觸發器

引用完整性:一個表的某個欄位的值是引用自另外一個表的某個欄位的值。引用的表就是外鍵表,被引用的表就是主鍵表
-- 1.建立引用的欄位類型必須一致
-- 2.建立引用的欄位的意義一樣
-- 3.建立主外鍵關係的時候選擇 外鍵表 去建立主外鍵關係
-- 4.建立主外鍵關係的欄位在主表中必須是主鍵或者唯一鍵
-- 5.對於操作的影響 :
-- 1.在添加數據時,先添加主鍵表再添加外鍵表數據
-- 2.在刪除的時候先外鍵表數據再刪除主鍵表數據


-- 級聯的操作:不建議使用:會破壞數據完整性
-- 不執行任何操作:該報錯就報錯,該刪除就刪除
-- 級聯:刪除主表記錄,從表引用該值的記錄也被刪除
-- 設置null:刪除主表記錄,從表對應的欄位值設置為null,前提是可以為null
-- 設置為default:刪除主表記錄,從表對應的欄位值設置為default,前提是可以為default

主鍵約束(PK Primary key) 唯一鍵約束(UQ unique) 外鍵約束(FK foreign key) 預設值約束(DF default) check約束(CK check)

語法:
alter table 表名
add constraint 首碼_約束名稱 約束類型 約束說明(欄位 關係表達式 值)

use School
if exists(select * from sysobjects where name='PK_Classes_Classid')
 alter table classes  drop constraint PK_Classes_Classid
alter table classes 
add constraint PK_Classes_Classid primary key(classid)
--為id添加主鍵
alter table teacher 
add constraint PK_teacher_id primary key(id)
--為name添加唯一鍵
alter table teacher
add constraint UQ_Teacher_Name unique(Name)
--同時創建salary的預設約束和age的check約束
alter table teacher
add constraint DF_Teacher_Salary default(5000) for salary,
constraint CK_Teacher_Age check(age>0 and age<=100)
--為teacher表的classid欄位創建主外鍵
if exists(select * from sysobjects where name='FK_Teacher_Classes_Classid')
 alter table teacher  drop constraint FK_Teacher_Classes_Classid
alter table teacher
with nocheck --不檢查現有數據
add constraint FK_Teacher_Classes_Classid foreign key(classid) references classes(classid)
--on delete set default  級聯操作
--不執行任何操作:該報錯就報錯,該刪除就刪除  --no action --預設選擇
--級聯:刪除主表記錄,從表引用該值的記錄也被刪除 --cascade
--設置null:刪除主表記錄,從表對應的欄位值設置為null,前提是可以為null   --set null
--設置為default:刪除主表記錄,從表對應的欄位值設置為default,前提是可以為default  --set default

5.四中基本字元類型說明

--len(參數) --獲取指定參數內容的字元個數
select LEN('abcd') 【4】運行結果
select LEN('中華人民共和國') 【7
--DataLength(參數):獲取指定內占據的位元組數--空間大小 select DataLength('abcd') 【4select DataLength('中華人民共和國') 【14
--char類型:當空間分配後,不會因為存儲的內容比分配的空間小就回收分配的空間。但是如果存儲的內容超出了指定的空間大小,就會報錯,當你存儲的內容的長度變化區間不大的時候可以考慮使用char select LEN(char) from CharTest 【2select DataLength(char) from CharTest 【10
--varchar var--變化的:當你存儲的內容小於分配的空間的時候,多餘的空間會自動收縮。但是如果存儲的內容超出了指定的空間大小,就會報錯 當存儲的內容波動區間比較大時候使用varchar select LEN(varchar) from CharTest 【2select DataLength(varchar) from CharTest 【2
--nchar-- n代表它是一個unicode字元。規定不管什麼樣的字元都占據兩個位元組。 char:空間是固定的 select LEN(nchar) from CharTest 【10select DataLength(nchar) from CharTest 【20
--nvarchar n var char select LEN(nvarchar) from CharTest 【2select DataLength(nvarchar) from CharTest 【4

 

6.SQL基本語句

數據插入
調用方法 一 一對應原則:類型對應,數量對應,順序對應
語法: 形參 實參
insert into 表名([欄位列表]) values(值列表) --數據必須要符合數據完整性
插入操作是單個表的操作
插入操作insert一次只能插入一條記錄

use School
--插入teacher所有欄位的數據.如果在表後沒有指定需要插入的欄位名稱,那麼就預設為所有欄位添加值
--但是一定需要註意的是:標識列永遠不能自定義值--不能人為插入值
--僅當使用了列列表並且 IDENTITY_INSERT 為 ON 時,才能為表'Teacher'中的標識列指定顯式值。
insert into Teacher values('張三',5,1,30,4000,'1984-9-11')
insert into Teacher(Name,ClassId,Gender,Age,Salary,Birthday) values('張三',5,1,30,4000,'1984-9-11')
--不為可以為null的欄位插入值  :可以null的欄位可以不賦值 
--列名或所提供值的數目與表定義不匹配
insert into Teacher(Name,ClassId,Gender,Age,Salary) values('李四',5,1,30,4000)
--非空欄位一定需要賦值 :不能將值 NULL 插入列 'Gender',表 'School.dbo.Teacher';列不允許有 Null 值。INSERT 失敗
insert into Teacher(Name,ClassId,Age,Salary) values('李四',5,30,4000)
--為有預設值的欄位插入值:
--1.不寫這一列讓系統自動賦值
insert into Teacher(Name,ClassId,Gender,Age) values('王五',5,1,30)
--指定 null或者default
insert into Teacher(Name,ClassId,Gender,Age,Salary,Birthday) values('趙六',5,1,30,default,null)
--數據必須完全符合表的完整性約束
insert into Teacher(Name,ClassId,Gender,Age,Salary,Birthday) values('趙六1',5,1,300,default,null)

--任意類型的數據都可以包含在''以內,     不包括關鍵字
insert into Teacher(Name,ClassId,Gender,Age,Salary,Birthday) values('馬鵬飛','5','0','15',default,null)
--但是字元串值如果沒有包含在''以內.會報錯   列名 '蘭鵬' 無效。
insert into Teacher(Name,ClassId,Gender,Age,Salary,Birthday) values('蘭鵬','5','0','15',default,null)
--但是數值組成的字元串可以不使用''包含
insert into Teacher(Name,ClassId,Gender,Age,Salary,Birthday) values(123,'5','0','15',default,null)
--日期值必須包含在’‘以內,否則就是預設值
insert into Teacher(Name,ClassId,Gender,Age,Salary,Birthday) values('鄒元標2','5','0','15',default,'1991-9-11')
View Code

數據刪除
語法:
delete [from] 表名 where 條件

delete from Teacher where Age<20
--特點:
--1.刪除是一條一條進行刪除的
--2.每一條記錄的刪除都需要將操作寫入到日誌文件中
--3.標識列不會從種子值重新計算,以從上次最後一條標識列值往下計算
--4.這種刪除可以觸發delete觸發器

--truncate table 表名 --沒有條件,它是一次性刪除所有數據
--特點:
--1.一次性刪除所有數據,沒有條件,那麼日誌文件只以最小化的數據寫入
--2.它可以使用標識列從種子值重新計算
--3.它不能觸發delete觸發器
truncate table teacher

數據更新(數據修改):一定需要考慮是否有條件
語法:
update 表名 set 欄位=值,欄位=值 。。where 條件

update Teacher set Gender='true'
--修改時添加條件
update Teacher set Gender=0 where Id=20
--多欄位修改
update Teacher set ClassId=4,Age+=5,Salary=5000 where Id=22
--修改班級id=4,同時年齡》20歲的人員工資+500
update Teacher set Salary=Salary+500 where ClassId=4 and Age>20

數據檢索--查詢
語法: *代表所有欄位
select */欄位名稱列表 from 表列表

select StudentNo,StudentName,Sex,[Address] from Student
--可以為標題設置  別名,別名可以是中文別名
select StudentNo as 學號,StudentName 姓名,性別=Sex,[Address] from Student
--添加常量列
select StudentNo as 學號,StudentName 姓名,性別=Sex,[Address] ,國籍='中華人民共和國' from Student
--select的作用
--1.查詢
--2.輸出
select 1+1
--+是運算符,系統會自動為你做類型轉換
select 1+'1'
select '1'+1
--如果+兩邊都是字元串,那麼它就是一字元串連接符
select '1'+'1'
select 'a'+1
--可以輸出多列值
select 1,2,34,3,545,67,567,6,7
--Top、Distinct
select * from Student
--top可以獲取指定的記錄數,值可以大於總記錄數.但是不能是負值
select top 100 * from Student
--百分比是取ceiling()
select top 10 percent * from Student

--重覆記錄與原始的數據表數據無關,只與你查詢的結果集有關係 distinct可以去除結果集中的重覆記錄--結果集中每一列的值都一樣
select distinct LoginPwd,Sex,Email from Student
select distinct Sex from Student
select的作用
--聚合函數:
--1.對null過濾
--2.都需要有一個參數
--3.都是返回一個數值
--sum():求和:只能對數值而言,對字元串和日期無效
--avg():求平均值
--count():計數:得到滿足條件的記錄數
--max():求最大值:可以對任意類型的數據進行聚合,如果是字元串就比較拼音字母進行排序
--min():求最小值
--獲取學員總人數
select COUNT(*) from Student
--查詢最大年齡值
select  MIN(BornDate) from Student
select  max(BornDate) from Student

--查詢總分
select SUM(StudentResult) from Result where StudentNo=2
--平均分
select avg(StudentResult) from Result where SubjectId=1
--註意細節:
select  SUM(StudentName) from Student
select  SUM(BornDate) from Student

select  min(StudentName) from Student
select  max(StudentName) from Student

--查詢學號,姓名,性別,年齡,電話,地址 ---查詢女生
select StudentNo,StudentName,Sex,BornDate,Address from Student where Sex='' and BornDate >'1990-1-1' and Address='廣州傳智播客'
--指定區間範圍
select StudentNo,StudentName,Sex,BornDate,Address from Student where  BornDate >='1990-1-1' and BornDate<='1993-1-1'
--between...and  >=  <=
select StudentNo,StudentName,Sex,BornDate,Address from Student where BornDate  between '1990-1-1' and '1993-1-1'
--查詢班級id  1  3 5  7的學員信息
select * from Student where ClassId=1 or ClassId=3 or ClassId=5 or ClassId=7
--指定具體的取值範圍--可以是任意類型的範圍.值的類型需要一致--可以相互轉換
select * from Student where ClassId in(1,3,'5',7)
select * from Student where ClassId not in(1,3,'5',7)
聚合函數
--帶條件的查詢-模糊查詢-- 只針對字元串而言

--查詢  姓 林 的女生信息
--=是一種精確查詢,需要完全匹配
select * from Student where Sex='' and StudentName=''
--通配符--元字元
--%:任意個任意欄位  window:*  正則表達式 :.*
--_:任意的單個字元
--[]:代表一個指定的範圍,範圍可以是連續也可以是間斷的。與正則表達式完全一樣[0-9a-zA-Z].可以從這個範圍中取一個字元
--[^]:取反值
select * from Student where Sex='' and StudentName='林%'
--通配符必須在模糊查詢關鍵的中才可以做為通配符使用,否則就是普通字元
--like   像 。。。。一樣
select * from Student where Sex='' and StudentName  like '林%'
select * from Student where Sex='' and StudentName  like '林_'
--[]的使用  學號在11~15之間的學員信息
select * from Student where StudentNo like '[13579]'

---處理null值
--null:不是地址沒有分配,而是不知道你需要存儲什麼值  所以null是指   不知道。但是=只能匹配具體的值,而null根本就不是一個值
select COUNT(email) from Student where Email !=null
select COUNT(email) from Student where Email  is null
select count(email) from Student where Email  is not null
--將null值替換為指定的字元串值
select StudentName,ISNULL(Email,'沒有填寫電子郵箱') from Student where ClassId=2
模糊查詢
--當你看到  每一個,,各自,不同,,分別  需要考慮分組
--查詢每一個班級的男生人數
--與聚合函數一起出現在查詢中的列,要麼也被聚合,要麼被分組
select classid,Sex,COUNT(*) from Student where Sex='' group by ClassId,sex
--查詢每一個班級的總人數,顯示人數>=2的信息
--1.聚合不應出現在 WHERE 子句中--語法錯誤
select ClassId ,COUNT(*) as num from Student where Email is not null   GROUP by ClassId having COUNT(*)>=2 order by num desc
--完整的sql查詢家庭
 --5                            1                      2                                 3                                     4                                           6                                                 
--select 欄位列表 from 表列表  where 數據源做篩選 group by 分組欄位列表 having 分組結果集做篩選 Order by  對結果集做記錄重排

select ClassId ,COUNT(*) as num from Student where Email is not null   GROUP by ClassId order by ClassId desc

--關於top的執行順序 排序之後再取top值
select top 1 ClassId ,COUNT(*) as num from Student  GROUP by ClassId  order by num desc
分組統計

7.類型轉換函數

--select :輸出為結果集--虛擬表
--print:以文本形式輸出  只能輸出一個字元串值.

print 1+'a'
select 1,2

select * from Student

--類型轉換
--Convert(目標類型,源數據,[格式]) --日期有格式
print '我的成績是:'+convert(char(3),100)

print '今天是個大日子:'+convert(varchar(30),getdate(),120)
select getdate()
select len(getdate())

--cast(源數據  as  目標類型)  它沒有格式
print '我的成績是:'+cast(100 as char(3))

8.日期函數

--getdate():獲取當前伺服器日期
select GETDATE()
--可以在源日期值是追加指定時間間隔的日期數
select DATEADD(dd,-90,GETDATE())
--dateDiff:找到兩個日期之間指定格式的差異值
select StudentName,DATEDIFF(yyyy,getdate(),BornDate) as age from Student order by  age
--
              
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在Linux系統當中,如何搜、索查找文件裡面的內容呢? 這個應該是系統維護、管理當中遇到最常見的需求。那麼下麵介紹,總結一下如何搜索、查找文件當中的內容。 搜索、查找文件當中的內容,一般最常用的是grep命令,另外還有egrep, vi命令也能搜索文件裡面內容 1:搜索某個文件裡面是否包含字元串,使... ...
  • 1.定義 進程是具有一定獨立功能的程式關於某個數據集合上的一次運行活動,進程是系統進行資源分配和調度的一個獨立單位。 線程是進程的一個實體,是CPU調度和分派的基本單位,它是比進程更小的能夠獨立運行的基本單位。線程自己不擁有系統資源,與和它同在一個進程中的其他線程共用進程所擁有的系統資源。 2.關係 ...
  • 1. 安裝一個小程式:Add_Open_Command_Window_Here.reg 2. 選中一個文件夾,按住“Shift”+右鍵,出來 3. 自動跳出命令行視窗 ...
  • 安裝軟體時遇到這樣的情況:我就是管理員許可權啊,怎麼會安裝有問題呢? 後來知道,用戶名即使分配了你是管理員許可權,有些文件還是有限制的(特別是C盤) 昨天遇到一個問題,有個文件夾里的隱藏文件就是無法顯示,做瞭如下操作: 選中文件夾右鍵“屬性”—“安全”—添加“Everyone”,把所有許可權勾上。 ...
  • 1. 點擊“組織”,再選擇“文件夾和搜索選項”命令。 2. 接下來在打開的“文件夾選項”對話框中,單擊“查看”,切換到“查看”選項卡中。 3. 然後在下麵的“高級設置”區域,取消“隱藏受保護的操作系統文件”前面的覆選框;再選擇下麵的“顯示隱藏的文件、文件夾和驅動器”單選項。 4. 最後單擊“確定”按 ...
  • 一、線程屬性 可以使用pthread_attr_t結構修改線程預設屬性,並這些屬性和創建的線程練習起來,可以使用pthread_att_init函數初始化pthread_attr_t結構,調用pthread_attr_init後,pthread_attr_t結構所包含的就是操作系統實現支持的所有線程 ...
  • ELF:可執行二進位文件的存儲格式 可執行的,可鏈接的文件 文件系統: rootfs :根文件系統 ls / /boot:系統啟動相關的文件,如內核、initrd、以及grub(引導載入器bootloader) vmlinux-2.6.18-308.el5 initrd-2.6.18-308.el5 ...
  • 1.前言 在學習Socket之前,先來學習點網路相關的知識吧,自己學習過程中的一些總結,Socket是一門很高深的學問,本文只是Socket一些最基礎的東西,大神請自覺繞路。 傳輸協議 TCP:Transmission Control Protocol 傳輸控制協議TCP是一種面向連接(連接導向)的 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...