如何在Lua脚本中处理FreeSWITCH的Dbh查询返回零行时匹配"-ERR no reply"?
2019-6-25 17:8:43
收藏:0
阅读:152
评论:1
PostgreSQL表:
mydb=# table phone_numbers;
pn_id | user_id | phone_number
-------+---------+--------------
1 | 2 | 5550001111
4 | 2 | 5552223333
给定下面的Lua脚本:
conn_string =
"pgsql://hostaddr=1.2.3.4" ..
" dbname=mydb" ..
" user=postgres" ..
" password=postgres" ..
" options='-c client_min_messages=NOTICE'" ..
" application_name='myapp'"
dbh = freeswitch.Dbh(conn_string)
assert(dbh:connected())
freeswitch.consoleLog("INFO", "lua脚本:连接到数据库")
q =
"SELECT user_id, phone_number " ..
"FROM phone_numbers " ..
"WHERE phone_number = '5552223333'"
dbh:query(q, function(row)
freeswitch.consoleLog("INFO", "dbh:query回调中的日志")
for column_name, row_val in pairs(row) do
stream:write(string.format("%5s : %s\n", column_name, row_val))
end
end)
dbh:release()
在fs_cli中调用它的结果是
freeswitch@server> lua test.lua
user_id : 2
phone_number : 5552223333
[INFO] switch_cpp.cpp:1443 lua脚本:连接到数据库
[INFO] switch_cpp.cpp:1443 dbh:query回调中的日志
另一方面,当使用不会返回任何行的查询时,例如
q =
"SELECT user_id, phone_number " ..
"FROM phone_numbers " ..
"WHERE phone_number = '1234567890'"
那么将返回一个 "error" 并且 dbh:query() 回调甚至不会被调用:
freeswitch@server> lua test.lua
-ERR no reply
[INFO] switch_cpp.cpp:1443 lua脚本:连接到数据库
将 "error" 用引号括起来,因为它似乎不像错误处理一样工作;至少,我尝试了pcall,但没有成功。
匹配 -ERR no reply 结果(当查询结果为零行时)将是重要的,这样在这种情况下可以挂断呼叫。
解决方法
仅是为了记录,我通过调整SQL查询来找到了解决方法,使用 EXISTS 或 COALESCE ,因为它们始终提供可以从脚本中匹配的返回值,但我相信还有更好的方法。例如:
q =
"SELECT COALESCE(" ..
"SELECT user_id, phone_number " ..
"FROM phone_numbers " ..
"WHERE phone_number = '1234567890'" ..
", '0'" ..
")"
dbh:query(q, function(row)
if row.coalesce == "0" then
freeswitch.consoleLog("INFO", "零结果")
end
end)
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- Lua 虚拟机加密load(string.dump(function)) 后执行失败问题如何解决
- 我想创建一个 Nginx 规则,禁止访问
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?

如果查询没有结果,回调函数将不会运行。但是,您可以在回调函数中设置一个本地变量,以便知道回调函数是否运行(即查询是否有结果)。例如:
q = "SELECT COALESCE(" .. "(SELECT phone_number " .. "FROM phone_numbers " .. "WHERE phone_number = '" .. ani .. "')" .. ", '0'" .. ")" local got_results dbh:query(q, function(row) got_results = true -- 其他必要的操作 end) if not got_results then freeswitch.consoleLog("INFO", "零结果") -- 处理零结果的操作 end