主頁 > 資料庫 > MySQL之外鍵、表關系及SQL查詢關鍵字

MySQL之外鍵、表關系及SQL查詢關鍵字

2022-02-22 07:58:52 資料庫

一、外鍵

假設現在我們有一張員工資訊表,表的欄位如下:

id  # 主鍵
name  # 姓名
age  # 年齡
dep_name  # 部門名稱
dep_desc  # 部門描述

單從資料存盤上來看,這個表是沒有問題的,但是從程式開發角度來看的話,這張表目前有如下三個缺陷:

  1. 表的重點不清晰:到底是員工表還是部門表(其實可以忽略)
  2. 表中欄位會出現重復存盤,如資料量較大,那么會存盤多個相同部門的名稱和描述(其實也可以忽略)
  3. 表的擴展性極差,如要修改某個部門名稱資訊,就會導致牽一發而動全身(這一點不能忽略)

要如何解決上述的三個缺陷呢?

其實我們可以將上述表拆分成兩張表,一張員工表(emp),一張部門表(dep):

emp表:
id  name  age

dep表:
id dep_name dep_desc

這樣一來,上述的三個缺陷便全部解決了,但是你應該也發現了一個小問題,那就是這兩張表之間的資料沒有關系了,那又如何解決表與表之間的關系呢?

于是,MySQL給我們提供了外鍵:foreign key這種約束方式來幫我們解決上述問題,

通過建立外鍵欄位來標識表與表之間的資料關系,也可以簡單的理解為該欄位可以讓你去到其他表中查找資料,

下面就讓我們來看看如何使用這種方式給表與表之間添加關系,

二、表與表之間建立關系

表與表之間的關系總共就三種,如下:

  • 一對多
  • 多對多
  • 一對一

其實我們日常所能接觸到的最常見的關系反而不是這三種,而是 沒有關系

當然,沒有關系 我們是比較容易判斷的,那么對于上面三種關系,我們又該如何判斷呢,這里我推薦一種判斷表的方式,那就是換位思考,接下來就來看看這種方式在三種關系判斷中是如何體現的,

2.1 一對多

以員工和部門表為例:

  • 先站在員工表的基礎之上:
    • 問:一個員工資訊能否對應多個部門資訊
    • 答:不可以
  • 再站在部門表的基礎之上:
    • 問:一個部門資訊能否對應多個員工資訊
    • 答:可以

結論:

一個可以,一個不可以,那么表關系就是一對多

針對一對多 的表關系,外鍵欄位建在多的一方;

表關系沒有 多對一 一說,都是 一對多

在上述例子中,員工表是多,部門表是一,

SQL陳述句實作如下:

"""先創建不含外鍵欄位的基本表,之后再添加外鍵欄位"""
"""部門表"""
create table dep(
	id int primary key auto_increment,
    dep_name varchar(32),
    dep_desc varchar(254)
);

"""員工表"""
create table emp(
	id int primary key auto_increment,
    name varchar(32),
    age int,
    dep_id int,
    foreign key(dep_id) references dep(id)
)

2.2 多對多

以書籍表和作者表為例:

  • 先站在書籍表的基礎之上:
    • 問:一個書籍資訊能否對應多個作者資訊
    • 答:可以
  • 再站在作者表的基礎之上:
    • 問:一個作者資訊能否對應多個書籍資訊
    • 答:可以

結論:

兩個都可以,那么表關系就是多對多

針對多對多表關系,需要單獨開設第三張表存盤兩張表的關聯資料(第三張表也可以不系結關系)

SQL陳述句實作如下:

"""書籍表"""
create table book(
	id int primary key auto_increment,
    title varchar(32),
    price float(6,2)
);


"""作者表"""
create table author(
	id int primary key auto_increment,
    name varchar(32),
    age int
);


"""第三張關系表"""
create table book2author(
	id int primary key auto_increment,
    book_id int,
    author_id int,
    foreign key(book_id) references book(id)
    on update cascade   # 級聯更新
    on delete cascade,  # 級聯洗掉
    foreign key(author_id) references author(id)
    on update cascade   # 級聯更新
    on delete cascade  # 級聯洗掉
);

2.3 一對一

以作者表和作者詳情表為例:

  • 先站在作者表的基礎之上:
    • 問:一個作者資訊能否對應多個作者詳情資訊
    • 答:不可以
  • 再站在作者詳情表的基礎之上:
    • 問:一個作者詳情資訊能否對應多個作者資訊
    • 答:不可以

結論:

兩個都不可以,那么表關系可能是一對一或者沒有關系,這個視具體情況應該就能判斷出來;

針對一對一表關系,外鍵欄位建在任何一方都可以,但是推薦建在查詢頻率較高的表中;

SQL陳述句實作如下:

"""作者詳情表"""
create table author_detail(
	id int primary key auto_increment,
    phone bigint,
    address varchar(32)
);


"""作者表"""
create table author(
	id int primary key auto_increment,
    name varchar(32),
    age int,
    author_id int unique,    # 要加上唯一約束條件,這是與一對多表關系唯一不同的地方
	foreign key(author_id) references author_detail(id)
    on update cascade   # 級聯更新
    on delete cascade   # 級聯洗掉
);

2.4 外鍵約束

  • 在創建表的時候,需要先創建被關聯表(沒有外鍵欄位的表);

  • 在插入新資料的時候,應該先確保被關聯表中有資料;

  • 在插入新資料的時候,外鍵欄位只能填寫被關聯表中已經存在的資料;

  • 在修改和洗掉被關聯表中的資料的時候,無法直接操作,如果想要資料之間自動修改和洗掉,需要添加額外的配置,即上面所使用到的級聯更新,級聯洗掉:

    on update cascade   # 級聯更新
    on delete cascade   # 級聯洗掉
    

由于外鍵有實質性的諸多約束,當表特別多的時候外鍵的增多反而會增加耦合程度,

因此在實際開發專案中,有時候并不會直接使用外鍵創建表關系,而是通過SQL陳述句層面,建立邏輯意義上的表關系,

eg:操作員工表的SQL陳述句執行完畢之后,立刻跟著執行操作部門的SQL陳述句,

2.5 操作表的SQL陳述句補充

"""修改表名"""  
      ALTER TABLE 表名 RENAME 新表名;
      
"""增加欄位"""
      ALTER TABLE 表名 ADD 欄位名  資料型別 [約束條件…],...;
      ALTER TABLE 表名 ADD 欄位名  資料型別 [約束條件…]  FIRST;
      ALTER TABLE 表名 ADD 欄位名  資料型別 [約束條件…]  AFTER 欄位名;                       
"""洗掉欄位"""
      ALTER TABLE 表名 DROP 欄位名;
      
"""修改欄位"""    
      ALTER TABLE 表名 MODIFY  欄位名 資料型別 [約束條件…];
      ALTER TABLE 表名 CHANGE 舊欄位名 新欄位名 資料型別 [約束條件…];

modify只能改欄位資料型別和約束條件,不能改欄位名,但是change可以!

三、SQL查詢關鍵字

3.1 資料準備

"""資料準備"""
create table emp(
  id int primary key auto_increment,
  name varchar(20) not null,	# 姓名
  sex enum('male','female') not null default 'male',	# 性別
  age int(3) unsigned not null default 28,	# 年齡
  hire_date date not null,	# 錄用日期
  department varchar(50),		# 部門名稱
  department_comment varchar(100),	# 崗位名稱
  salary double(15,2),	# 薪資
  office int,	 #辦公室(同一部門在一件辦公室)
  depart_id int  # 部門編號
);


"""插入記錄"""
"""三個部門:教學,銷售,運營"""
insert into emp(name,sex,age,hire_date,department,salary,office,depart_id) values
('jason','male',18,'20170301','teacher',7300.33,401,1),	 # 以下是教學部
('tom','male',78,'20150302','teacher',1000000.31,401,1),
('kevin','male',81,'20130305','teacher',8300,401,1),
('tony','male',73,'20140701','teacher',3500,401,1),
('owen','male',28,'20121101','teacher',2100,401,1),
('jack','female',18,'20110211','teacher',9000,401,1),
('jenny','male',18,'19000301','teacher',30000,401,1),
('sank','male',48,'20101111','teacher',10000,401,1),
('哈哈','female',48,'20150311','sale',3000.13,402,2),  # 以下是銷售部門
('呵呵','female',38,'20101101','sale',2000.35,402,2),
('西西','female',18,'20110312','sale',1000.37,402,2),
('樂樂','female',18,'20160513','sale',3000.29,402,2),
('拉拉','female',28,'20170127','sale',4000.33,402,2),
('僧龍','male',28,'20160311','operation',10000.13,403,3),  # 以下是運營部門
('程咬金','male',18,'19970312','operation',20000,403,3),
('程咬銀','female',18,'20130311','operation',19000,403,3),
('程咬銅','male',18,'20150411','operation',18000,403,3),
('程咬鐵','female',18,'20140512','operation',17000,403,3);

image

3.2 查詢關鍵字之selectfrom

  • select 控制的是查詢表里面的哪些欄位;

    select * from emp;  # 查詢所有欄位
    select name,age from emp;  # 查詢指定欄位
    
  • from控制的是查詢哪張表;

3.3 查詢關鍵字之where篩選

下面通過幾道練習題來幫助我們體會where關鍵字的用法及其他補充知識點:

"""1.查詢id大于等于3小于等于6的資料"""
select * from emp where id >= 3 and id <= 6;
select * from emp where id between 3 and 6;  


"""2.查詢薪資是20000或者18000或者17000的資料"""
select * from emp where salary = 20000 or salary = 18000 or salary = 17000;
select * from emp where salary in (20000,18000,17000);  # 簡寫,類似于Python中的成員運算


"""3.查詢員工姓名中包含o字母的員工姓名與其薪資"""
select name,salary from emp where name like '%o%';


"""4.查詢員工姓名是由四個字符組成的員工姓名與其薪資"""
select name,salary from emp where name like '____';
select name,salary from emp where char_length(name) = 4;


"""5.查詢id小于3或者大于6的資料"""
select * from emp where id not between 3 and 6;  # 取反


"""6.查詢薪資不在20000,18000,17000范圍的資料"""
select * from emp where salary not in (20000,18000,17000);


"""7.查詢崗位描述為空的員工名與崗位名(針對null不能用等號,只能用is)"""
select name,department_comment from emp where department_comment = NULL;  # 不報錯,但查詢結果為空!
select name,department_comment from emp where department_comment is NULL;

補充知識點:

模糊查詢:沒有明確的篩選條件

關鍵字:like

關鍵符號:

  • %:匹配任意個數任意字符
  • _:匹配單個任意字符

示例:

show variables like '%mode%';  # 篩選出含有mode字符的結果 

3.4 查詢關鍵字之group by分組

即按照某個指定的條件將單個單個的個體分成 一個個整體,

eg:按照男女將人分組、按照年齡分組、按照膚色分組......

分組之后默認只能獲取到分組的依據,其他資料不能直接獲取,

針對5.6版本需要自己設定sql_mode:

set global sql_mode = 'ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,PAD_CHAR_TO_FULL_LENGTH';

聚合函式:主要就是配合分組一起使用,這里列出五個常用的聚合函式:

max  # 最大
min  # 最小
sum  # 求和
count  # 計數 
avg  # 平均

資料分組所能應用到的場景:每個部門的平均薪資,男女比例等,

下面通過幾道練習題來幫助我們體會group by關鍵字的用法:

"""1.按部門分組"""
select * from emp group by department;  # 沒設定sql_mode之前分組后取出的是每個組的第一條資料
select id,name,sex from emp group by department;  # 驗證

設定sql_modeonly_full_group_by后,意味著以后但凡分組,只能取到分組的依據,不應該再去取組里面的單個元素的值,那樣的話分組就沒有意義了,因為不分組就是對單個元素資訊的隨意獲取,

set global sql_mode = "strict_trans_tables,only_full_group_by";
# 重新連接客戶端
select * from emp group by department;  # 報錯
select id,name,sex from emp group by department;  # 報錯
select department from emp group by department;  # 獲取部門資訊

強調:只要分了組,就不能夠再“直接”查找到單個資料資訊了,只能獲取到組名

"""2.獲取每個部門的最高工資"""
# 以組為單位統計組內資料>>>>聚合查詢(聚集到一起合成為一個結果)
select department,max(salary) from emp group by department;

在顯示的時候還可以給欄位取別名:

select department as '部門',max(salary) as '最高工資' from emp group by department;

as也可以省略,但是不推薦,因為語意不明確,

"""每個部門的最低工資"""
select department,min(salary) from emp group by department;

"""每個部門的平均工資"""
select department,avg(salary) from emp group by department;

"""每個部門的工資總和"""
select department,sum(salary) from emp group by department;

"""每個部門的人數"""
select department,count(id) from emp group by department;  # 統計的時候只要是非空欄位,效果都是一致的 
"""演示特殊情況:department_comment"""
select department,count(department_comment) from emp group by department;

補充說明:

  • group_concat:分組之后使用

    如果真的需要獲取分組以外的資料欄位,可以使用group_concat()

    """每個部門的員工姓名"""
    select department,group_concat(name) from emp group by department;
    
    """每個部門的員工姓名,性別(支持自定義連接符)"""
    select department,group_concat(name,'|',sex) from emp group by department;
    
  • concat:未分組時使用

    select concat(name,sex) from emp;
    select concat(name,'|',sex) from emp;
    

3.5 查詢關鍵字之having過濾

wherehaving都是篩選功能,但是有區別:

  • where是在分組之前對資料進行篩選
  • having是在分組之后對資料進行篩選
"""篩選出員工年齡在30歲以上,且平均薪資在10000以上的部門"""
select department,avg(salary) from emp where age>30 group by department having avg(salary)>10000;

注意:

一條SQL陳述句的結果也可以看成是一張全新的表,

3.6 查詢關鍵字之distinct去重

"""對有重復的展示資料進行去重操作 一定要是重復的資料"""
select distinct department from emp;  # 去重單個欄位
select distinct id,age from emp;  # 如去重多個欄位必須滿足去重的欄位資料都重復才能去重,否則不去重

3.7 查詢關鍵字之order by排序

select * from emp order by salary asc;  # 也可不寫asc,默認升序排
select * from emp order by salary desc;  # 降序排

"""先按照age降序排,在年齡相同的情況下再按照薪資升序排"""
select * from emp order by age desc,salary asc; 

"""統計各部門年齡在10歲以上的員工平均工資,并且保留平均工資大于1000的部門,然后對平均工資進行降序排序"""
select department,avg(salary) from emp where age>10 group by department having avg(salary)>1000 order by avg(salary) desc;

3.8 查詢關鍵字之limit分頁

"""限制展示條數"""
select * from emp limit 3;

"""查詢工資最高的人的詳細資訊"""
select * from emp order by salary desc limit 1;

"""分頁顯示"""
select * from emp limit 0,5;  # 第一個引數表示起始位置,第二個引數表示的是條數,不是索引位置
select * from emp limit 5,5;

3.9 查詢關鍵字之regexp正則

select * from emp where name regexp '^j.*(n|y)$';

3.10 查詢關鍵字之exists存在

exists關鍵字表示是否存在,

在使用exists關鍵字時,內層查詢陳述句不回傳查詢的記錄,而是回傳一個真偽值,TrueFalse

  • 當回傳True時,外層查詢陳述句將進行查詢;

  • 當回傳值為False時,外層查詢陳述句不進行查詢,

select id,name from emp where exists (select id from emp where id > 3);  # 有結果
select id,name from emp where exists (select id from emp where id > 200);  # 內層查詢無結果,所以外層查詢陳述句不執行

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/430237.html

標籤:其他

上一篇:MySQL之外鍵、表關系及SQL查詢關鍵字

下一篇:用戶無法從Laravel8中的自定義注冊頁面登錄

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more