luasql中的sqlite3查询参数化变量

发布于 2022-09-01 23:13:48 字数 544 浏览 11 评论 0

id_html="zzzzz"
require"luasql.sqlite3"
env=assert(luasql.sqlite3())
conn=assert(env:connect('info_db'))
cursor,res=conn:execute([[select usbkeyid from user_list where userid=id_html]])//假如我把id_html换成‘zzzzz’就可以,但是使用id_html变量就不对,请问是因为在where userid=id_html这里表示id_html变量的方式不对吗? 如果不对,那么如何在select中进行参数查询呢?试了百度的很多方法都不行,求指教,万分感谢!!
print(cursor)
print(res)
row,errorString=cursor:fetch({},"a")
while row do
print(string.format("%s",row.v))
-- reusing the table of results
row = cursor:fetch(row, "a")
end

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

淡淡の花香 2022-09-08 23:13:48

其实问题解决应该不难,因为在lua中[[ 字符串 ]]表示普通的字符串,它不具有变量展开的能力,你可以用2种方法构建完整且合适的sql语句字符串,
. 方法1,利用string.format,如:

--...
sqlstr = string.format("select usbkeyid from userlist where userid=%s",idhtml)
cursor,res=conn:execute( sqlstr )
--...

. 方法2,利用字符串拼接,如:

--...
sqlstr = "select usbkeyid from userlist where userid=" .. idhtml
cursor,res=conn:execute( sqlstr )
--...
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文