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

相关文章

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySql死锁怎么排查的方法实现

《MySql死锁怎么排查的方法实现》本文主要介绍了MySql死锁怎么排查的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言一、死锁排查方法1. 查看死锁日志方法 1:启用死锁日志输出方法 2:检查 mysql 错误

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

MySQL修改密码的四种实现方式

《MySQL修改密码的四种实现方式》文章主要介绍了如何使用命令行工具修改MySQL密码,包括使用`setpassword`命令和`mysqladmin`命令,此外,还详细描述了忘记密码时的处理方法,包... 目录mysql修改密码四种方式一、set password命令二、使用mysqladmin三、修改u

查询SQL Server数据库服务器IP地址的多种有效方法

《查询SQLServer数据库服务器IP地址的多种有效方法》作为数据库管理员或开发人员,了解如何查询SQLServer数据库服务器的IP地址是一项重要技能,本文将介绍几种简单而有效的方法,帮助你轻松... 目录使用T-SQL查询方法1:使用系统函数方法2:使用系统视图使用SQL Server Configu

SQL Server数据库迁移到MySQL的完整指南

《SQLServer数据库迁移到MySQL的完整指南》在企业应用开发中,数据库迁移是一个常见的需求,随着业务的发展,企业可能会从SQLServer转向MySQL,原因可能是成本、性能、跨平台兼容性等... 目录一、迁移前的准备工作1.1 确定迁移范围1.2 评估兼容性1.3 备份数据二、迁移工具的选择2.1

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查