主頁 > 資料庫 > MySQL8資料庫 | MySQL調優|MySQL底層原理|MySQL零基礎新手教程

MySQL8資料庫 | MySQL調優|MySQL底層原理|MySQL零基礎新手教程

2020-11-25 02:56:17 資料庫

MySQL8資料庫安裝

一、Windows 環境下安裝

A、下載 MySQL

Select Operating System:
Microsoft Windows

快捷下載:mysql-8.0.22-winx64.zip

B、解壓并配置MySQL環境變數

MYSQL_HOME:
C:\MySQL\mysql-8.0.22-winx64

C、在解壓根目錄創建my.ini組態檔

[mysqld]
#設定3306埠
port = 3306
# 設定mysql的安裝目錄
basedir=C:/MySQL/mysql-8.0.22-winx64
# 設定mysql資料庫的資料的存放目錄
datadir=C:/MySQL/mysql-8.0.22-winx64\data
# 允許最大連接數
max_connections=200
# 允許連接失敗的次數,這是為了防止有人從該主機試圖攻擊資料庫系統
max_connect_errors=10
# 服務端使用的字符集默認為utf8
character-set-server=utf8mb4
# 創建新表時將使用的默認存盤引擎
default-storage-engine=INNODB
# 默認使用 “mysql_native_password” 插件認證
default_authentication_plugin=mysql_native_password

[mysql]
# 設定mysql客戶端默認字符集
default-character-set=utf8mb4

[client]
# 設定mysql客戶端連接服務端時默認使用的埠
port=3306
# 設定mysql客戶端連接服務端時默認使用的字符集
default-character-set=utf8mb4

D、安裝 MySQL (以下操作必須是管理員身份)

  1. 初始化MySQL
mysqld --defaults-file=C:\MySQL\mysql-8.0.22-winx64\my.ini --initialize --console

注意:復制保存 MySQL初始化密碼 fVdpg:bM9pAk

  1. 安裝MySQL服務
mysqld --install mysql8
  1. 啟動MySQL服務
net start mysql8

E、登錄、修改密碼

  1. 登錄 MySQL
mysql -u賬號 -p密碼

使用上面方式無法登錄的解決方案

1、停止 mysql8 net stop mysql8

2、無密碼啟動 mysqld --console --skip-grant-tables --shared-memory

3、前面視窗不能關閉,再開啟一個新的視窗進行無密碼登錄 mysql -u root -p

4、清空密碼 update mysql.user set authentication_string='' where user='root' and host='localhost;'

5、重繪權限 plush privilege;

6、重新啟動 mysql 服務,再以無密碼登錄 mysql

  1. 登錄后使用MySQL修改密碼
ALTER USER root@localhost IDENTIFIED BY '123456';
  1. 開啟遠程訪問
CREATE USER 'root' @'%' IDENTIFIED BY '123456'; -- 這一步執行失敗也沒關系

GRANT ALL ON *.* TO 'root' @'%';

# alter user 'root'@'%' identified with mysql_native_password by '123456';

FLUSH privilege;

二、Linux 環境下安裝

A、下載 MySQL

Select Operating System:
Source Code

Select OS Version:
Generic Linux (Architecture Independent)

快捷下載:mysql-8.0.22.tar.gz

B、把下載的 MySQL 壓縮包上傳到 Linux 服務器

C、解壓mysql-8.0.22.tar.gz

tar -zxvf mysql-8.0.22.tar.gz

D、把解壓后的檔案移動到 /usr/local 目錄下

mv mysql-8.0.22 /usr/local/mysql

E、添加MySQL組合用戶 (默認會添加,沒有添加就手動添加)

groupadd mysql
useradd -r -g mysql mysql

F、進入 /usr/local/mysql 目錄,修改相關權限

cd /usr/local/mysql
chown -R mysql:mysql ./

G、MySQL初始化操作,記錄臨時密碼

cd /usr/local/mysql/bin
./mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

注意:復制保存 MySQL初始化密碼 fVdpg:bM9pAk

H、創建MySQL組態檔 /etc/my.cnf

cd /etc
vi my.cnf

my.cnf

[mysqld]
port = 3306
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
max_connections=200
max_connect_errors=10
character-set-server=utf8mb4
default-storage-engine=INNODB
default_authentication_plugin=mysql_native_password

[mysql]
default-character-set=utf8mb4

[client]
port=3306
default-character-set=utf8mb4

I、啟動MySQL服務

cd /usr/local/mysql/support-files
./mysql.server start

J、通過臨時密碼登錄MySQL并修改密碼

cd /usr/local/mysql/bin
./mysql -u root -p生成的臨時密碼 
ALTER USER 'root' @'localhost' IDENTIFIED BY '123456';

K、開啟遠程訪問

CREATE USER 'root' @'%' IDENTIFIED BY '123456';  -- 這一步執行失敗也沒關系

GRANT ALL ON *.* TO 'root' @'%';

FLUSH privilege;

MySQL 資料庫操作

資料庫操作

創建資料庫

CREATE DATABASE db_name DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

查詢資料庫

-- 查詢所有資料庫
SHOW DATABASES;
-- 查詢資料庫建表時的sql腳本
SHOW CREATE DATABASE db_name;

洗掉資料庫

DROP DATABASE db_name;

修改資料庫

-- 修改資料庫的字符編碼和排序方式
ALTER DATABASE db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

選擇資料庫

USE db_name;

設定操作的編碼格式

SET NAMES utf8;

表操作

創建表

CREATE TABLE tb_name (建表的欄位、型別、長度、約束、默認、注釋)

約束

  • 非空 NOT NULL
  • 非負 UNSIGNED
  • 主鍵 PRIMARY KEY
  • 自增 AUTO_INCREMENT
  • 默認 DEFAULT
  • 注釋 COMMENT
-- 資料庫存在就洗掉
DROP DATABASE IF EXISTS testdb;
-- 創建資料庫的操作
CREATE DATABASE IF NOT EXISTS testdb;
-- 使用資料庫
USE testdb;
-- 資料表存在就洗掉
DROP TABLE IF EXISTS testdb;
-- 創建表的操作
CREATE TABLE IF NOT EXISTS tb_test 
( 
	test_id INTEGER ( 10 ), 
	test_name VARCHAR ( 50 ) 
);
-- 使用資料庫
USE testdb;
-- 資料表存在就洗掉
DROP TABLE IF EXISTS testdb;
-- 創建表的操作
CREATE TABLE IF NOT EXISTS tb_test 
( 
	test_id INTEGER (10) AUTO_INCREMENT PRIMARY KEY COMMENT '測驗ID', 
	test_name VARCHAR (50) NOT NULL COMMENT '測驗名稱',
	test_password VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '測驗密碼'
);

常用型別

  • 極小整形 TIYINT 1個位元組,無符號最大值 256 (2^8 -1),正負 -128 ~ 127 (-2^7 -1 ~ 2^7 -1)
  • 小整形 SMALLINT 2個位元組,無符號最大值 65535 (2^16 - 1),正負 -32768 ~ 32767 (-2^15 - 1 ~ 2^15 - 1)
  • 中整形 MEDIUMINT 3個位元組,無符號最大值 16777215 (2^24 - 1),正負 (-2^23-1 ~ 2^23-1)
  • 整形 INT 4個位元組,無符號最大值 2^32 -1,正負 (-2^31-1 ~ 2^31-1)
  • 長整形 BIGINT 8個位元組,無符號最大值 2^64 - 1, 正負 (-2^63-1 ~ 2^63-1)
  • 單精度 FLOAT 4個位元組 Float [(M,D)] -3.4E+38~3.4E+38( 約 )
  • 雙精度 DOUBLE 8個位元組 Double [(M,D)] -1.79E+308~1.79E+308( 約 )
  • 小數值 DECIMAL M>D ? M+2 : D+2 個位元組 Decimal [(M,D)] 注:M 為長度, D 為小數
  • 定長字串CHAR 最大保存255個位元組,如果值沒有達到給定的長度,使用空格補充
  • 變長字串VARCHAR 最大保存255個位元組,用多大長度占多大長度
  • 極小文本 TINYTEXT 最大長度255個位元組(2^8-1)
  • 中文本 MEDIUMTEXT 最大長度 16777215 個位元組(2^24-1)
  • 文本 TEXT 最大長度65535個位元組(2^16-1)
  • 長文本 LONGTEXT 最大長度4294967295個位元組 (2^32-1)
  • 日期 DATE 日期(yyyy-mm-dd)
  • 時間 TIME 時間(hh:mm:ss)
  • 日期時間 DATETIME 日期與時間組合(yyyy-mm-dd hh:mm:ss)
  • 時間戳 TIMESTAMP yyyymmddhhmmss
  • 年份 YEAR 年份yyyy
-- 創建表的操作
CREATE TABLE IF NOT EXISTS tb_user
( 
	user_id int(11) AUTO_INCREMENT PRIMARY KEY COMMENT '用戶ID', 
	user_name VARCHAR (30) NOT NULL COMMENT '用戶名稱',
	user_birthday date COMMENT '用戶生日',
	user_gender CHAR(3) COMMENT '用戶性別',
	user_status TINYINT(1) NOT NULL COMMENT '用戶狀態',
	user_height DECIMAL(4,1) NOT NULL COMMENT '用戶身高',
    user_desc text COMMENT '用戶簡介'
);

表欄位索引

  • 主鍵索引:ALTER TABLE table_name ADD PRIMARY KEY (column),用于唯一標識一條記錄
  • 唯一索引:ALTER TABLE table_name ADD UNIQUE (column) 往往不是為了提高訪問速度,而是為了避免資料出現重復
  • 普通索引:ALTER TABLE table_name ADD INDEX index_name (column),唯一任務是加快對資料的訪問速度
  • 全文索引:ALTER TABLE table_name ADD FULLTEXT index_name (column1, column2) ,僅可用于 MyISAM 表,針對較大的資料,生成全文索引很耗時好空間
  • 聯合索引:ALTER TABLE table_name ADD INDEX index_name (column1, column2, column3) ,為了更多的提高mysql效率
# 洗掉主鍵索引
ALTER TABLE `table_name` DROP PRIMARY KEY

# 洗掉唯一索引
ALTER TABLE `table_name` DROP INDEX unique_index_name;
ALTER TABLE `table_name` DROP INDEX cloumn;

# 洗掉普通索引
ALTER TABLE `table_name` DROP INDEX index_name;

# 洗掉全文索引
ALTER TABLE `table_name` DROP INDEX fulltext_index_name;
ALTER TABLE `table_name` DROP INDEX cloumn;
修改表

欄位添加

# ALTER TABLE tb_name ADD 欄位 欄位型別 非空約束 默認值 注釋
ALTER TABLE tb_name ADD address VARCHAR ( 100 ) NOT NULL DEFAULT COMMENT '用戶地址';

欄位型別修改

# ALTER TABLE tb_name MODIFY 欄位 新的欄位型別 非空約束 默認值 注釋
ALTER TABLE tb_name MODIFY address VARCHAR ( 50 ) NOT NULL DEFAULT COMMENT '用戶地址';

欄位名稱型別修改

# ALTER TABLE tb_name MODIFY 舊的欄位 新的欄位 新的欄位型別 非空約束 默認值 注釋
ALTER TABLE tb_name CHANGE address addr VARCHAR ( 50 ) NOT NULL DEFAULT COMMENT '用戶地址';

欄位型別查詢

DESC tb_name;

欄位洗掉

# ALTER TABLE tb_name DROP 欄位
ALTER TABLE tb_name DROP addr;

表名修改

# ALTER TABLE 舊表名 RENAME TO 新表名
ALTER TABLE tb_name RENAME TO tb_name1

表引擎修改

# ALTER TABLE tb_name ENGINE = 新引擎
ALTER TABLE tb_name ENGINE = MyISAM;
洗掉表
# DROP TABLE 表名
DROP TABLE tb_name;
# 如果表存在就洗掉
DROP TABLE IF EXISTS tb_name;
查詢表
# 查詢所有表
SHOW TABLES;
# 查詢建表時的腳本
SHOW CREATE TABLE tb_name;

MySQL DML 操作

新增資料
# insert into 表名 (欄位名:欄位1,欄位2,...欄位n) values (值1,值2,...值n);

# 全表插入
INSERT INTO `tb_user`(`user_name`, `user_birthday`, `user_gender`, `user_status`, `user_height`, `user_desc`) VALUES ('曾小賢', '2020-11-22', '男', 1, 174.5, '好男人就是我,我就是好男人曾小賢');

# 指定列插入,前提是其他列沒有非空的約束
INSERT INTO `tb_user`(`user_name`, `user_birthday`, `user_gender`, `user_status`, `user_height`) VALUES ('胡小梅', '2020-11-22', '女', 1, 174.5);
修改資料
# update 表名 set 欄位1=新值1,欄位2=新值2,...欄位n=新值n where 條件
UPDATE `tb_user` SET user_birthday='1995-10-20' WHERE user_id=2;
UPDATE `tb_user` SET user_birthday='1995-10-20', user_status = 2 WHERE user_id=2;

UPDATE `tb_user` SET user_status = 1 where user_id > 1;

UPDATE `tb_user` SET user_status = 1;
洗掉資料
# delete from 表名 where 條件
DELETE FROM `tb_user` WHERE user_id=2;
查詢資料
# select 欄位1,欄位2,...欄位n from 表名 where 條件

# 不帶條件查詢
select * from tb_user;
select user_id,user_name from tb_user;

# 帶條件查詢 (比較運算 >, <, >=, <=, !=, <>, =)
select * from tb_user where user_id > 1;

# 帶邏輯條件查詢 (and,or)
select * from tb_user where user_status = 1 and user_id > 1;
select * from tb_user where user_id = 1 or user_name = '胡小梅';

# 模糊查詢 (like %%)
select * from tb_user where user_name like '曾%';
select * from tb_user where user_name like '%閑';
select * from tb_user where user_name like '%小%';

# 范圍查詢
select * from tb_user where tb_status in (0,1,2);

# 聚合函式
-- count(field)
select count(user_id) 用戶數量 from tb_user;
-- sum(field)
select sum(user_height) 總身高 from tb_user;
-- avg(field)
select avg(user_height) 平均身高 from tb_user;

...

# 分組查詢
-- group by 統計男女的平均身高: group by 查詢中出現的欄位必須是 group by 后面的欄位
select user_gender as 性別,avg(user_height) 平均身高 from tb_user group by user_gender;

select user_status,user_gender as 性別,avg(user_height) 平均身高 from tb_user group by user_gender,user_status;

select user_gender as 性別,avg(user_height) 平均身高,sum(user_height),count(user_id) 用戶數量 from tb_user group by user_gender;

# 排序查詢
-- order by 默認是 asc 升序, desc 降序; order by 是放在 group by 之后的
select * from tb_user order by user_id asc;

select * from tb_user order by user_id desc;

select * from tb_user where user_id < 10 order by user_id desc;

select * from tb_user where user_id < 10 order by user_id,user_status desc;

select user_gender as 性別,avg(user_height) 平均身高,sum(user_height),count(user_id) 用戶數量 from tb_user group by user_gender order by 用戶數量;
# 創建分數表
CREATE TABLE `tb_score` (
  `id` int(11) NOT NULL PRIMARY KEY AUTO_INCREMENT,
  `stu_id` int(11) NOT NULL,
  `cou_id` int(11) NOT NULL,
  `score` decimal(4,1) NOT NULL
);

-- 插入測驗資料 
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(1,1,89.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(1,2,78.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(1,3,94.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(1,4,77.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(1,5,99.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(3,1,90.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(3,2,88.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(3,3,69.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(3,4,83.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(3,5,92.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(2,1,77.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(2,2,84.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(2,3,91.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(2,4,80.0);
INSERT INTO tb_score (`stu_id`, `cou_id`, `score`) VALUES(2,5,99.0);

# 分頁查詢
-- 查詢科目id為1的最高成績
select max(score) from tb_score where course_id = 1;
select * from tb_score where course_id = 1 limit 1;
-- 查詢課程id為4的前五名成績資訊
select * from tb_score where course_id = 4 order by score limit 5;
-- limit 分頁, 起始值是 0: (pageIndex - 1) * pageSize, pageSize
select * from tb_score limit 0,10
select * from tb_score limit 10,10
select * from tb_score limit 20,10

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

標籤:MySQL

上一篇:講武德,你們要的 MySQL批量SQL插入性能優化,來了

下一篇:mysql基礎---DOS下資料庫的基本使用

標籤雲
其他(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