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

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

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

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

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

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值