【连载】关系型数据库是如何工作的?(10) - 查询管理器之解析

解析器会检查每条语句都会的关键字语法正确性,如果一条语句语法有误,解析器会拒绝本次请求。例如:如果把”SELECT”写成”SLECT”,就会遭到拒绝。

解析器还会进一步检查关键字出现的顺序,比如WHERE出现在SELECT之前就会被拒绝。

另外,查询中的表明和字段名会被解析,解析器会使用数据库的运输局来进行对比检查:

  • 表是否存在。
  • 表中的字段是否存在。
  • 对于这种字段类型的操作是否合法,比如:不能将String和Integer进行对比、不能对一个Integer使用substring()函数。

还会检查当前用户是否具备读或写表的权限,这些权限同样是由DBA来设置。在解析之后,SQL语句会被转换为一种数据库内部表示,通常是转换为一种树结构。如果解析器一切OK,那么内部表示就会被转发给重写器继续处理。

你可能感兴趣的:(数据库,mysql,select,sql解析)