本文主要給大家介紹MySQL數(shù)據(jù)庫VIEW視圖的詳細介紹,文章內(nèi)容都是筆者用心摘選和編輯的,具有一定的針對性,對大家的參考意義還是比較大的,下面跟筆者一起了解下Mysql數(shù)據(jù)庫VIEW視圖的詳細介紹吧。
創(chuàng)新互聯(lián)建站作為成都網(wǎng)站建設(shè)公司,專注重慶網(wǎng)站建設(shè)公司、網(wǎng)站設(shè)計,有關(guān)企業(yè)網(wǎng)站制作方案、改版、費用等問題,行業(yè)涉及成都加固等多個領(lǐng)域,已為上千家企業(yè)服務(wù),得到了客戶的尊重與認可。
由MySQL AB公司開發(fā),是最流行的開放源碼SQL數(shù)據(jù)庫管理系統(tǒng),主要特點:
1、是一種數(shù)據(jù)庫管理系統(tǒng)
2、是一種關(guān)聯(lián)數(shù)據(jù)庫管理系統(tǒng)
3、是一種開放源碼軟件,且有大量可用的共享MySQL軟件
4、MySQL數(shù)據(jù)庫云服務(wù)器具有快速、可靠和易于使用的特點
5、MySQL云服務(wù)器工作在客戶端/云服務(wù)器模式下,或嵌入式系統(tǒng)中
InnoDB存儲引擎將InnoDB表保存在一個表空間內(nèi),該表空間可由數(shù)個文件創(chuàng)建。這樣,表的大小就能超過單獨文件的最大容量。表空間可包括原始磁盤分區(qū),從而使得很大的表成為可能。表空間的最大容量為64TB。
2.1.視圖VIEW命令簡介:
VIEW視圖就是存儲下來的SELECT語句數(shù)據(jù)
1.創(chuàng)建視圖命令格式:
CREATE
[OR REPLACE]
[ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
[DEFINER = { user | CURRENT_USER }]
[SQL SECURITY { DEFINER | INVOKER }]
VIEW view_name [(column_list)]
AS select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION]
格式:CREATE VIEW view_name AS select_statement 創(chuàng)建一個名為view_name
視圖,視圖的內(nèi)容,是select語句查詢出來的內(nèi)容。
Usage: CREATE VIEW sct AS SELECT Name,Cname,Tname FROM students,courses,teachers WHERE
students.CID1=courses.CID AND courses.CID=teachers.TID;
把查詢students,courses,teachers表中CID相等的數(shù)據(jù)存儲在sct視圖中。
2.命令功能:
對數(shù)據(jù)庫的SELECT數(shù)據(jù)進行存儲為視圖,視圖也是相當(dāng)于一個虛表,視圖存儲的SELECT語句中的表叫基表,視圖不能修改,只能基于基表進行修改。所以一般不建議MySQL創(chuàng)建視圖。
3.命令參數(shù):
DISTING 獨特的,不重復(fù)的
SELECT [DISTINCT] * FROM tb_name WHERE qualification;
從tb_name表中選擇符合條件的獨特的不重復(fù) 的條目。
4. 實例
1.查看所創(chuàng)建的表是如何創(chuàng)建的;
mysql> SHOW CREATE TABLE class \G;
*************************** 1. row ***************************
Table: class
Create Table: CREATE TABLE `class` (
`ID` int(11) NOT NULL AUTO_INCREMENT,
`Name` char(20) NOT NULL,
`Age` tinyint(4) NOT NULL,
`Gender` varchar(10) NOT NULL,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=gbk
1 row in set (0.00 sec)
ERROR:
No query specified
[root@lamp ~]# mysql -e 'CREATE DATABASE edb;' 直接建立數(shù)據(jù)庫edb
[root@lamp ~]# mysql -e 'SHOW DATABASES;'
+--------------------+
| Database |
+--------------------+
| information_schema |
| edb |
| hellodb |
| mydb |
| mysql |
+--------------------+
[root@lamp ~]# mysql -e 'DROP DATABASE edb;' #直接刪除edb數(shù)據(jù)庫
[root@lamp ~]# mysql -e 'SHOW DATABASES;'
+--------------------+
| Database |
+--------------------+
| information_schema |
| hellodb |
| mydb |
| mysql |
| performance_schema |
| students |
| test |
| testdb |
+--------------------+
[root@lamp ~]# mysql -e 'SELECT * FROM students.class;'
#不登錄mysql客戶端,直接查詢students數(shù)據(jù)庫中class表中的數(shù)據(jù)。
+----+-------------+-----+--------+
| ID | Name | Age | Gender |
+----+-------------+-----+--------+
| 1 | Yang Guo | 22 | |
| 2 | Guo Jing | 46 | |
| 3 | Xiao Longnv | 18 | |
| 4 | Huang Rong | 40 | |
+----+-------------+-----+--------+
[root@lamp ~]# cat autoinsert.sh
#!/bin/bash
function rand(){
min=$1
max=$(($2-$min+1))
num=$(date +%s%N)
echo $(($num%$max+$min))
}
Name="stu"
for i in {1..11000}
do
Agernd=$(rand 1 10)
Genderrnd=$(rand 1 2)
CID1rnd=$(rand 1 10)
CID2rnd=$(rand 1 20)
TIDrnd=$(rand 1 10)
CTime=$(date "+%Y-%m-%d %H:%M:%S")
mysql -e "INSERT INTO jiaowu.students (Name,Age,Gender,CID1,CID2,TID,CreateTime) VALUES ('$Name$i','$Agernd','$Genderrnd','$CID1rnd','$CID2rnd','$TIDrnd','$CTime' )"
done
exit 0
[root@lamp ~]# mysql -e "select COUNT(*) from jiaowu.students;"
+----------+
| COUNT(*) |
+----------+
| 11034 |
+----------+
附1:shell 生成指定范圍隨機數(shù)與隨機字符串
1.使用系統(tǒng)的 $RANDOM 變量
[plain] view plain copy
fdipzone@ubuntu:~$ echo $RANDOM
17617
$RANDOM 的范圍是 [0, 32767]
如需要生成超過32767的隨機數(shù),可以用以下方法實現(xiàn)。
例:生成400000~500000的隨機數(shù)
[plain] view plain copy
#!/bin/bash
function rand(){
min=$1
max=$(($2-$min+1))
num=$(($RANDOM+1000000000)) #增加一個10位的數(shù)再求余
echo $(($num%$max+$min))
}
rnd=$(rand 400000 500000)
echo $rnd
exit 0
#!/bin/bashecho $(($RANDOM%50+1))
2.使用date +%s%N
例:生成1~50的隨機數(shù)
[plain] view plain copy
#!/bin/bash
function rand(){
min=$1
max=$(($2-$min+1))
num=$(date +%s%N)
echo $(($num%$max+$min))
}
rnd=$(rand 1 50)
echo $rnd
exit 0
3.使用/dev/random 和 /dev/urandom
/dev/random 存儲著系統(tǒng)當(dāng)前運行環(huán)境的實時數(shù)據(jù),是阻塞的隨機數(shù)發(fā)生器,讀取有時需要等待。
/dev/urandom 非阻塞隨機數(shù)發(fā)生器,讀取操作不會產(chǎn)生阻塞。
例:使用/dev/urandom生成100~500的隨機數(shù),使用urandom避免阻塞。
[plain] view plain copy
#!/bin/bash
function rand(){
min=$1
max=$(($2-$min+1))
num=$(cat /dev/urandom | head -n 10 | cksum | awk -F ' ' '{print $1}')
echo $(($num%$max+$min))
}
rnd=$(rand 100 500)
echo $rnd
exit 0
4.使用linux uuid
uuid 全稱是通用唯一識別碼,格式包含32個16進制數(shù)字,以'-'連接號分為5段。形式為8-4-4-4-12 的32個字符。
[plain] view plain copy
fdipzone@ubuntu:~/shell$ cat /proc/sys/kernel/random/uuid
fd496199-372a-403e-8ec9-bf4c52cbd9cd
例:使用linux uuid 生成100~500隨機數(shù)
[plain] view plain copy
#!/bin/bash
function rand(){
min=$1
max=$(($2-$min+1))
num=$(cat /proc/sys/kernel/random/uuid | cksum | awk -F ' ' '{print $1}')
echo $(($num%$max+$min))
}
rnd=$(rand 100 500)
echo $rnd
exit 0
5.生成隨機字符串
例:生成10位隨機字符串
[plain] view plain copy
#使用date 生成隨機字符串
date +%s%N | md5sum | head -c 10
#使用 /dev/urandom 生成隨機字符串
cat /dev/urandom | head -n 10 | md5sum | head -c 10
看完以上關(guān)于Mysql數(shù)據(jù)庫VIEW視圖的詳細介紹,很多讀者朋友肯定多少有一定的了解,如需獲取更多的行業(yè)知識信息 ,可以持續(xù)關(guān)注我們的行業(yè)資訊欄目的。