MySQL索引類型:
1.普通索引
2.唯一索引:只存在唯一的值,重復插入會報錯
3.主鍵索引:一個表只能有一個
4.全文索引:方便查找大容量字段
5.外鍵索引
6.組合索引
mysql8 group by的問題:https://www.cnblogs.com/wang615/p/12376491.html
【MySQL訓練題】
Student(SID,Sname,Sage,Ssex)?
- SID?學生編號,Sname?學生姓名,Sage?出生年月,Ssex?學生性別
Course(CID,Cname,TID)?
- CID?--課程編號,Cname?課程名稱,TID?教師編號
Teacher(TID,Tname)?
- TID?教師編號,Tname?教師姓名
SC(SID,CID,score)?
- SID?學生編號,CID?課程編號,score?分數
1、查詢"01"課程比"02"課程成績高的學生的信息及課程分數
Select?a.sname,?b.score?
FROM?Student?as?a?LEFT?JOIN?SC?ON?a.SID?=?b.SID
wHERE
1、查詢"01"課程比"02"課程成績高的學生的信息及課程分數
SELECT stu.\*,c1.score '01課程',c2.score '02課程',c3.score '03課程' from (SELECT score,Scid from sc
WHERE cid=01) c1,(SELECT score,Scid from sc
WHERE Cid=02) c2,student stu,(SELECT score,Scid from sc
WHERE Cid=02) c3
WHERE c1.Scid=c2.scid and stu.Sid=c1.scid and c3.scid=c2.scid and
c1.score>c2.score
2、查詢"01"課程比"02"課程成績低的學生的信息及課程分數
SELECT stu.\*,c1.score '01課程',c2.score '02課程',c3.score '03課程' from (SELECT score,Scid from sc
WHERE cid=01) c1,(SELECT score,Scid from sc
WHERE Cid=02) c2,student stu,(SELECT score,Scid from sc
WHERE Cid=02) c3
WHERE c1.Scid=c2.scid and stu.Sid=c1.scid and c3.scid=c2.scid and
c1.score<c2.score
3、查詢平均成績大于等于70分的同學的學生編號和學生姓名和平均成績
SELECT student.sid,student.sname,AVG(sc.score)
FROM student,sc
WHERE student.sid=sc.scid GROUP BY student.sid,student.sname
HAVING AVG(sc.score)>=70
4、查詢平均成績小于70分的同學的學生編號和學生姓名和平均成績
SELECT student.sid,student.sname,AVG(sc.score)
FROM student,sc
WHERE student.sid=sc.scid
GROUP BY student.sid,student.sname
HAVING AVG(sc.score)<70
5、查詢所有同學的學生編號、學生姓名、選課總數、所有課程的總成績
SELECT student.sid,student.sname,COUNT(sc.cid),sum(sc.score)
FROM student,sc
WHERE student.sid=sc.scid
GROUP BY student.sid,student.sname
6、查詢"李"姓老師的數量
SELECT count(tname) FROM teacher where tname like "李%"
7、查詢學過"張三"老師授課的同學的信息
SELECT student.* from student,teacher,sc
WHERE student.sid=sc.scid and teacher.tid=sc.cid and teacher.tname ="張三"
group BY student.sid,student.sname,student.sage,student.ssex
8、查詢沒學過"張三"老師授課的同學的信息
SELECT student.* from student,teacher,sc
WHERE teacher.tid=sc.cid
and student.sname not in (SELECT student.sname from student,teacher,sc
WHERE student.sid=sc.scid and teacher.tid=sc.cid and teacher.tname ="張三")
group BY student.sid,student.sname,student.sage,student.ssex
9、查詢學過編號為"01"并且也學過編號為"02"的課程的同學的信息
SELECT \* FROM student WHERE sid in (SELECT s1.scid FROM (SELECT scid
FROM sc WHERE cid='01') s1,(SELECT scid FROM sc WHERE cid='02') s2
WHERE s1.scid=s2.scid)
10、查詢學過編號為"01"但是沒有學過編號為"02"的課程的同學的信息
SELECT student.\* FROM student
where sid =(SELECT scid from sc where scid not in (SELECT scid FROM sc WHERE cid='02') GROUP BY scid )
參考:
https://blog.csdn.net/qq_43154385/article/details/87967878
- 高級工程師或以上級別的行為習慣
- Laravel封裝
- 公用類
- 查詢
- 項目1
- Laravel CMS
- 無限分級列表
- Laravel
- Laravel簡介
- Laravel下載和安裝
- 微服務
- Laravel身份認證
- Laravel Passport
- 后臺身份驗證
- Passport實現前后端登錄認證
- Laravel Sanctum
- Laravel輔助
- Unitest
- Laravel常用命令行
- Laravel數據庫配置
- Laravel連接數據庫模板
- Laravel數據庫操作
- Laravel路由
- Laravel操作
- Laravel Blade模板引擎
- Laravel CRUD (create, read, update, delete)
- Laravel實例
- Laravel Eloquent
- belongsTo和belongsToMany案例
- Laravel Package
- Laravel File Manager
- Laravel language
- Laravel查詢
- Laravel合并查詢
- Laravel統計
- Laravel Voyager Blog System
- Laravel Excel
- Laravel AsgardCms后臺
- Laravel基礎集合
- Laravel 備份和更新
- Laravel和Codeigniter對比
- Laravel事務處理
- Laravel Redis
- Laravel在Nginx服務器運行時遇到404錯誤的修正
- Laravel安全
- Laravel JWT
- Laravel Passport
- Laravel加密和解密
- Laravel sent email
- laravel 5.4 eloquent-relationships
- 加入變量文件
- Laravel migrations
- Laravel隊列
- Laravel+RabbitMQ
- Laravel OSS
- CMS設計
- 角色權限設計
- Lumen
- Lumen API
- lumen email
- 服務器
- Cloud9使用
- 配置本地服務器多域名
- PHP運行環境部署方式
- 同時運行PHP、Java、Python
- Linux操作
- Composer
- 支付開發
- 微信支付
- 支付寶API
- PayPal開發
- PHP基礎
- JavaScript相對PHP開發側重後臺功能的劣勢
- PHP foreach 和 for循環
- PHP檢測數組有哪里連續的字符串,以及有多少個
- Session
- 域名判斷顯示
- 檢測登錄設備
- PHP foreach循環, 則只循環相同數據一次
- PHP計算搜索過程所用的時間
- PHP文件處理
- Session和cookie案例:登錄時的記住我功能
- PHP array判斷
- PHP剔除數組中相同子元素的值
- PHP分頁
- PHP "三元運算符"簡寫
- 防CSRF跨站請求偽造攻擊
- PHP Json system
- crul
- PHP爬蟲
- 參考
- PHP一和二維數組
- 格式轉換
- PHP抓取網頁指定內容
- PHP Simple HTML DOM Parser
- PHP提取多維數組指定一列的方法大全
- PHP將第一個字符轉為指定內容
- OpenSSL加密解密
- 圖片+文字
- PHP理論
- Opcache
- Git
- 安裝Git
- Git操作
- Git參考
- 參考筆記
- 程序員接單平臺
- 后端PHP面試
- 基礎面試
- MySQL訓練題
- 經典算法題
- 框架原理
- 高并發
- 微服務架構
- 安全性
- 分布式設計
- 服務器集群
- 模擬題目
- 模擬面試1
- 模擬面試2
- 網絡協議
- 英文面試
- 高端PHP面試取勝點
- MVC設計
- 模板引擎
- 算法高效解題
- 算法概述
- leetcode算法題
- 排序
- SQL
- MySQL
- MySQL連接
- Join案例
- MySQL參考文章
- mysql_pdo_select
- mysql_pdo_insert
- MySQL索引
- MySQL事務
- MySQL將數據表字段不重復的值合成一個數組
- MySQL常用語句
- 備份
- MySQL other
- MsSQL
- MsSQL連接
- MySQL PDO連接
- MsSQL安裝
- mssql_pdo_select
- mssql_pdo_insert
- MySQL past
- MySql常用操作
- MySQL基礎練習
- MySQL設計
- MySQL案例
- php array轉換放入數據表
- PHP Mysql連接數據庫并輸出數據
- MySQL常用命令
- MySQL導出導入
- PDO
- Excel
- Excel在Drupal的應用
- Excel在Laravel的應用
- PHPOffice/PhpSpreadsheet的基本使用
- 用PHP Simple HTML DOM Parser獲取指定列的內容
- PHPOffice/PhpSpreadsheet的案例
- Sublime Text
- elasticsearch
- 后端基礎核心:數據的輸入和輸出
- 發送郵件功能
- PHPMailer發送郵件功能源碼
- PHPMailer發送郵件功能源碼(詳細案例)
- 常用cnd鏈接
- API
- API ajax+php demo
- PHP Postman API
- API1
- demo-api
- Google API
- google sheet data insert into database
- Laravel API
- Google Analytics
- 其他工具
- 經驗
- 編程注意事項
- 開發語言的差別
- 軟件產品
- 經驗之談
- test
- Bootstrap 4
- 1.demo page
- CMS設計
- 編輯器
- Other