MySQL數(shù)據(jù)庫數(shù)據(jù)視圖
一、 數(shù)據(jù)視圖
視圖是原始數(shù)據(jù)庫數(shù)據(jù)的一種變換,是查看表中數(shù)據(jù)的另外一種方式。我們可以將視圖看成是一個(gè)移動(dòng)的窗口,從這個(gè)窗口中可以看到感興趣的數(shù)據(jù)。
二、數(shù)據(jù)視圖操作
創(chuàng)建視圖
// 標(biāo)準(zhǔn)語法: CREATE VIEW 視圖名稱 [(列名列表)] AS 查詢語句; // 創(chuàng)建city_country視圖,保存城市和國(guó)家的信息(使用指定列名) CREATE VIEW city_country(city_id,city_name,country_name) AS SELECT c1.id, c1.name, c2.name FROM city c1, country c2 WHERE c1.cid = c2.id;
修改視圖數(shù)據(jù)
// 標(biāo)準(zhǔn)語法: UPDATE 視圖名稱 SET 列名=值 WHERE 條件; // 注意:修改視圖數(shù)據(jù)后,源表中的數(shù)據(jù)也會(huì)隨之修改 UPDATE city_country SET city_name="深圳" WHERE city_name="北京";
修改視圖列明
// 標(biāo)準(zhǔn)語法: ALTER VIEW 視圖名稱 (列名列表) AS 查詢語句; ALTER VIEW city_country (city_id, city_name, NAME) AS SELECT c1.id, c1.name, c2.name FROM city c1, country c2 WHERE c1.cid = c2.id;
刪除視圖
// 標(biāo)準(zhǔn)語法 DROP VIEW [IF EXISTS] 視圖名稱; // 刪除city_country視圖 DROP VIEW IF EXISTS city_country;
三、數(shù)據(jù)的備份與回復(fù)
liunx備份
備份文件:
mysqldump -u root -p 數(shù)據(jù)庫名稱 > 文件保存路徑
還原:
source 文件保存路徑
mysql備份
備份-> 導(dǎo)出備份數(shù)據(jù)庫 還原-> 導(dǎo)入備份文件
四、 MySQL存儲(chǔ)過程和函數(shù)
概念
- 存儲(chǔ)過程和函數(shù)是 事先經(jīng)過編譯并存儲(chǔ)在數(shù)據(jù)庫中的一段 SQL 語句的集合
好處:
- 可以重復(fù)使用,減輕開發(fā)人員的工作量
- 減少網(wǎng)絡(luò)流量,調(diào)用只需要傳遞參數(shù)名和參數(shù)即可
- 減少數(shù)據(jù)在數(shù)據(jù)庫和應(yīng)用服務(wù)器之間的傳輸,可以提高數(shù)據(jù)處理的效率
- 將部分邏輯在數(shù)據(jù)庫層進(jìn)行了處理,減少業(yè)務(wù)層代碼
區(qū)別:
- 函數(shù)必須有返回值
- 存儲(chǔ)過程沒有返回值
五、存儲(chǔ)過程操作
初始數(shù)據(jù)
-- 創(chuàng)建學(xué)生表 CREATE TABLE student( id INT PRIMARY KEY AUTO_INCREMENT, NAME VARCHAR(20), age INT, gender VARCHAR(5), score INT ); -- 添加數(shù)據(jù) INSERT INTO student VALUES (NULL,'張三',23,'男',95),(NULL,'李四',24,'男',98), (NULL,'王五',25,'女',100),(NULL,'趙六',26,'女',90); -- 按照性別進(jìn)行分組,查詢每組學(xué)生的總成績(jī)。按照總成績(jī)的升序排序 SELECT gender, SUM(score) getSum FROM student GROUP BY gender ORDER BY getSum ASC;
創(chuàng)建過程
// 標(biāo)準(zhǔn)語法
//
DELIMITER $
-- 標(biāo)準(zhǔn)語法
CREATE PROCEDURE 存儲(chǔ)過程名稱(參數(shù)列表)
BEGIN
SQL 語句列表;
END $
-- 修改分隔符為分號(hào)
DELIMITER ;
// 創(chuàng)建stu_group()存儲(chǔ)過程,封裝 分組查詢總成績(jī),并按照總成績(jī)升序排序的功能
DELIMITER$
CREATE PROCEDURE stu_group()
BEGIN
SELECT gender, SUM(score) getSum FROM student GROUP BY gender ORDER BY getSum ASC;
END$
DELIMITER ;調(diào)用存儲(chǔ)過程
// CALL 存儲(chǔ)過程名稱(實(shí)際參數(shù)); CALL stu_group();
查找存儲(chǔ)過程
// 標(biāo)準(zhǔn)語法: SELECT * FROM mysql.proc WHERE db='數(shù)據(jù)庫名稱'; SELECT * FROM mysql.proc WHERE db='demoMysql';
刪除存儲(chǔ)過程
//標(biāo)準(zhǔn)語法: DROP PROCEDURE [IF EXISTS] 存儲(chǔ)過程名稱; DROP PROCEDURE IF EXISTS stu_group;
其他語法
// 定義變量
// 語法:DECLARE 變量名 數(shù)據(jù)類型 [DEFAULT 默認(rèn)值];
// 變量賦值
// 語法一:SET 變量名 = 變量值;
// 語法二:SELECT 列名 INTO 變量名 FROM 表名 [WHERE 條件];
// 判斷語句
// if語句
// IF 判斷條件1 THEN 執(zhí)行的sql語句1;
// [ELSEIF 判斷條件2 THEN 執(zhí)行的sql語句2;]
// ...
// [ELSE 執(zhí)行的sql語句n;]
// END IF;
DELIMITER $
CREATE PROCEDURE pro_test2()
BEGIN
-- 定義變量
DECLARE NAME VARCHAR(20);
DECLARE totalScore INT;
DECLARE info VARCHAR(10);
-- 為變量賦值
SET NAME = '賦值方式1';
SELECT SUM(score) INTO totalScore FROM student;
IF totalScore > 500 THEN
SET info='總分超過500';
END IF;
-- 使用變量
SELECT NAME,totalScore,info;
END$
DELIMITER;
// 參數(shù)傳遞
// 標(biāo)準(zhǔn)語法: CREATE PROCEDURE 存儲(chǔ)過程名稱([IN|OUT|INOUT] 參數(shù)名 數(shù)據(jù)類型)
DELIMITER $
CREATE PROCEDURE pro_test5(IN total INT, OUT info VARCHAR(10))
BEGIN
-- 對(duì)總成績(jī)判斷
IF total > 380 THEN
SET info = '學(xué)習(xí)優(yōu)秀';
ELSEIF total >= 320 AND total <= 380 THEN
SET info = '學(xué)習(xí)不錯(cuò)';
ELSE
SET info = '學(xué)習(xí)一般';
END IF;
END$
DELIMITER;
// 調(diào)用過程
CALL pro_test5(350,@info);
SELECT @info;六、 存儲(chǔ)函數(shù)
其實(shí)和存儲(chǔ)過程區(qū)別不大,主要在于定義的時(shí)候用FUNCTION,同時(shí)有return
DELIMITER $ CREATE FUNCTION fun_test1() RETURNS INT // 返回值類型 BEGIN DECLARE s_count INT; SELECT COUNT(*) INTO s_count FROM student WHERE score > 95;// 條件語句 RETURN s_count;// 返回結(jié)果; END $ DELIMITER ; // 調(diào)用函數(shù) SELECT fun_test1(); // 刪除函數(shù) DROP FUNCTION fun_test1();
到此這篇關(guān)于MySQL數(shù)據(jù)庫數(shù)據(jù)視圖的文章就介紹到這了,更多相關(guān)SQL數(shù)據(jù)視圖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mysql主鍵,外鍵,非空,唯一,默認(rèn)約束及創(chuàng)建表的方法
這篇文章主要介紹了mysql主鍵,外鍵,非空,唯一,默認(rèn)約束及創(chuàng)建表的方法,在數(shù)據(jù)庫中,數(shù)據(jù)表是數(shù)據(jù)庫中最重要、最基本的操作對(duì)象,是數(shù)據(jù)存儲(chǔ)的基本單位2022-07-07
MySQL Innodb 存儲(chǔ)結(jié)構(gòu) 和 存儲(chǔ)Null值 用法詳解
這篇文章主要介紹了MySQL Innodb 存儲(chǔ)結(jié)構(gòu) 和 存儲(chǔ)Null值 用法詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
MySQL生成千萬測(cè)試數(shù)據(jù)以及遇到的問題
前兩天發(fā)現(xiàn)同事要做一個(gè)對(duì)大表進(jìn)行范圍查詢的功能,所以需要生成千萬數(shù)據(jù)進(jìn)行性能測(cè)試,下面這篇文章主要給大家介紹了關(guān)于MySQL生成千萬測(cè)試數(shù)據(jù)以及遇到的問題的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
ktl工具實(shí)現(xiàn)mysql向mysql同步數(shù)據(jù)方法
在本篇內(nèi)容里我們給大家介紹了用ktl工具實(shí)現(xiàn)mysql向mysql同步數(shù)據(jù)的具體步驟,有需要的朋友們跟著學(xué)習(xí)參考下。2019-03-03
mysql怎么關(guān)閉sql_mode=ONLY_FULL_GROUP_BY模式
前段時(shí)間在項(xiàng)目開發(fā)過程中發(fā)現(xiàn)了系統(tǒng)異常,打開日志查看發(fā)現(xiàn)了如下的這個(gè)報(bào)錯(cuò),查找相關(guān)資料終于解決了,這篇文章主要給大家介紹了關(guān)于mysql怎么關(guān)閉sql_mode=ONLY_FULL_GROUP_BY模式的相關(guān)資料,需要的朋友可以參考下2024-01-01

