【MySQL】從零開始:掌握MySQL數據庫的核心概念(四)

人們之所以不愿改變,是因為害怕未知。但歷史唯一不變的事實,就是一切都會改變。?

前言

?這是我自己學習mysql數據庫的第四篇博客總結。后期我會繼續把mysql數據庫學習筆記開源至博客上。

? 上一期筆記是關于mysql數據庫的表格約束,沒看的同學可以過去看看:

【MySQL】從零開始:掌握MySQL數據庫的核心概念(三)-CSDN博客https://blog.csdn.net/hsy1603914691/article/details/146385371

表格的增刪查改

增?

正常插入

//指定列單行插入
insert into tb_name() values();
//全列單行插入
insert into tb_name values();
//指定列多行插入
insert into tb_name() values(),();
//全列多行插入
insert into tb_name values(),();

沖突插入?

//插入更新
insert into tb_name() values() 
on duplicate key update column_name1=xxx,column_name2=yyy,...;
//替換更新
replace into tb_name() values(); 

1. 此時無法正常插入,已經存在沖突數據主鍵值重復或者唯一鍵值重復

2. insert into插入更新時,會存在以下情況:

  • -- 0 row affected: 表中有沖突數據,但沖突數據的值和update的值相等。
  • -- 1 row affected: 表中沒有沖突數據,數據被插入。
  • -- 2 row affected: 表中有沖突數據,并且數據已經被更新。

3. replace into替換更新時,會存在以下情況:

  • -- 1 row affected: 表中沒有沖突數據,數據被插入。
  • -- 2 row affected: 表中有沖突數據,刪除后重新插入。

查詢插入

insert into tb_name select ...;

1. 除了向表格中插入具體的數據,還可以向表格中插入查詢出來的數據。?

刪?

delete子句-turncate子句

//刪除表格的數據
delete from tb_name ...;
//重置表格
turncate table tb_name;

1. turncate只能對整個表格進行操作,不能像delete一樣針對部分數據操作。

2.?turncate會重置auto_increment項。

3.?實際上turncate不對數據操作,所以比delete更快,但是turncate在刪除數據的時候,并不經過真正的事物,所以無法回滾。

查?

整體查詢

//全列查詢
select * from tb_name;
//指定列查詢
select column_name1 column_name2 from tb_name;
//表達式運算查詢
select column_name1 as new_name1 column_name2+column_name3+num as new_name2 from tb_name;
//去重查詢
select distinct column_name1 from tb_name;

1. 通常情況下不建議使用全列查詢

  • 查詢的列越多,意味著需要傳輸的數據量越大。
  • 可能會影響到索引的使用。

條件查詢

運算符
算術運算符
>,>=,<,<=
大于,大于等于,小于,小于等于
=
等于
!=
不等于
between a and b
范圍匹配, [a,b] ,如果 a<=value<=b ,返回 true(1)
in(option,...)
如果是 option中的任意一個,返回true(1)
is null
null
is not null不是null
like
模糊匹配。其中 % 表示任意多個(包括 0 個)任意字符;其中 _ 表示任意一個字符。
邏輯運算符
and與運算
or并運算
not非運算
where子句
select ... from ... where ...

1. 語法上,先執行from...,再執行where...,最后執行select...。所以在where子句中,不能使用select...中定義的別名。

2. where子句中可以使用圓括號()來限制先后邏輯。

改?

修改數據

update tb_name set column_name_change ...;

1. column_name_change大部分以重新賦值的形式呈現。

查詢排序?

//升序
asc
//降序
desc
//
select ... from ... where ... order by column_name sort_order;

1. 在order by子句中,默認升序排序

2. NULL值也參與排序,但是視為比任何值都小

3. 語法上,先執行from...,再執行where...,然后執行select...,最后執行order by...。所以在where子句中,不能使用select...中定義的別名,但是在order by子句中,可以使用select...中定義的別名。

分頁篩選?

//從下標為0的數據開始,往后篩選n條數據
select ... from ... where ... limit n;
//從下標為s的數據開始,往后篩選n條數據
select ... from ... where ... limit n offset s;

1.?對未知表進行查詢時,最好加上:limit 1。避免因為表中數據過大,查詢全表數據導致數據庫卡死。

聚合函數

count()
返回查詢到的數據的數量
sum()
返回查詢到的數據的總和,不是數字沒有意義
avg()
返回查詢到的數據的平均值,不是數字沒有意義
max()
返回查詢到的數據的最大值,不是數字沒有意義
min()
返回查詢到的數據的最小值,不是數字沒有意義
select func(column_name) from tb_name;

1. 聚合函數視為一個整體,相當于一個新的變量

分組查詢?

select func(column_name1) from tb_name group by column_name2 having ...;

1. 分組的目的是為了更好的進行分組聚合統計

2. 分組的依據一般是指定的列名,根據該列的不同數據來進行分組。

3. where主要是對具體的某一列進行條件篩選,having主要是對分組后的結果進行條件篩選。

4. wherehaving的條件篩選的階段是不同的。

致謝?

??感謝您花時間閱讀這篇文章!如果您對本文有任何疑問、建議或是想要分享您的看法,請不要猶豫,在評論區留下您的寶貴意見。每一次互動都是我前進的動力,您的支持是我最大的鼓勵。期待與您的交流,讓我們共同成長,探索技術世界的無限可能!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/74054.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/74054.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/74054.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Manus:通用智能體的架構革命與產業破局

&#x1f90d; 前端開發工程師、技術日更博主、已過CET6 &#x1f368; 阿珊和她的貓_CSDN博客專家、23年度博客之星前端領域TOP1 &#x1f560; 牛客高級專題作者、打造專欄《前端面試必備》 、《2024面試高頻手撕題》、《前端求職突破計劃》 &#x1f35a; 藍橋云課簽約作者、…

HTTP協議手寫服務器

目錄 一、請求的是Web根目錄 二、GET方法通過URL傳參 三、根據資源類型對應出Content-Type值 四、Http代碼 項目完整源代碼&#xff1a;Http 周不才/cpp_linux study - 碼云 - 開源中國 一、請求的是Web根目錄 如果URL中請求的資源是Web根目錄&#xff0c;則自動跳轉到主…

小藍和鑰匙

錯位排序組合數 從28個人里面選14個人分到原來房間的鑰匙 C 28 14 另外14個人錯位排序 模板 請在此處填寫你的解題思路 D14 都是模板記住就好了 無需理解 做題可以看出來是錯位排序 或者組合數 然后會寫代碼就行了 import java.util.Scanner;/*** author zb* date2025/3…

使用飛書API自動化更新共享表格數據

飛書API開發之自動更新共享表格 天馬行空需求需求拆解1、網站數據爬取2、飛書API調用2.1 開發流程2.2 創建應用2.3 配置應用2.4 發布應用2.5 修改表格權限2.6 獲取tenant_access_token2.7 調用API插入數據 總結 天馬行空 之前一直都是更新的爬蟲逆向內容&#xff0c;工作中基本…

Python-Django入手

18.1 建立項目 18.1.1 制定規范 - 定義項目目標&#xff1a;明確應用的核心功能 - 創建項目文檔&#xff1a;用README.md記錄技術棧和開發流程 - 規劃目錄結構&#xff1a;建議遵循Django官方推薦的項目布局 18.1.2 建立虛擬環境 在命令行執行&#xff1a; python -m ven…

LangChain4j 入門(二)

LangChain 整合 SpringBoot 下述代碼均使用 阿里云百煉平臺 提供的模型。 創建項目&#xff0c;引入依賴 通過 IDEA 創建 SpringBoot 項目&#xff0c;并引入 Spring Web 依賴&#xff0c;SpringBoot 推薦使用 3.x 版本。 引入 LangChain4j 和 WebFlux 依賴 <!--阿里云 D…

3.30學習總結 Java包裝類+高精度算法+查找算法

包裝類&#xff1a; 基本數據類型對應的引用數據類型。 基本數據類型&#xff1a;在內存中記錄的是真實的值。 八種包裝類的父類都是Object類。 對象之間不能直接進行計算。 JDK5之后可以把int和integer看成一個東西&#xff0c;因為會進行內部優化。自動裝箱和自動拆箱。 …

centos 7 LVM管理命令

物理卷&#xff08;PV&#xff09;管理命令 pvcreate&#xff1a;用于將物理磁盤分區或整個磁盤創建為物理卷。 示例&#xff1a;sudo pvcreate /dev/sdb1 解釋&#xff1a;將 /dev/sdb1 分區創建為物理卷。 pvdisplay&#xff1a;顯示物理卷的詳細信息&#xff0c;如大小、所屬…

借助FastAdmin和uniapp,高效搭建AI智能平臺

在數字化辦公時代&#xff0c;效率與協作是企業發展的核心競爭力。傳統的辦公工具雖然功能豐富&#xff0c;但在面對復雜多變的團隊協作需求時&#xff0c;往往顯得力不從心。為了解決這一痛點&#xff0c;我們推出了一款全新的辦公AI平臺&#xff0c;它不僅能夠滿足文字和語音…

項目上傳github——SSH連接配置文檔

1. 檢查是否已有 SSH 密鑰 打開終端&#xff0c;檢查是否已經存在 SSH 密鑰對&#xff1a; ls ~/.ssh如果你看到類似 id_rsa 和 id_rsa.pub 的文件&#xff0c;說明你已經有 SSH 密鑰。否則&#xff0c;繼續下一步。 2. 生成 SSH 密鑰 如果你沒有 SSH 密鑰&#xff0c;使用…

傳奇類網游頁游2.5D游戲場景地圖素材Eagle庫 沙漠沙海隔壁

傳奇類網游頁游2.5D游戲場景地圖素材Eagle庫 沙漠沙海隔壁 鏈接: https://pan.baidu.com/s/1GY8N-KEkHBGEbS7uxrE4Dg 提取碼: yrs8 備用下載地址&#xff1a;http://pan.1234f.com:5212/s/rLzIp 電子資料文檔&#xff1a;https://www.1234f.com/sj/GitHub/sucai/20250327/1323…

通過TIM+DMA Burst 實現STM32輸出變頻且不同脈沖數量的PWM波形

Burst介紹&#xff1a; DMA控制器可以生成單次傳輸或增量突發傳輸&#xff0c;傳輸的節拍數為4、8或16。 為了確保數據一致性&#xff0c;構成突發傳輸的每組傳輸都是不可分割的&#xff1a;AHB傳輸被鎖定&#xff0c;AHB總線矩陣的仲裁器在突發傳輸序列期間不會撤銷DMA主設備…

鴻蒙學習手冊(HarmonyOSNext_API16)_數據持久化③:關系型數據庫

概述 關系型數據庫&#xff1a;像“Excel表格聯合作戰”的管家 關系型數據庫就像一個超級智能的表格管理系統&#xff0c;專門處理數據之間有復雜關聯的情況。比如學生和成績、訂單和商品、用戶和評論——這些數據像蜘蛛網一樣相互連接&#xff0c;用鍵值數據庫的“獨立抽屜”…

Windows 11 VS Code C/C++ 開發環境搭建——一種盡量“綠色”的方法

我的電腦是Windows 11 系統&#xff0c;安裝了Visual Studio Code&#xff0c;在上面搭建C/C開發環境&#xff0c;當然&#xff0c;這需要用到MinGW之流了。作為一個綠色愛好者&#xff08;帽子除外&#xff09;&#xff0c;我也盡量綠色地架設這樣一個環境…… 第一步&#x…

mysql-分區和性能

mysql自身只支持表的橫向分區。 常聽到開發人員說“”對表做個分區“&#xff0c;然后數據的查詢就會快了。這是真的嗎&#xff1f;實際上可能跟根本感覺不到查詢速度的提升&#xff0c;甚至會發現查詢速度急劇下降。因此&#xff0c;在合理使用分區之前&#xff0c;必須了解分…

DeepSeek協助優化-GTX750Ti文物顯卡0.65秒卷完400MB float 音頻512階時域FIR

文章目錄 1. 學習目的2. 階段成果2.1 NVVP 性能探查2.2 測試編譯環境2.3 測試樣例 3 學習過程3.1 提問DeepSeek3.2 最終代碼 4. 體會 1. 學習目的 最近在學習cuda&#xff0c;準備給我的taskBus SDR添加CUDA的模塊支持&#xff0c;以便可以用PC機壓榨山寨 B210那56M的帶寬。 因…

RabbitMQ高級特性--TTL和死信隊列

目錄 1.TTL 1.1設置消息的TTL 1.1.1配置交換機&隊列 1.1.2發送消息 1.1.3運行程序觀察結果 1.2設置隊列的TTL 1.2.1配置隊列和交換機的綁定關系 1.2.2發送消息 1.2.3運行程序觀察結果 1.3兩者區別 2.死信隊列 2.1 聲名隊列和交換機 2.2正常隊列綁定死信交換機 …

【JavaEE】UDP數據報套接字編程

目錄 網絡編程基礎 基本概念 發送端和接收端 請求和響應 客戶端和服務端 常見的客戶端服務端模型 Socket套接字 TCP/UDP特點 Java數據報套接字通信模型(UDP通信) UDP數據報套接字編程 DatagramSocket 1.類定義 2.構造方法 3.核心方法 4.特性說明 DatagramPacke…

Spring Boot 3.4.3 基于 SpringDoc 2 和 Swagger 3 實現項目接口文檔管理

在現代企業級應用開發中&#xff0c;前后端分離已成為主流模式&#xff0c;前端負責界面呈現&#xff0c;后端專注提供 RESTful API 接口。然而&#xff0c;接口文檔的編寫和維護往往是開發過程中的痛點。Spring Boot 3.4.3 結合 SpringDoc 2 和 Swagger 3&#xff0c;為開發者…

構建大語言模型應用:數據準備(第二部分)

本專欄通過檢索增強生成&#xff08;RAG&#xff09;應用的視角來學習大語言模型&#xff08;LLM&#xff09;。 本系列文章 簡介數據準備&#xff08;本文&#xff09;句子轉換器向量數據庫搜索與檢索大語言模型開源檢索增強生成評估大語言模型服務高級檢索增強生成 RAG 如上…