关于oceanbase中存储过程的设计与实现

转自http://www.zhujuncoding.com/index.php/Index/blogview?id=82

这篇文章是关于在淘宝的数据库oceanbase中添加存储过程支持的文章,oceanbase在下文中使用ob简称

    学校接的项目要在开源数据系统oceanbase中实现存储过程的

    首先、我们要进行语法分析和词法分析,这两个使用开源的flex & bison来做,因为在ob中的sql语句解析就是使用这样的模式来做的,我们存储过程的实现是参考postgrepsql中的存储过程部分来实现的

    语句输入后由 语言处理模块分离出 过程语言和 sql语句

    Sql 语句调用oceanbase的sql引擎来执行

    过程语言 进行语法分析,把变量和数据类型保存符号表中

    中间代码保存在缓存中,而源代码需要保存在数据库系统表中

    

    存储过程执行

    使用名字堆栈 (解决变量的作用域)

    

        词法分析 ->语法分析–>语义处理

   

原文地址:https://www.cnblogs.com/zhujunxxxxx/p/3918973.html