mysql學習-常用sql語句

1、安裝mysql參考網上鏈接,進入mysql數據庫

mysql -u root -p

2、數據庫操作

2.1、創建數據庫

create database `數據庫名` default character set utf8;

2.2、顯示所有數據庫

show databases;

2.3、選擇數據庫

use elementInfo;

2.4、刪除數據庫

drop database `數據庫名`;

3、表操作

3.1、創建表

CREATE TABLE `class`(
`cid` int(3) NOT NULL AUTO_INCREMENT,
`caption` varchar(32) NOT NULL,
PRIMARY KEY(`cid`)
) ENGINE=INNODB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;

在數據庫中創建一個名位class的表。

cid int(3) NOT NULL? AUTO_INCREMENT:定義了一個名為cid的整數類型字段,顯示寬度被指定為3,此字段是自動遞增的(AUTO_INCREMENT),意味著每添加一條新記錄時,如果沒有明確的指定cid值,數據庫會自動為其分配一個唯一的遞增值。此外,由于設置了NOT NULL,所以每一行都必須為此列提供一個值,但由于它是自動遞增的,實際上不需要手動提供。

PRIMARY KEY(cid): 指定cid為主鍵,這表示它在一個表中的每一行中都必須有唯一值,并且用來唯一標識表中的記錄。

ENGINE=INNODB:指定了存儲引擎為InnoDB。

AUTO_INCREMETN=5:設置了自增的起始值為5,剛開始向表中插入新紀錄時,第一條記錄的cid將從5開始計數。

DEFAULT CHARSET=utf8:設置了表的默認字符集為utf8。

備注:實際寫sql語句時,也可以使用Navicat Premium客戶端,操作會方便一些

3.2、查看表相關信息(包括列名、數據類型、是否允許NULL、鍵信息等)

desc 表名

3.3、增加數據

INSERT INTO `class` VALUES ('1', '2021年');
INSERT INTO `class` VALUES ('2', '2021年');
INSERT INTO `class` VALUES ('3', '2022年');

3.4、刪除表

drop table `表名`

3.5、刪除表中數據

delete from `表名` where 條件

3.6、改表中數據

update table_name set field1=new_value1;

4、各種查詢語句

4.1、全部查詢

-- 全部查詢
select * from student;

4.2、只查詢部分字段

-- 只查詢部分字段
select `sname`,`class_id` from student;

4.3、別名、列名(相當于給列起別名)

select `sname` as '姓名',`class_id` as '班級id' from student;

4.4、把查詢出來的結果重復記錄去掉

-- 把查詢出來的結果的重復記錄去掉
select distinct `class_id` from student;

4.5、條件查詢

-- 查詢姓名為 張三 的學生信息select* from `student` where `sname` = '張三';-- 查詢性別為 男 并且班級為2 的學生信息
select* from `student` where `gender` = '男' and `class_id`=2;

4.6、范圍查詢

-- 查詢班級id 1 到 3 的學生信息
select * from student where `class_id` BETWEEN 1 AND 3;

4.7、判空查詢

-- 判斷不為空字符串
select * from student where `gender` <> '';-- 判斷為空字符串
select * from student where `gender` = '';

4.8、模糊查詢

-- 使用like關鍵字,"%"代表任意數量的字符,"_"代表占位符
-- 查詢名字為 李 開頭的學生信息
select * from student where `sname` like '李%';-- 查詢第二個字為 四的學生信息
select * from student where `sname` like '_四%';

4.9、分頁查詢

-- 分頁查詢主要用于查看第N條 到 第M條的信息,通常和查詢一起使用
-- 使用limit關鍵字,第一個參數表示從第幾條開始,第二個參數表示要顯示的數目
select * from student limit 0,3;

4.10、查詢后排序

-- 關鍵字order by field asc:升序 desc:降序
select* from `score` order by `num` asc;-- 按照多個字段排序
select* from `score` order by `course_id` desc, `num` desc;

4.11、聚合查詢

-- 分組加group_cat
-- 按性別分組,并把班級id聚合起來
select `gender`, group_concat(`class_id`) as '班級id' from student group by `gender`;-- 按性別分組,統計男生、女生人數
select `gender`, count(*) as '總數' from student group by 'gender';

4.12、聯表查詢

INNER JOIN:只取倆張表有對應關系的記錄
LEFT JOIN:在內連接的基礎上保留左表沒有對應關系的記錄

RIGHT JOIN:在內連接的基礎上保留右表沒有對應關系的記錄

-- 表course 和 表teacher中id相同,獲取cid信息
select `cid` from `course` INNER JOIN `teacher` on course.teacher_id = teacher.tid

4.13、子查詢/合并查詢

-- 相當于select返回的結果,又作為另一個select語句的輸入
select * from `course` where teacher_id = (select tid from teacher where tname = '謝小二老師');

備注:要多動手練練

學習鏈接:https://github.com/0voice

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

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

相關文章

(全)2024下半年真題 系統架構設計師 綜合知識 答案解析01

系統架構設計師第二版教程VIP課程https://edu.csdn.net/course/detail/40283 操作系統 下列選項中不能作為預防死鎖措施的是 。 A. 破壞“循環等待"條件 B. 破壞“不可搶占”條件 C. 破壞“互斥”條件 D. 破壞“請求和保持”條件 答案&#xff1a;C 解析&…

Java泛型程序設計使用方法

Java泛型程序設計是Java語言中一項強大的特性&#xff0c;它允許你編寫更加通用和類型安全的代碼。以下是Java泛型程序設計的使用方法和技巧&#xff1a; 1. 基本概念 泛型類&#xff1a;可以定義一個類&#xff0c;其中的某些類型是參數化的。 public class Box<T> {pr…

LeetCode算法心得——零數組變換IV(0-1背包)

大家好&#xff0c;我是晴天學長&#xff0c;很久很久沒有寫算法題解了&#xff0c;今天開始轉python了。&#x1f4aa;&#x1f4aa;&#x1f4aa; 1&#xff09;統計打字方案數 給你一個長度為 n 的整數數組 nums 和一個二維數組 queries &#xff0c;其中 queries[i] [li, …

superset部署記錄

具備網絡條件的&#xff0c;完全可以一鍵部署&#xff0c;不需要折騰。網絡條件不具備時&#xff0c;部署記錄留存備查。 1、正常模式 詳細介紹參考&#xff1a;【開源項目推薦】Apache Superset——最優秀的開源數據可視化與數據探索平臺-騰訊云開發者社區-騰訊云 (tencent.c…

AI大模型完全指南:從核心原理到行業落地實踐

目錄 大模型技術演進脈絡核心原理解析與數學基礎主流大模型架構對比開發環境搭建與模型部署Prompt Engineering高階技巧垂直領域應用場景實戰倫理與安全風險防控前沿發展方向與學習資源 一、大模型技術演進脈絡 1.1 發展歷程里程碑 2017&#xff1a;Transformer架構誕生&…

HTB 學習筆記 【中/英】《前端 vs. 后端》P3

&#x1f4cc; 這篇文章講了什么&#xff1f; 介紹了 前端&#xff08;客戶端&#xff09; 和 后端&#xff08;服務器端&#xff09; 的區別。解釋了 全棧開發&#xff08;Full Stack Development&#xff09;&#xff0c;即前端后端開發。介紹了 前端和后端常用的技術。討論…

golang中的結構體

1.簡介 go也支持面向對象編程(OOP)&#xff0c;但是和傳統的面向對象編程有區別&#xff0c;并不是純粹的面向對象語言。所以說go支持面向對象編程特性是比較準確的。go沒有類(class)&#xff0c;go語言的結構體(struct)和其它編程語言的類(class)有同等的地位&#xff0c;你可…

Day 64 卡瑪筆記

這是基于代碼隨想錄的每日打卡 參加科學大會&#xff08;第六期模擬筆試&#xff09; 題目描述 ? 小明是一位科學家&#xff0c;他需要參加一場重要的國際科學大會&#xff0c;以展示自己的最新研究成果。 ? 小明的起點是第一個車站&#xff0c;終點是最后一個車站。然…

《C語言中\0:字符串的神秘“終結者”》

&#x1f680;個人主頁&#xff1a;BabyZZの秘密日記 &#x1f4d6;收入專欄&#xff1a;C語言 &#x1f30d;文章目入 引言一、字符串的定義與存儲二、\0&#xff1a;字符串的終結標志三、\0在字符串操作中的作用四、\0的陷阱與注意事項五、\0與字符串的動態分配六、總結 引言…

九、Prometheus 監控windows(外部)主機

一、監控 Windows 主機的方法 方式 1:使用 Windows Exporter Windows Exporter(wmi_exporter) 是 Prometheus 官方推薦的 Windows 監控工具,它可以采集 CPU、內存、磁盤、網絡、進程、服務狀態等 指標。 方式 2:使用 Node Exporter for Windows node_exporter 主要用于…

TCP/IP協議中三次握手(Three-way Handshake)與四次揮手(Four-way Wave)

TCP/IP協議中三次握手&#xff08;Three-way Handshake&#xff09;與四次揮手&#xff08;Four-way Wave&#xff09; 一、TCP三次握手&#xff08;Three-way Handshake&#xff09;二、TCP四次揮手&#xff08;Four-way Wave&#xff09;三、常見問題解答總結為什么三次握手不…

Java集成WebSocket實現消息推送,詳細步驟以及出現的問題如何解決

Java集成WebSocket實現消息推送 WebSocket是一種在單個TCP連接上進行全雙工通信的協議,非常適合實現實時消息推送功能。與傳統的HTTP請求-響應模式不同,WebSocket建立連接后可以保持長連接狀態,服務器可以主動向客戶端推送數據,這使得它成為實現聊天應用、通知系統和實時數…

如何在Linux中切換用戶?

Linux切換用戶 在Linux系統中&#xff0c;切換用戶可以通過使用su命令和sudo命令實現 1、su命令 su是switch user的縮寫&#xff0c;用于切換到另一個用戶。su命令的語法如下&#xff1a; su [選項] [用戶名]以下是一些示例&#xff1a; # 切換到root用戶 su - # 切換到指定…

網頁制作16-Javascipt時間特效の設置D-DAY倒計時

01、效果圖 02、應用 new Date()//返回今天日期 new Date("April 1,2025")//返回目標日期 document.write()//文檔顯示 getTime()返回當日毫秒數 Math.floor(amadays / (1000 * 60 * 60 * 24)//把毫秒換算天 03、代碼 <!doctype html> <html> &…

c#Winform也可以跨平臺了GTK框架GTKSystem.Windows.Forms

一、簡介 >> 新版下載&#xff0c;問題求助 QQ群&#xff1a;1011147488 1032313876 236066073&#xff08;滿&#xff09; Visual Studio原生開發&#xff0c;無需學習&#xff0c;一次編譯&#xff0c;跨平臺運行. C#桌面應用程序跨平臺&#xff08;windows、linux、…

`lower_bound`、`upper_bound` 和 `last_less_equal`

lower_bound、upper_bound 和 last_less_equal。它們的作用是在 有序數組 中查找目標值的位置。下面是對每個函數的詳細解釋&#xff1a; 1. lower_bound 函數 功能&#xff1a; 在有序數組 a 中查找第一個 大于或等于 target 的元素的位置。 參數&#xff1a; a[]&#xf…

網絡安全常識科普(百問百答)

汪乙己一到店&#xff0c;所有喝酒的人便都看著他笑&#xff0c;有的叫道&#xff0c;“汪乙己&#xff0c;你又監控員工隱私了&#xff01;”他不回答&#xff0c;對柜里說&#xff0c;“來兩個fofa。”便排出三個比特幣。他們又故意的高聲嚷道&#xff0c;“你一定又在電報群…

JSON 序列化 反序列化

序列化&#xff0c;反序列化 其實就是轉換數據格式的過程。 序列化 (Serialization) 是將【對象的狀態信息】轉換為【可以存儲或傳輸的形式】的過程。即&#xff1a;把C#中的類 轉換成 JSON格式的字符串&#xff0c;就是序列化。其中【對象的狀態信息】就是類的各種屬性。 …

如何優化AI模型的Prompt:深度指南

隨著人工智能&#xff08;AI&#xff09;技術的快速發展&#xff0c;AI模型在文本生成、翻譯、問答等領域的應用越來越廣泛。在使用這些模型時&#xff0c;**Prompt&#xff08;提示&#xff09;**的質量直接影響輸出結果的好壞。優化Prompt不僅能提升生成文本的準確性&#xf…

五大基礎算法——模擬算法

模擬算法 是一種通過直接模擬問題描述的過程或規則來解決問題的算法思想。它通常用于解決那些問題描述清晰、步驟明確、可以直接按照規則逐步實現的問題。以下是模擬算法的核心概念、適用場景、實現方法及經典例題&#xff1a; 一、核心概念 問題描述清晰 問題的規則和步驟明確…