返回顶部
首页 > 资讯 > 数据库 >Mysql数据库VIEW视图的详细介绍
  • 931
分享到

Mysql数据库VIEW视图的详细介绍

2024-04-02 19:04:59 931人浏览 薄情痞子
摘要

本文主要给大家介绍Mysql数据库VIEW视图的详细介绍,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下mysql数据库VIEW视图的详细介绍吧。&n

本文主要给大家介绍Mysql数据库VIEW视图的详细介绍,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下mysql数据库VIEW视图的详细介绍吧。 

一、简介

由Mysql AB公司开发,是最流行的开放源码SQL数据库管理系统,主要特点:

  • 1、是一种数据库管理系统

  • 2、是一种关联数据库管理系统

  • 3、是一种开放源码软件,且有大量可用的共享MySQL软件

  • 4、MySQL数据库云服务器具有快速、可靠和易于使用的特点

  • 5、MySQL云服务器工作在客户端/云服务器模式下,或嵌入式系统中


  • InnoDB存储引擎将InnoDB表保存在一个表空间内,该表空间可由数个文件创建。这样,表的大小就能超过单独文件的最大容量。表空间可包括原始磁盘分区,从而使得很大的表成为可能。表空间的最大容量为64TB。


二、VIEW视图 (虛表)

2.1.视图VIEW命令简介:

     VIEW视图就是存储下来的SELECT语句数据

1.创建视图命令格式:

   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 创建一个名为view_name

      视图,视图的内容,是select语句查询出来的内容。

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相等的数据存储在sct视图中。


2.命令功能:

对数据库的SELECT数据进行存储为视图,视图也是相当于一个虚表,视图存储的SELECT语句中的表叫基表,视图不能修改,只能基于基表进行修改。所以一般不建议MySQL创建视图。


3.命令参数:

DISTING 独特的,不重复的

SELECT [DISTINCT] * FROM tb_name WHERE qualification;

从tb_name表中选择符合条件的独特的不重复 的条目。


4. 实例

  1.查看所创建的表是如何创建的;

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


三、直接不登录mysql客户端,实现修改mysql数据库中的数据

[root@lamp ~]# mysql -e 'CREATE DATABASE edb;' 直接建立数据库edb

[root@lamp ~]# mysql -e 'SHOW DATABASES;'

+--------------------+

| Database   |

+--------------------+

| infORMation_schema |

| edb     |

| hellodb   |

| mydb     |

| mysql     |

+--------------------+

[root@lamp ~]# mysql -e 'DROP DATABASE edb;'   #直接删除edb数据库

[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数据库中class表中的数据。

+----+-------------+-----+--------+

| 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 生成指定范围随机数与随机字符串


1.使用系统的 $RANDOM 变量


[plain] view plain copy

  1. fdipzone@ubuntu:~$ echo $RANDOM  

  2. 17617  

$RANDOM 的范围是 [0, 32767]


如需要生成超过32767的随机数,可以用以下方法实现。

例:生成400000~500000的随机数


[plain] view plain copy

  1. #!/bin/bash  

  2.   

  3. function rand(){  

  4.     min=$1  

  5.     max=$(($2-$min+1))  

  6.     num=$(($RANDOM+1000000000)) #增加一个10位的数再求余  

  7.     echo $(($num%$max+$min))  

  8. }  

  9.   

  10. rnd=$(rand 400000 500000)  

  11. echo $rnd  

  12.   

  13. exit 0 


#!/bin/bashecho $(($RANDOM%50+1))


2.使用date +%s%N

例:生成1~50的随机数


[plain] view plain copy

  1. #!/bin/bash  

  2.   

  3. function rand(){  

  4.     min=$1  

  5.     max=$(($2-$min+1))  

  6.     num=$(date +%s%N)  

  7.     echo $(($num%$max+$min))  

  8. }  

  9.   

  10. rnd=$(rand 1 50)  

  11. echo $rnd  

  12.   

  13. exit 0  


3.使用/dev/random 和 /dev/urandom


/dev/random 存储着系统当前运行环境的实时数据,是阻塞的随机数发生器,读取有时需要等待。

/dev/urandom 非阻塞随机数发生器,读取操作不会产生阻塞。

例:使用/dev/urandom生成100~500的随机数,使用urandom避免阻塞。


[plain] view plain copy

  1. #!/bin/bash  

  2.   

  3. function rand(){  

  4.     min=$1  

  5.     max=$(($2-$min+1))  

  6.     num=$(cat /dev/urandom | head -n 10 | cksum | awk -F ' ' '{print $1}')  

  7.     echo $(($num%$max+$min))  

  8. }  

  9.   

  10. rnd=$(rand 100 500)  

  11. echo $rnd  

  12.   

  13. exit 0  


4.使用linux uuid


uuid 全称是通用唯一识别码,格式包含32个16进制数字,以'-'连接号分为5段。形式为8-4-4-4-12 的32个字符。


[plain] view plain copy

  1. fdipzone@ubuntu:~/shell$ cat /proc/sys/kernel/random/uuid  

  2. fd496199-372a-403e-8ec9-bf4c52cbd9cd  

例:使用linux uuid 生成100~500随机数


[plain] view plain copy

  1. #!/bin/bash  

  2.   

  3. function rand(){  

  4.     min=$1  

  5.     max=$(($2-$min+1))  

  6.     num=$(cat /proc/sys/kernel/random/uuid | cksum | awk -F ' ' '{print $1}')  

  7.     echo $(($num%$max+$min))  

  8. }  

  9.   

  10. rnd=$(rand 100 500)  

  11. echo $rnd  

  12.   

  13. exit 0  


5.生成随机字符串


例:生成10位随机字符串


[plain] view plain copy

  1. #使用date 生成随机字符串  

  2. date +%s%N | md5sum | head -c 10  

  3.   

  4. #使用 /dev/urandom 生成随机字符串  

  5. cat /dev/urandom | head -n 10 | md5sum | head -c 10  

看完以上关于Mysql数据库VIEW视图的详细介绍,很多读者朋友肯定多少有一定的了解,如需获取更多的行业知识信息 ,可以持续关注我们的数据库栏目的。

您可能感兴趣的文档:

--结束END--

本文标题: Mysql数据库VIEW视图的详细介绍

本文链接: https://lsjlt.com/news/35580.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Mysql数据库VIEW视图的详细介绍
    本文主要给大家介绍Mysql数据库VIEW视图的详细介绍,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下Mysql数据库VIEW视图的详细介绍吧。&n...
    99+
    2024-04-02
  • MySQL数据库索引的详细介绍
    这篇文章主要讲解了“MySQL数据库索引的详细介绍”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL数据库索引的详细介绍”吧!01、前言看了很多关于索...
    99+
    2024-04-02
  • mysql数据库的高级应用索引、视图,触发器的详细介绍
    下文主要给大家带来mysql数据库的高级应用索引、视图,触发器的详细介绍,希望这些内容能够带给大家实际用处,这也是我编辑mysql数据库的高级应用索引、视图,触发器的详细介绍这篇文章的主要目的。好了,废话不...
    99+
    2024-04-02
  • mysql数据库之索引详细介绍
    目录思维导图简单理解索引模型的演变二叉查找树自平衡二叉树B树B+树聚集索引与二级索引总结 如果你想深入了解为什么mysql可以快速的进行检索数据,那么你一定要来了解一下mysql的索...
    99+
    2024-04-02
  • 详细介绍MySQL数据库索引知识
    下面讲讲关于MySQL数据库索引知识,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完MySQL数据库索引知识这篇文章你一定会有所受益。MySQL数据库------索引一、索引的介...
    99+
    2024-04-02
  • MySQL数据库——MySQL创建视图(CREATE VIEW)
    创建视图是指在已经存在的 MySQL 数据库表上建立视图。视图可以建立在一张表中,也可以建立在多张表中。 基本语法 可以使用 CREATE VIEW 语句来创建视图。 语法格式如下: CREATE VIEW AS 语法说明如下。 :指定...
    99+
    2023-09-08
    数据库 mysql sql
  • Python 绘图和可视化详细介绍
    Python之绘图和可视化 1. 启用matplotlib 最常用的Pylab模式的IPython(IPython --pylab) 2. matplotlib的图像都位于Figure对象中。 可以使用pl...
    99+
    2022-06-04
    详细介绍 Python
  • Python全栈MySQL数据库基本操作的详细介绍
    下文给大家带来有关Python全栈MySQL数据库基本操作的详细内容,相信大家一定看过类似的文章。我们给大家带来的有何不同呢?一起来看看正文部分吧,相信看完Python全栈MySQL数据库基本操作你一定会有...
    99+
    2024-04-02
  • vue视图响应式更新详细介绍
    目录概述思路第一步统一封装更新函数第二步监听并触发视图更新引入Dep管家实现下语法糖v-model概述 前面两篇文章已经实现了对数据的变化的监听以及模板语法编译初始化,但是当数据变化...
    99+
    2024-04-02
  • MyBatis操作数据库的详细步骤介绍
    这篇文章主要介绍“MyBatis操作数据库的详细步骤介绍”,在日常操作中,相信很多人在MyBatis操作数据库的详细步骤介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”My...
    99+
    2024-04-02
  • springMVC中的view视图详细解析
    目录1、ThymleafView2、转发视图3、重定向视图4、视图控制器view-controllerSpring MVC中的视图是view接口,视图的作用是渲染数据,将模型mode...
    99+
    2024-04-02
  • mysql数据库介绍
    什么是数据库:数据库是与应用程序实现信息交互的数据存储、管理软件,并且存储数据的也都可以称为数据库。在以前没有使用数据库的时候,只能够自己写数据的存储方案。什么是sql语句:Sql语句就是对数据库进行操作的...
    99+
    2024-04-02
  • Android 自定义View的构造函数详细介绍
     Android自定义View的构造函数 自定义View是Android中一个常见的需求,每个自定义的View都需要实现三个基本的构造函数,而这三个构造函数又有两种...
    99+
    2022-06-06
    view 函数 自定义view 构造函数 Android
  • MYsql库与表的管理及视图介绍
    目录库的管理1、库的管理2、表的管理3、表的修改表操作的练习题视图视图的作用应用场景创建视图的语法库的管理 1、库的管理 创建、修改、删除 1、库的创建 CREATE DATABASE UF NOT EXISTS boo...
    99+
    2024-04-02
  • Oracle数据库表空间超详细介绍
    目录表空间概述表空间的分类创建表空间参数详解1、undo2、tablespace3、datafile datefile_spec14、MININUM EXTENT integer [k|m]5、blockSIZE int...
    99+
    2023-05-12
    oracle表空间是什么 oracle 表空间查询 oracle表空间创建
  • 关于Redis数据库入门详细介绍
    目录1、Redis是什么?2、Redis特点:单线程为何如此快?3、redis 对比 memcached4、redis 典型应用场景:5、Redis下载与安装:Redis服务...
    99+
    2024-04-02
  • 九、MySQL之视图的介绍
    🙌作者简介:数学与计算机科学学院学生、分享学习经验、生活、 努力成为像代码一样有逻辑的人 🌙个人主页:阿芒的主页 👉推荐一款刷题、找工作神器 牛客网注册即可免费刷题 文章目录 &...
    99+
    2023-08-19
    数据库 mysql sql
  • 阿里云RDS数据库实例的详细介绍
    阿里云RDS是阿里云提供的关系型数据库服务,它可以帮助用户快速搭建和管理数据库实例,提供稳定、安全、高效的数据存储和处理能力。在本文中,我们将详细介绍阿里云RDS数据库实例的特性和使用方法。 一、阿里云RDS的优势架构简单:阿里云RDS提供...
    99+
    2023-11-07
    阿里 详细介绍 实例
  • 数据库介绍以及mysql的安装配置,超详细教程
    数据库–基础 数据库相关概念 数据库 存储数据的仓库,数据是有组织的进行存储英文:DataBase,简称DB 数据库管理系统 管理数据库的大型软件英文:DataBase Management,简称DBMS SQL 英文:Structured...
    99+
    2023-12-25
    数据库 mysql microsoft
  • SpringMVC数据响应详细介绍
    目录一、环境准备二、响应页面[了解]三、返回文本数据[了解]四、响应JSON数据SpringMVC接收到请求和数据后,进行一些了的处理,当然这个处理可以是转发给Service,Ser...
    99+
    2023-02-06
    SpringMVC数据响应 SpringMVC响应
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作