首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Linux下MySQL shell脚本执行错误 $’r’:command not found

问题描述 前几天编写的shell小脚本,测试自动安装MySQL的,今天测试运行,然后出现如下错误 $’\r’:command not found, 问题分析 检查脚本,没有问题,只是有空行。...提示这个错误也不是代码本身错误,怀疑可能是编码格式等错误,:脚本是Linux下编辑完成测试。后期我又做了简单修改,是在在window下修改后完成,然后上传到Linux服务器的。...Linux下不识别\r为回车符,如果脚本有\r回车符那么会导致脚本编码执行出现问题。 处理问题 在linux上执行 dos2unix 脚本名,转换后,在执行脚本。...[root@localhost soft]# yum -y install dos2unix 在Linux上执行 dos2unix 脚本名, [root@localhost soft]#  dos2unix...然后执行脚本 脚本执行完毕,MySQL直接到登录界面。完成。 在学习中尽量慢慢养成好的习惯,在Linux下编码 测试 更新等 结尾 在工作和学习中遇到的问题和大家分享,希望对大家有所帮助。

2K10

Mysql查询语句执行流程

第二部:   查询缓存 mysql拿到请求后首先判断请求的查询语句是否有缓存,是否命中缓存,但是不推荐使用mysql的缓存,官方也不推荐,因为只要有一条数据更新表的缓存就会被删除,降低效率 第三步:   ...分析器 没有命中缓存的话就要开始执行语句了,首先对sql语句进行解析, 首先做 “词法解析”,分析出sql语句的关键词等字符串代表什么含义,然后通过”语法分析“判断这个sql是否满足语法标准。...第四步:   优化器 优化sql执行的速度,比如执行的索引、表连接(join)的执行顺序,然后决定出最快的执行方案 第五步:   执行器 判断用户对这个表是否有权限,有的话就会根据这个表的引擎执行通过优化器给出的最优执行方案去执行

4.3K10

Mysql语句执行过程

当你希望MySQL能够以更高的性能运行查询时,最好的办法是弄清楚MySQL是如何优化和执行查询。...《高性能MySQL》 衡量查询开销的三个指标 响应时间扫描的行数 服务时间(处理这条语句真正花的时间) 排队时间(等待资源,例如IO,行锁等) 扫描的行数 返回的行数 当删除了搜索条件列的索引时,语句进行全表扫描...查询的执行流程 ? 图二 语句的处理过程 1.连接数据库 客户端发起一条Query请求,监听客户端的‘连接管理模块’接收请求。 将请求转发到‘连接进/线程模块’。 调用‘用户模块’来进行授权检查。...命中查询缓存,用户权限没有问题,MySQL直接从缓存中拿结果返回给客户端。 查询优化处理(解析SQL、预处理、优化SQL的执行计划),将SQL转化成一个执行计划。...优化过程书上介绍了很多情况,请参考书籍6.43章 执行计划 MySQL会生成一个指令树,然后通过存储引擎完成这棵树并返回结果 如图2 查询执行引擎  查询执行引擎则根据执行计划来完成整个查询。

2.6K20

Mysql系列】(一)MySQL语句执行流程

MySQL 服务器接收到 SQL 语句后,会执行相应的操作,比如查询、插入、更新等。 MySQL 服务器执行完 SQL 语句后,会将结果返回给 MySQL 客户端程序。...MySQL 查询缓存的工作原理如下: 当执行一个查询语句时,MySQL 会首先检查查询缓存,看看是否有与当前查询语句完全匹配的缓存结果。...如果你的语句不对,就会收到You have an error in your SQL syntax的错误提醒,比如下面这个语句 select 少打了开头的字母“s”。...执行器 什么是 MySQL 执行MySQL 执行器(MySQL Executor)是 MySQL 数据库的一个组件,负责执行查询语句并返回结果。...MySQL 执行器是 MySQL 查询处理的核心组件之一,负责实际执行查询操作,并将结果返回给客户端。它与优化器、存储引擎等组件协同工作,完成数据库查询的全过程。 本文由 mdnice 平台发布

36130

shell脚本执行错误 $‘r‘:command not found

今天在Windows下编辑了一段CentOS7下编译安装ffmpeg源代码以及相关依赖软件包的编译sh脚本,直接拷贝到CentOS7下报错了:出现$’\r’:command not found的错误。...在linux上执行脚本时出现$’\r’:command not found,然而仔细检查脚本,对应行位置只是一个空行,并没有问题,那么linux为什么会将一个回车的空行报错?...原因是这样的:脚本是在window下编辑完成后上传到linux上执行的,win下的换行是回车符+换行符,也就是\r\n,而unix下是换行符\n。...linux下不识别\r为回车符,所以导致每行的配置都多了个\r,因此是脚本编码的问题。 在linux上执行 dos2unix 脚本名,再次执行脚本,报错消失。...,并chmod +x build_ffmpeg_all.sh为脚本添加可执行权限运行: sh build_ffmpeg_all.sh

2.1K30

MySQL执行sql语句的机制

目录 1 概念 2 执行过程 1 概念 连接器: 身份认证和权限相关(登录 MySQL 的时候)。...查询缓存: 执行查询语句的时候,会先查询缓存(MySQL 8.0 版本后移除,因为这个功能不太实用)。...第二步,语法分析,主要就是判断你输入的 sql 是否正确,是否符合 MySQL 的语法。 优化器: 按照 MySQL 认为最优的方案去执行执行器: 执行语句,然后从存储引擎返回数据。...首先执行前会校验该用户有没有权限,如果没有权限,就会返回错误信息,如果有权限,就会去调用引擎的接口,返回接口执行的结果。...,然后调用数据库引擎,返回执行结果 更新(包括删除、新增)语句执行执行更新语句时会就日志:归档日志和重做日志, 1、先查询数据 2、然后将查出的数据修改,调用引擎API接口写入这一行数据,InnoDB

3.8K30

MySQL执行SQL语句过程详解

开发人员基本都知道,我们的数据存在数据库中(目前最多的是MySQL和Oracle,由于作者更擅长MySQL,所以这里默认数据库为MySQL),服务器通过sql语句将查询数据的请求传入到MySQL数据库。...流程概述   MySQL得到sql语句后,大概流程如下:   1.sql的解析器:负责解析和转发sql   2.预处理器:对解析后的sql树进行验证   3.查询优化器:得到一个执行计划   4.查询执行引擎...如果写入特别,可能缓存反而会导致MySQL变慢。 查询不到缓存的情况:   1.查询条件有不确定数据:如now ,current_time等。   ...验证是否使用错误的关键字,sql语法顺序是否正确等。(语法层面的错误)   解析完成后,进行查询语句预处理器,根据MySQL的规则,检查解析树是否合法。...执行完成后,将结果返回给客户端,如果是查询语句,并且开启了缓存,那么,MySQL会同时将结果集放到查询缓存中。然后将查到的结果集返回。如果是增删改操作,那么返回执行语句后受影响的行数。

3.5K20

select语句执行流程(MySql

学习了极客时间MySql课程,做个总结 以一条select语句为例:select * from T where ID=4 ,梳理下执行的流程 一条sql语句执行过程中需要经过连接器、分析器、优化器、...查询缓存 在经过连接器之后,会执行第二步查询缓存,在MySql拿到查询后,会先到查询缓存查看是否执行过这条语句,之前执行的结果会以key-value对的形式存在,如果不在查询缓存中,会继续执行后面的极端...在MySql8.0之后去掉了查询缓存的功能。...分析器 分析器会先做“词法分析”,识别出sql里的字符串分别是什么,读出“select”关键字对出这是一条查询语句,把字符串T识别成“表T” “语法分析”,根据词法分析的结果,判断该条sql是否满足MySql...的语法 优化器 优化器的作用在于选择最优的逻辑执行sql,例如在一个语句进行多表关联的时候,决定各个表的连接顺序 执行器 在开始执行前,先判断你对表T是否有执行查询的权限,没有就返回没有权限的错误,有权限则继续执行

8610
领券