MySQL数据库企业级开发技术(下篇)

2024-04-21 10:04

本文主要是介绍MySQL数据库企业级开发技术(下篇),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用语言 MySQL

使用工具 Navicat Premium 16

代码能力快速提升小方法,看完代码自己敲一遍,十分有用

  • 拖动表名到查询文件中就可以直接把名字拉进来
  • 中括号,就代表可写可不写 

目录

1. 视图 

1.1 需要视图的原因 

1.2 视图介绍 

1.2.1 视图的概念 

1.2.2 使用视图给开发人员带来的好处 

1.2.3 使用视图给数据库的最终用户带来的好处 

1.3 在MySQL中使用视图 

1.3.1 创建视图 

1.3.2 查询视图中的数据 

1.3.3 创建查询视图示例 

1.3.4 删除视图 

 1.3.5 使用视图的注意事项

2. 数据库备份和恢复 

2.1 数据库备份 

2.1.1 使用mysqldump备份数据库

2.1.2 mysqldump示例 

2.1.3 mysqldump备份文件中的两种注释信息

2.1.4 使用Navicat备份数据库 

2.2 数据库恢复 

2.2.1 使用mysql命令导入数据 

2.2.2 使用mysql命令当选中不存在的目标数据库时 

2.2.3 使用source命令恢复数据 

2.2.4  使用source命令恢复数据示例

2.2.5 使用Navicat的数据导入功能导入数据 

2.2.6 使用Navicat导入数据示例


 

1. 视图 

1.1 需要视图的原因 

在数据库系统中,数据的安全非常重要。数据的定义由两种含义:一种物理是上的数据安全,即保证数据不丢失;另一种是数据的权限控制,数据库的使用者权限不同,能够看到的数据页不同。这种需求不仅保证合适的人可以看到合适的数据,还符合用户的日常业务逻辑,使他们更容易理解数据。在数据库系统中可以通过视图实现这样的功能。视图就是保存在数据库中的select查询。在实际的数据库系统中,对查询执行的大多数操作可以在视图上进行。 

在实际工作中,不同身份的用户所能查询的数据范围可能有所不同。例如,企业的员工信息表中保存了该企业所有员工的详细信息,不同职位的人员对该表中查询的数据范围可能不同。根据企业的人力资源管理制度要求,企业的老板关注企业员工的全部信息,他可以浏览全体员工的全部记录;企业的人力资源主管主要查询全体员工目前的岗位、薪金和绩效;企业的出纳员只能查询每个员工的薪金,不能也无权查询企业员工的其他信息;企业的员工只能查看本人记录,不得查看其他员工的任何信息。

另外,在编写SQL代码时有时会使用子查询和多表查询复杂语句,如果这段SQL代码是一个经常使用的功能,那么每次都需要重复编写这样一大串代码,无疑会增加工作量和影响工作效率。现在,可以借助视图对复杂的代码进行封装保存。名称统计此数据时,只需调用并执行对应的视图就可以轻松地完成任务。

1.2 视图介绍 

1.2.1 视图的概念 

视图可以看做一张数据库中的虚拟表,也就是说,在物理上,视图不是真实存在的。视图通常是由一张或多张表的行或列的子集组成的,当然也可以包含全部的行和列。视图并不是数据库中存储的数据值的集合,它的行和列来自查询中引用的表。也就是说,视图中的数据直接显示来自被查询表中的数据。
视图充当表数据筛选器的角色。定义视图的查询可以基于一张或多张表,也可以基于其他视图,当前数据库或其他数据可靠。它的本质就是一张物理上不存在的数据表。 

视图通常用来进行以下3种操作 

  • 筛选表中的行
  • 防止未经许可的用户范围敏感数据
  • 将多张物理数据表抽象为一张逻辑数据表(多表联查后然后存在视图中) 

1.2.2 使用视图给开发人员带来的好处 

  • 限制数据检索更容易。开发人员有时需要隐藏某些行或列中的信息。通过使用视图,用户可以灵活地访问他们需要的数据,同时保证同一张表或其他表中的数据安全性。要实现这一目标,可以在创建视图时将对用户保密的列排除在外。
  • 维护应用程序更方便。调试视图比调试查询容易,跟踪视图中各步骤的错误更容易,这时因为所有的步骤都是视图的组成部分。

1.2.3 使用视图给数据库的最终用户带来的好处 

  • 结果更容易理解。创建视图时,可以将列名改为有意义的名称,使用户更容易理解所代表的内容。在视图中修改列名不会影响基表的列名。
  • 获得数据更容易。很多人对SQL不太理解,因此,对他们来说创建对多张表的复杂查询很困难,可以通过创建视图访问多张表中的数据。

1.3 在MySQL中使用视图 

1.3.1 创建视图 

创建视图的语法格式如下:

  • create view 视图名 as <select语句>;

一般来说,为了方便查看,视图一般以view_xxx或v_xxx的格式来命名 

1.3.2 查询视图中的数据 

查询视图中的数据与查询数据表中的数据的方法一样,所以就不再说太多,主要看后面的示例理解。

1.3.3 创建查询视图示例 

运行结果

1.3.4 删除视图 

与数据表一样,若将要创建的视图在数据库中已存在,则只有先删除视图才能创建成功。删除视图的语法格式如下。

  • drop view [if exists] 视图名; 

 1.3.5 使用视图的注意事项

  • 每个试图中可以使用多张表
  • 与查询相似,一个视图可以嵌套另一个视图,但尽量不超过3层(就是查询x个视图存到另一个视图中)
  • 对视图数据进行添加、更新和删除操作实际上是直接操作引用表中的数据。

所以一般使用视图时不要进行增删改操作 

  • 当试图数据来自多张表时,不允许添加和删除数据 

2. 数据库备份和恢复 

数据在企业中的价值至关重要,数据保障了企业业务的正常运行。因此,数据的安全性及可靠性是运维的重中之重,然后数据的丢失都可能对企业产生严重的影响。通常情况下,数据丢失的原因由如下几种。

  • 程序错误
  • 人为操作错误
  • 运算错误
  • 磁盘故障
  • 灾难(如火灾、地震)和盗窃
  • 病毒入侵 

2.1 数据库备份 

为了保障数据安全,应经常性地对数据库中的数据进行备份。数据库备份的方法有多种        

2.1.1 使用mysqldump备份数据库

mysqldump是客户端常用的逻辑备份命令,它能够产生一组被执行以后再现原始数据库对象定义和表数据的SQL语句。通过mysqldump命令可以将指定的数据库和数表导出为SQL脚本,在通过导出的SQL脚本就可以方便地将其转移到其他设备上。恢复数据时只需执行SQL语句就可以将数据导入目标数据库中。
使用mysqldump备份数据库是在命令行中实现的。命令如下:

  • mysqldump [options] database [table1,table2,...] > [path]/filename.sql 

options: 连接数据库的参数,主要内容如下 

  • -u username: 用户名
  • -h host: 登录用户的主机名称,若本机为主机,则此项省略
  • -p password: 登录密码

本机的一般写法如下:

  • -u root -p

database: 需要备份的数据库
table: 需要备份的数据表,可指定多张表。可选项,若备份真个数据库,则此项省略
filename: 备份文件的名称 

2.1.2 mysqldump示例 

需求:使用mysqldump备份hospital数据库 

 

代码如上,如果没有输出任何东西就代表成功了,然后就可以去对应的位置找文件了,注意最后不要加分号; 

注意:mysqldump是dos系统下的命令,使用时无需进入mysql命令行;否则,将无法执行

2.1.3 mysqldump备份文件中的两种注释信息

 

  • 以"--"开头就是关于SQL语句的注释信息 
  • 以"/*!"开头、"*/"结尾:关于mysql服务器相关的注释。这些语句可以被mysql执行,但其他数据库管理系统将被作为注释忽略,这可以提高数据库的可移植性。 

从备份文件中可以获取以下信息:

  • 备份文件使用的mysqldump工具的版本号
  • 备份账户的名称和主机信息及备份的数据库名称
  • 使用set语句将当前系统变量的值赋给用户定义的变量 

导出的脚本文件在注释后的语句就是数据表的创建语句(create table)和数据导入语句(insert into); 

2.1.4 使用Navicat备份数据库 

 Navicat也可以用于导出数据的备份脚本。方法如下:

 

选中的选项就是备份的点击,点击后就可以选择保存路径,数据库也可以右击选择此选项;

  • 注:备份后的名字要数据库名_日期才是规范的 

2.2 数据库恢复 

数据库恢复的方法也有很多种,可以选择任意一种方法实现数据导入操作。

2.2.1 使用mysql命令导入数据 

使用mysqldump或Navicat导出的SQL备份脚本,在需要恢复时可以通过MySQL命令对齐进行导入操作。命令格式如下:

  • mysql -u username -p dbname < filename.sql

username: 登录数据库系统的用户名
dbname: 导入目标数据库的数据库名
filename.sql: 数据库备份后的文件路径 

导出的备份文件中只包含表的备份,而不包含创建数据表的语句,因此,执行导入操作时必须指定库名,且目标库必须存在。 

2.2.2 使用mysql命令当选中不存在的目标数据库时 

以上的异常就是说以上的test111数据库无法找到,如果目标数据库存在的话输出结果如下(按下上箭头可以找到前面的dos命令并填充): 

 

2.2.3 使用source命令恢复数据 

除了在命令行中导入数据,还可以在已连接数据库的状态下导入数据,就是在dos命令中登录mysql后导入数据,语法格式如下:

  • source filename; 

2.2.4  使用source命令恢复数据示例

 示例如上,注意,在执行source命令时,SQL脚本文件后面不要加";"

2.2.5 使用Navicat的数据导入功能导入数据 

除了使用命令行导入数据,还可以在Navicat中直接导入数据。右击要导入数据的数据库,在弹出的快捷菜单中执行"运行SQL文件.."命令,打开导入窗口,选择要运行的SQL文件,单击"开始"按钮,开始导入数据。 

2.2.6 使用Navicat导入数据示例

 

 

在文件的栏上选择路径即可;

这篇关于MySQL数据库企业级开发技术(下篇)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/922802

相关文章

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

SQL Server中行转列方法详细讲解

《SQLServer中行转列方法详细讲解》SQL行转列、列转行可以帮助我们更方便地处理数据,生成需要的报表和结果集,:本文主要介绍SQLServer中行转列方法的相关资料,需要的朋友可以参考下... 目录前言一、为什么需要行转列二、行转列的基本概念三、使用PIVOT运算符进行行转列1.创建示例数据表并插入数

MySQL MHA集群详解(数据库高可用)

《MySQLMHA集群详解(数据库高可用)》MHA(MasterHighAvailability)是开源MySQL高可用管理工具,用于自动故障检测与转移,支持异步或半同步复制的MySQL主从架构,本... 目录mysql 高可用方案:MHA 详解与实战1. MHA 简介2. MHA 的组件组成(1)MHA

SQL 注入攻击(SQL Injection)原理、利用方式与防御策略深度解析

《SQL注入攻击(SQLInjection)原理、利用方式与防御策略深度解析》本文将从SQL注入的基本原理、攻击方式、常见利用手法,到企业级防御方案进行全面讲解,以帮助开发者和安全人员更系统地理解... 目录一、前言二、SQL 注入攻击的基本概念三、SQL 注入常见类型分析1. 基于错误回显的注入(Erro

MySQL基本表查询操作汇总之单表查询+多表操作大全

《MySQL基本表查询操作汇总之单表查询+多表操作大全》本文全面介绍了MySQL单表查询与多表操作的关键技术,包括基本语法、高级查询、表别名使用、多表连接及子查询等,并提供了丰富的实例,感兴趣的朋友跟... 目录一、单表查询整合(一)通用模版展示(二)举例说明(三)注意事项(四)Mapper简单举例简单查询

MySQL中的DELETE删除数据及注意事项

《MySQL中的DELETE删除数据及注意事项》MySQL的DELETE语句是数据库操作中不可或缺的一部分,通过合理使用索引、批量删除、避免全表删除、使用TRUNCATE、使用ORDERBY和LIMI... 目录1. 基本语法单表删除2. 高级用法使用子查询删除删除多表3. 性能优化策略使用索引批量删除避免

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE