SQL基礎語法的單表操作 select|insert|update|delete(增刪改查) 簡單使用

来源:https://www.cnblogs.com/eyesCentre/archive/2019/04/11/10692787.html
-Advertisement-
Play Games

1、select(查詢) select簡單的查詢分為兩種 註:欄位也就是表結構中的列的名稱 第一種: select 欄位名 from 表名 此種查詢只列出你所需要查詢的欄位,要查詢多個欄位以“,”隔開 第二種: select * from 表名 * 的意思是查詢出此表的所有欄位 額外的內容:dist ...


以下案列以此表舉例

1、select(查詢)

select簡單的查詢分為兩種

註:欄位也就是表結構中的列的名稱

第一種:

select  欄位名  from  表名

此種查詢只列出你所需要查詢的欄位,要查詢多個欄位以“,”隔開   

 

第二種:

select  *  from  表名

 * 的意思是查詢出此表的所有欄位

 

 

額外的內容:distinct關鍵字

select  distinct  欄位名  from  表名

給查詢的結果去重

 

2、insert(插入)

insert插入數據行(記錄)的兩種簡單實現方式

第一種:

insert  into  表名  values(值1,值2...)

 

這種插入數據行的的值必須與表的欄位名一一對應,否則數據會插入失敗給出錯誤提示:

錯誤提示:Column count doesn't match value count at row 1

第二種:

insert  into  表名(欄位名,欄位名...)  values(值1,值2...)

顯而易見,這是指定欄位名來插入數據

 

3、update(更新(修改))

語法:

update  表名  set  欄位名  =  新值  where  欄位名  =   舊值

 

where 後面接條件,條件有多種多樣,後面我會一一說明。在這裡where的意思就是我要修改這個欄位名下的這個舊值,新值寫在set後面

 

4、delete(刪除)

語法:

delete  from  表名  where  欄位名 = 值

 

根據欄位名找到值的這一行記錄就被刪除了

 

where(重點,條件語句)

如果你的語句中有條件,則在語句末尾加上where,再跟上你的條件。例如:

select  *  from  表名  where  欄位名 = 值

delete  from  表名  where  欄位名 = 值

=, >, <, >=, <=, <>(不等於)都適用於where

where用法極其豐富,後面我會一一講解,這裡暫時給點簡單的例子

 

and 和 or(運算符)

and類似於java(不僅僅java)運算符的  &(與),  or類似於  | (或) 。

AND 和 OR 可在 WHERE 子語句中把兩個或多個條件結合起來

and例子:

select  *  from  表名  where  條件1  and  條件2

 

查詢列出滿足條件1條件2的結果

or例子:

select  *  from  表名  where  條件1  or  條件2

 

查詢列出滿足條件1或者條件2的結果(滿足其中一的都列出來)

 

order by(排序)

對結果進行排序

 

order by 寫在語句最後面,給結果集排序。

 

order by 列子:

 

select  欄位1,欄位2  from  表名  order by 欄位1 desc, 欄位2 asc

 

order by asc  升序  查詢出的結果升序

可以沒有order by 後面的關鍵字,那樣就預設asc(升序)

 

order by desc  降序   結果降序

用法大同小異,多種結果也可以多種排序,用","隔開

 

limit(規定返回的數目)

註意:mySQL使用的是limit來規定返回的數目,Oracle的語法是不一樣的

 

在你的select語句後面加上它,可以指定你查詢結果的記錄的條數

列子1:

select  *  from  表名  limit  2

 

查詢列出這張表的前2行的記錄

 

like與通配符

首先我們要知道什麼是通配符,以下就是sql中使用的通配符,但必須和like一起使用

%        替代一個或多個字元

_         只代替一個字元

[charlist]   在字元列中的任何單一字元

[^charlist]

等價於

[!charlist]  不在字元列中的任何單一字元

%通配符:

select  *  from  表名  where  欄位名  like  'xx%'

 

查詢列出此欄位以xx開頭的記錄

 

 

select  *  from  表名  where  欄位名  like  '%xx%'

 

查詢列出此欄位包含xx的記錄

_:

select  *  from  表名  where  欄位名  like  '_xx'

 

查詢列出此欄位先以一個任意字元開頭,後面為xx的記錄

 

 

select  *  from  表名  where  欄位名  like  '_x_x_'

 

查詢列出此欄位先以一個任意字元開頭,後面為x,又接一個任意字元,又接一個x,再接一個任意字元的記錄

[charlist]:

select  *  from  表名  where  欄位名  regexp  '[abc]%'

 

查詢列出此欄位以a或b或c開頭的記錄,這裡沒用到  like   關鍵字,是因為mysql的語法用regexp(正則表達式)代替了

[!charlist]:

select  *  from  表名  where  欄位名  like  '[!abc]%'

查詢列出此欄位不以a或b或c開頭的記錄

 

in

前面我們可以根據具體的欄位來查詢記錄比如:

where  欄位名 in 值

where  欄位名 in (值1,值2,值3....)

有了in我們可以規定多個值

 

 

between

BETWEEN ... AND 會選取介於兩個值之間的數據範圍。這些值可以是數值、文本或者日期

select  *  from  表名  where  欄位名  between  左範圍  and  右範圍

這裡提個醒,mysql的between語法的查詢結果會包含左範圍和右範圍,也就是>=和<=,其他的資料庫可能會有別的變動,在這裡我只用mysql舉例

 


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

-Advertisement-
Play Games
更多相關文章
  • 趁著這波比較閑的時候來劃一波水,想起自己那都快生會的騰訊雲伺服器 到現在還不能通過版本控制系統上傳文件,於是趁這波功夫在伺服器上安裝個svn來管理代碼。 首先就簡單的介紹一波 svn : 首先svn不同於GIT它是集中式的,即只有一條主線並沒有分支,Subversion(SVN) 是一個開源的版本控 ...
  • Linux 中主要有五種IO模式:阻塞IO, 非阻塞IO, IO 多路復用,信號驅動IO和非同步IO; 如果從同步非同步,阻塞非阻塞角度來看,又可以分為:同步阻塞IO, 同步非阻塞IO,非同步阻塞IO和非同步非阻塞IO; 每種IO模型,都有自己的使用模式,他們對於特定的應用程式都有自己的優點:其簡單分佈如 ...
  • FIO是測試IOPS的非常好的工具,用來對硬體進行壓力測試和驗證。磁碟IO是檢查磁碟性能的重要指標,可以按照負載情況分成照順序讀寫,隨機讀寫兩大類。 目前主流的第三方IO測試工具有fio、iometer 和 Orion,這三種工具各有千秋,在linux 下也可以使用dd 進行簡單的磁碟(文件系統)測 ...
  • 1、下載壓縮包:https://github.com/opencv/opencv,在Branch欄選擇3.4版本,clone下載 2、安裝cmake及依賴庫,打開終端,輸入以下命令: 3、解壓所下載的壓縮包,在包含有CmakeList.txt文件的目錄下右鍵打開終端: 新建文件夾build,並切換到 ...
  • 1.前提 由於之前一直用的機械硬碟,電腦用了幾年是越來越慢,所以打算買個SSD,裝個新系統,其他的機械硬碟都當從盤用 2.準備工作 SSD :256G 3星的 WIN10正版光碟一張 外置光碟機一個 3.踩坑 不知是光碟機問題還是光碟問題,在pc上始終識別失敗,導致始終報錯“reboot and sel ...
  • MYSQL ERROR 2003 (HY000): Can't connect to MySQL server on '192.168.10.210' (111) 解決方法 今天在測試MySQL的連接時候,發現連接不通過,並報錯ERROR 2003 (HY000): Can't connect to ...
  • 1. 數據的抽取 1.1 從資料庫中抽取數據生成本地文件 1.1.1 將“數據流任務”控制項拖入“控制流”視窗 1.1.2 選擇數據源 1.1.2.1 將““OLE DB 源””拖入“數據流”視窗,雙擊編輯屬性 1.1.2.2 新建“連接管理器”,輸入資料庫名稱,選擇連接方式,選擇資料庫名,嘗試連接成 ...
  • 一、主拓展模式 主擴展模式通常用來將幾個相似的對象的共有屬性抽取出來,形成一個”公共屬性表“,且“公共屬性表”與“專有屬性表”是“一對一”的關係。“專有屬性表”可以看做是“公共屬性表”的 擴展,兩者合在一起就是對一個特定對象的完整描述,故此得名“主擴展模式”。 主要適用於,對象的個數不多,各個對象之 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...