SQL-Tool-LX2018

来源:https://www.cnblogs.com/LX2018/archive/2018/05/25/LX2018.html
-Advertisement-
Play Games

--創表示例 create table testtab( id int primary key identity(20180,1), -- identity 是自增 (起始值,每次增值) -- primary key 主鍵唯一,且不能為空 name varchar(20), --欄位設置唯一值(un ...


--創表示例

create table testtab(
   id int primary key identity(20180,1),   -- identity 是自增  (起始值,每次增值)   -- primary key 主鍵唯一,且不能為空
   name varchar(20),  --欄位設置唯一值(unique)(可為空)    -- name varchar(20)  unique
   phone varchar(20),
   age int,
   birth date      --時間2018-05-24    datetime(yy-mm-dd(hh-mm-ss))
);

--插

insert  into  testtab values('LX','15066668888',20,'2018-5-24');  --向表中插入數據   (預設對應列)

insert  into  testtab(name,phone,age,birth) values('LX','15066668888',20,'2018-5-24');  --向表中插入數據   (一一對應列)

--結構相同的子表

create table testtabson(
   id int primary key identity(20180,1),
   name varchar(20),
   phone varchar(20),
   age int,
   birth date
);

--插表數據到子表(這種方法,可以用,簡單易懂易操作;另一種是用資料庫直接生成腳本,然後改下表名就可以了(就不示例了,想實踐可聯繫我,也可查資料))

insert into testtabson (name,phone,age,birth)
select name,phone,age,birth
from testtab

--更新(修改)

update testtab set age=18 where id=1

--刪除

drop table testtab  --註意:要刪除表,要確定表是其他表的外鍵,是,則刪不掉的,必須找到關聯的主表,刪除後再刪該表;或者刪除外鍵後,再刪除表

delete from testtab where id=1  --刪除該行數據

--查(方法很多,多總結,也就那麼幾種常用的)

select * from testtab  --最簡單查最全(“*”表的所有欄位)

select  age from testtab where id=1  --查詢滿足條件的

select age as a from testtab   --查詢結果改列名    as可改列名 可改表名(連表時用,很簡潔)  --註意:虛擬存在,其實表結構(列名,表名)並沒有修改,我是這樣理解的;真正的修改是alter,後面會有示咧。

select name from testtab where age is null   --查詢age是空的name行  (不,請加not)

select name, 'sex' as 男 from testtab  --常量  “sex”也是虛擬的欄位,“男”是列值

select top 2 name from testtab  --查詢name的前兩條

select top 20 percent name from testtab   --查詢name的20%

select * from where (not)in(all,any,exist)  age>(select *....)   where子查詢,簡單說一下,因為查詢方式很多,就看你想要的是什麼結果,還可以和聚合函數,分組,排序聯合用;但結構差不多是這樣的。

select SQnumber,t.score from(select Row_number() over(order by score desc)SQnumber,a.id,a.score from MP_partyscore a join MP_partymemberdata b on a.id=b.id)t where id=      滿足條件的分數排名(上次自己遇到的問題)  這個其實也不複雜,難得想。

--排序

select name from testtab order by id desc  --降序   升序(asc)

--“喜歡”才像

select * from testtab where name like 'L%'    --註意:“like”只能查字元串,“%”代表省略的

--兩者之間

select * from testtab where age between 18 and 20  

  --在裡面(in)

select name from testtab where age in (20,18,16)    --“in“括弧里可換成查詢語句,就是子查詢了

--分組查詢(gruop by 搭配having)

select id,count(name) as a from testtab group by id having id>20185   --group by要在聚合函數(count(),avg(),sum())中使用,having增加限制條件

--連表(現在就要用as來簡化)

select * from testtab as a join testtabson as b on a.id=b.id    --不加inner預設是內聯  (left outer 左外  right outer 右外  當然也不列外,有左右內連)

--欄位類型

image  存儲圖片

bit  bool數字類型  預設true或false 值預設1或0  插入任何數字類型(除預設外)都顯示值1,只有true和false以字元串的格式可插入,顯示對應預設值1或0  (不能理解也沒啥,bit不常用)

money  自然是存錢的咯,而且精度高

float  存儲數字,單精度    小數,存進去是啥就是啥  可與數字類型比較,做運算

decimal   精確數字型   如:decimal(5,2)   共五位數,保留兩位小數

text  字元型,存儲大量的非統一編碼型字元數據

--轉換類型

--convert(數據類型[(長度)],表達式[格式])

select convert(nvarchar,name) return  name    參數1:想要轉成的數據類型;參數2:可以是表的列名,也可以是自定義參數值    註意:字元串轉數字類型,要保證字元串是數字類型;通俗的說是:字元串轉換後就必須是數字。
select N’年齡:’+convert(nvarchar,20)    加N編碼漢字,不然資料庫會不顯示完整的漢字(可以說是亂碼)

select convert(nvarchar ,getdate(),120)          返回 2018-05-25 12:22:21    getdate() 獲取當前時間   也可以替換成某表的時間列欄位(記得加上屬於那個表喲) 120是固定值   如select convert(nvarchar,birth,120) from testtab
select convert(nvarchar(10) ,getdate(),120)   返回 2018-05-25    類型長度 截取想要的格式    還有其他的方法,改變固定值120,也可以達到不同的格式(111);百度一下,日期格式的轉換,你就知道了。

--cast

select cast(20 as nvarchar)   return  20  同理convert
select N’年齡:’+cast(20 as nvarchar)   return  年齡:20

--截取(left,right,substring)

--left,right

--直接上示咧:left(‘love’,2)  參數一:要截取的字元串;參數二:從左往右截取兩個   示咧:return  lo  同樣參數一可以換成表的列欄位  如:select left(name,1) from testtab   right與之類似,不過是從右往左罷了。

--substring

select substring('love20',2,2) 參數一:要截取的字元串;參數二:起始位置2開始截包含2(下標,索引從1開始);參數三:截取的長度。感覺是不是要高大上一點點。  return ov

--alter

--修改表欄位類型

alter table testtab alter column age varchar(20)   註意:float轉int有數據值時會失敗,float可以和decimal間互轉,decimal記得表明範圍,否則預設為保留整數部分

--給表增加欄位

alter table testtab add love varchar(20)

--給表刪除欄位

alter table testtab drop column love

--給表添加唯一鍵

alter table testtab add constraint uni unique (name,phone)   註意:如果表已經有數據(重覆),修改會失敗  uni自定義約束名

--給表添加主鍵

alter table testtabso add constraint pk_s primary key (id)    註意:限制id要不為空  pk_s自定義主鍵名,一張表有且僅有一個主鍵存在

--給表添加外鍵

alter table testtabson add constraint fk_sid foreign key (sid) references testtab(id);  註意:要分清楚究竟誰是誰的外鍵,再來關聯,關聯欄位要匹配

--刪除(主,外,唯一)鍵

alter table 表名 drop constraint 自定義名(如pk_s,fk_sid,uni)

--觸發器(我覺得挺實用的,在一些表間有關聯時,經常用,而且要同時保證數據,這觸發器,就是神器了,只是我說的太LOW)

create trigger tri_cfq_del
on testtab
for delete  
as
insert into testtabson(name,phone,age,birth)      註意:刪除和插入在 搭配使用時,要用for 在之前就插入;如果說是插入的插入,after和for都可以;欄位可多可少,根據需求來;還有就是delete對應deleted,insert對應insertd  說著逗累,上列子
select name,phone,age,birth from deleted                                      update  更新也差不多,就不多說了,有問題可私聊我,或者查資料。刪除觸發器,drop trigger tri_cfq_del       as後面的T-SQL語句,可根據需要修改,僅供參考。

--執行這個語句,就會觸發    delete from testtab where id=20181

create trigger tri_cfq_ins
on testtab
for(after) insert
as
insert into testtabson(name,phone,age,birth)
select name,phone,age,birth from inserted

--同理   insert into testtab values('520','15066668888',20,'2018-5-24');
--存儲過程

declare @a int
declare @sum int
set @a=1
set @sum=0
while @a<=100
begin
    set @sum+=@a
    set @a+=1
end
print @sum

待完善,會持續更新,關註俺,你逗會發現,其實我也很懶的,只是偶爾裝B

第一次

 


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

-Advertisement-
Play Games
更多相關文章
  • 前面給大家介紹了很多在Linux安裝軟體的知識,這些軟體往往依賴了很多第三方的工具或者軟體,如果在Linux伺服器有外網的情況,咱們可以通過yum install這樣的命令直接去安裝這些相關的工具或者軟體,比如: 但是我們在平時的項目開發和運維當中,伺服器為了安全是不一定會開放外網的,對於部署在內網 ...
  • 我們知道用linux命令rz/sz可以通過一些終端軟體如secureCRT等在linux伺服器與本地windows之間傳文件。在伺服器上rz一下,在本地windows下就跳出一個視窗,選擇文件後就傳到了伺服器上;而在伺服器上用sz命令sz一個文件,在本地電腦硬碟上就有了這個文件。用起來是很方便,但是 ...
  • ##/proc的意義在linux查看各種狀態,其實質是查看內核中相關進程的數據結構中的項通過工具將其格式化後輸出出來。但是內核的數據是絕對不能隨意查看或更改的,至少不能直接去修改。所以,在linux上出現了偽文件系統/proc,它是內核中各屬性或狀態向外提供訪問和修改的介面。##查看進程信息 pst ...
  • 今天淺談一下三大操作系統(Operation System): Windows , MacOS , Linux。 適合碼農使用的操作系統是:MacOS 和 Linux。 簡答做了一個思維導圖如下(僅供參考) 1.操作系統的作用 通過提供系統調用,控制和管理硬體。(應用軟體 --> 操作系統 系統調用 ...
  • 資料庫操作前的準備 -- 創建資料庫 -- create database python_test_1 charset=utf8; -- 使用資料庫 -- use python_test_1; -- students表 -- create table students( -- id int unsi ...
  • 一直用Navicat來對MySQL資料庫進行操作,今天突然想試試用DOS控制台來操作,特記錄自己第一次使用經歷,若有錯誤之處,還望大佬們指點。 首先打開控制台,win+R鍵,輸入cmd,確定 輸入mysql -uroot -p123456 其中root表示你的用戶名,123456是你的資料庫密碼 若 ...
  • 簡單介紹 MySQL 的 SELECT INTO OUTFILE 和 LOAD DATA LOCAL INFILE ...
  • “億牛雲爬蟲代理IP”通過固定雲代理服務地址,建立專線網路鏈接,代理平臺自動實現毫秒級代理IP切換,保證了網路穩定性和速度,避免爬蟲客戶在代理IP策略優化上投入精力 獨享高匿家庭ip,支持隧道模式和api提取.高效穩定可測試基於Linux系統研發的平臺,自營線路,電信機房寬頻,私密家庭IP。平臺註冊 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...