如何解析sql语句中的绑定变量

lcmzgy 2014-05-02 03:27:20
做一个自己使用的文件数据库,为了支持简单sql语句,需要编写一个sql解析器。现在碰到一个问题,
在解析带有绑定变量的sql语句的时候如何将变量真正的值解析出来,
例如,insert into student values('make','+age+'); 这边插入的第二个值是一个变量,问题是sql语句是以一个字符串的形式传递到解析函数里面的,在解析函数里面我该如何获取到这个变量的值?


附带一个问题,有谁写过sql的解析器的吗,能不能分享一下你是怎么编写的吗?我的方法是直接对sql进行解析,将需要的东西解析出来
比如create table student {
name char[8]
age int
}
解析这个语句的时候,我就是将表名student 列信息 name char[8] age int 代表的信息提取出来,存到对应的数据结构中,当然解析的时候也会对sql语句的合法性进行一定的检查,反正我能想到的错误类型都检查了,应该还有差错
...全文
406 13 打赏 收藏 转发到动态 举报
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
Falleyes 2014-05-04
  • 打赏
  • 举报
回复
引用 12 楼 lcmzgy 的回复:
怎么没人回答啊?
大神可能睡觉去了,而且我见得很多人都是用其他语言连接数据库,要不然你试试在MS SQL板块问问?
lcmzgy 2014-05-02
  • 打赏
  • 举报
回复
怎么没人回答啊?
lcmzgy 2014-05-02
  • 打赏
  • 举报
回复
自己顶,求大神
lcmzgy 2014-05-02
  • 打赏
  • 举报
回复
引用 9 楼 derekrose 的回复:
比如说我c++要支持sql 我可能去用一些lib来提供数据库的基本功能 这时候这些库会帮你进行解析变量的部分 这不是sql解析的职责
我的程序是写一个 文件数据库,为了支持sql语句,需要编写一个sql解析器。很明显别的程序使用到我写的这个数据库的时候,一定会用到sql语句,我的sql解析器的功能就是将sql语句转换成具体函数的调用,首先要将sql语句中的一些信息提取出来,比如说上面提到的变量值, 比如说 我解析insert sql语句的函数为 parseInsert(string sql)我需要在parseInsert()函数里面获取sql语句里面的变量值。你懂我的意思了吗?
derekrose 2014-05-02
  • 打赏
  • 举报
回复
比如说我c++要支持sql 我可能去用一些lib来提供数据库的基本功能 这时候这些库会帮你进行解析变量的部分 这不是sql解析的职责
derekrose 2014-05-02
  • 打赏
  • 举报
回复
你的意思是用户定义的变量?? 那变量也不定义在你的本地啊 如果你纯正的写一个sql解释器的话 那么是不存在掺杂变量这种事情的 还是说你要写一个c++相关的sql解释器
lcmzgy 2014-05-02
  • 打赏
  • 举报
回复
引用 6 楼 derekrose 的回复:
很明显在定义变量的时候把变量的字符串形式和变量的地址同时存进去呀
还是不是很清楚,比如说 int age=12; sql=“ insert into 。。。。 ” db.exec(sql); 这个变量由谁来存,我这个程序是数据库,总不能叫用户在使用的时候来存储变量,而且为了解析的时候可以使用map,这个map的作用域是多大,全局?局部?
derekrose 2014-05-02
  • 打赏
  • 举报
回复
很明显在定义变量的时候把变量的字符串形式和变量的地址同时存进去呀
lcmzgy 2014-05-02
  • 打赏
  • 举报
回复
引用 3 楼 derekrose 的回复:
[quote=引用 2 楼 lcmzgy 的回复:] [quote=引用 1 楼 derekrose 的回复:] 用std::map 存变量的值
哈,和我刚想的办法不谋而合 [/quote] 那就不要客气了 哥们 来搞基吧[/quote] 先不急搞基,,,解决问题先,在哪里将变量值存进去呢? 一般我们的调用都是 sql=“ insert into 。。。。 ” db.exec(sql); 明显没有将变量存到map的时机啊? 你的将变量存进去map里面的具体操作时怎样呢?请赐教!
Falleyes 2014-05-02
  • 打赏
  • 举报
回复
楼上证明了这是一个屌丝的论坛
derekrose 2014-05-02
  • 打赏
  • 举报
回复
引用 2 楼 lcmzgy 的回复:
[quote=引用 1 楼 derekrose 的回复:] 用std::map 存变量的值
哈,和我刚想的办法不谋而合 [/quote] 那就不要客气了 哥们 来搞基吧
lcmzgy 2014-05-02
  • 打赏
  • 举报
回复
引用 1 楼 derekrose 的回复:
用std::map 存变量的值
哈,和我刚想的办法不谋而合
derekrose 2014-05-02
  • 打赏
  • 举报
回复
用std::map 存变量的值

65,208

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧