MySQL编程怎么执行 mysql语句怎么执行

mysql 怎么执行sql文件基本步骤如下:
1、创建包含sql命令的sql脚本文件
文件中包含一些列的sql语句 , 每条语句最后以;结尾,文件内容示例如下:
--创建表,使用“--”进行注释
create table 表名称(Guid Varchar(38) not null primary key,
Title Varchar(255),
) TYPE=InnoDB;
--在表A中增加字段Status
alter table A add Status TinyInt default '0';
--在表A上创建索引
create index XX_TaskId_1 on A(Id_);
--在表A中添加一条记录
Insert into A (Id,ParentId, Name) values(1,0,'名称');
【MySQL编程怎么执行 mysql语句怎么执行】--添加、修改、删除数据后 , 有可能需要提交事务Commit;2、执行sql脚本文件
方法一 使用cmd命令执行(windows下,unix或linux在的其控制台下)
【Mysql的bin目录】\mysql –u用户名 –p密码 –D数据库【sql脚本文件路径全名】,示例:
D:\mysql\bin\mysql –uroot –p123456 -Dtestd:\test\ss.sql注意:A、如果在sql脚本文件中使用了use 数据库 , 则-D数据库选项可以忽略
B、如果【Mysql的bin目录】中包含空格 , 则需要使用“”包含 , 如:“C:\Program Files\mysql\bin\mysql” –u用户名 –p密码 –D数据库【sql脚本文件路径全名】
方法二 进入mysql的控制台后,使用source命令执行
MySql中Sql的执行过程如果查询缓存没有命中,那么SQL请求会进入分析器 , 分析器是用来分辨SQL语句的执行目的,其执行过程大致分为两步:
表1 语法分析关键字然后再通过语法规则解析 , 判断输入的SQL 语句是否满足MySQL语法,并且生成图5的语法树 。由SQL语句生成的四个单词中,识别出两个关键字,分别是select 和from 。根据MySQL的语法Select 和 from之间对应的是fields 字段,下面应该挂接username;在from后面跟随的是Tables字段,其下挂接的是userinfo 。
优化器的作用是对SQL进行优化,生成最有的执行方案 。如图6所示,前面提到的SQL解析器通过语法分析和语法规则生成了SQL语法树 。这个语法树作为优化器的输入,而优化器(黄色的部分)包含了逻辑变换和代价优化两部分的内容 。在优化完成以后会生成SQL执行计划作为整个优化过程的输出 , 交给执行器在存储引擎上执行 。
所处的位置如上图所示,这节的重点在优化器中的逻辑变换和代价优化上 。
逻辑变换也就是在关系代数基础上进行变换,其目的是为了化简,同时保证SQL变化前后的结果一致,也就是逻辑变化并不会带来结果集的变化 。其主要包括以下几个方面:
这样讲概念或许有些抽象,通过图7 来看看逻辑变化如何在SQL中执行的吧 。
如图7所示 , 从上往下共有4个步骤:
1. 针对存在的SQL语句,首先通过“否定消除”,去掉条件判断中的“NOT” 。语句由原来的“or”转换成“and”,并且大于小于符号进行变号 。蓝色部分为修改前的SQL,红色是修改以后的SQL 。2. 等值传递,这一步很好理解分别降”t2.a=9” 和”t2.b=5”分别替换掉SQL中对应的值 。3. 接下来就是常量表达式计算,将“5+7”计算得到“12” 。4. 最后是常量表达式计算后的化简,将”9=10”化简为”true”带入到最终的SQL表达式中完成优化 。
代价优化是用来确定每个表,根据条件是否应用索引,应用哪个索引和确定多表连接的顺序等问题 。为了完成代价优化,需要找到一个代价最小的方案 。因此,优化器是通过基于代价的计算方法来决定如何执行查询的(Cost-based Optimization) 。简化的过程如下:
这里将配置操作的代价分为MySQL 服务层和MySQL 引擎层,MySQL 服务层主要是定义CPU的代价,而MySQL 引擎层主要定义IO代价 。MySQL 5.7 引入了两个系统表mysql.server_cost和mysql.engine_cost来分别配置这两个层的代价 。如下:MySQL 服务层代价保存在表server_cost中 , 其具体内容如下:

推荐阅读