尝试连接全局变量'q2'(一个表值) corona错误
2018-1-26 0:24:50
收藏:0
阅读:89
评论:2
我正在做一个corona项目,我一直在尝试将2个文本框值插入到我的sqlite数据库中,但是我无法做到这一点,不断出现一个错误“尝试连接全局变量'q2'(一个表值)”,下面是错误截图。

local widget = require "widget"
local sqlite3 = require( "sqlite3" )
local path = system.pathForFile( "data.db", system.DocumentsDirectory )
local db = sqlite3.open( path )
local tablesetup = [[CREATE TABLE IF NOT EXISTS test (id INTEGER PRIMARY KEY, q1, q2);]]
print( tablesetup )
db:exec( tablesetup )
_G.numericField = q1
local function textListener( event )
if ( event.phase == "began" ) then
-- 用户开始编辑“numericField”
end
end
-- 创建文本框
q1 = native.newTextField( 290, 150, 50, 30 )
q1.inputType = "number"
q1:addEventListener( "userInput", textListener )
_G.numericField1 = q2
local function textListener( event )
if ( event.phase == "began" ) then
-- 用户开始编辑“numericField”
end
end
-- 创建文本框
q2 = native.newTextField( 290, 50, 50, 30 )
q2.inputType = "number"
q2:addEventListener( "userInput", textListener )
saveData = function ( event )
--textString = q1.text
--textString = q2.text
-- LINE 39 IS BELOW
local tablefill = [[INSERT INTO test VALUES (NULL, ']]..q1..[[',']]..q2..[['); ]]
db:exec( tablefill )
end
savebutton = widget.newButton {
left = 60,
top = 250,
default = "buttonGreen.png",
over = "buttonGreenOver.png",
label = "Update",
embose = true,
onRelease = saveData
}
有人能帮忙吗?先感谢您!
更新(第36-41行)
saveData = function ( event )
q1.text = ""
q2.text = ""
local tablefill = [[INSERT INTO test VALUES (NULL, ']]..q1..[[',']]..q2..[['); ]]
db:exec( tablefill )
end
现在我仍然得到相同的错误,但是这次是在第40行。
点赞
用户7026995
要获取 TextField 对象的值,请使用 textField.text。它会返回表示原生文本输入字段内容的字符串。
指令 q1.text 和 q2.text 适用于你。
2018-01-25 09:03:32
评论区的留言会收到邮件通知哦~
推荐文章
- 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 代码?

你正在创建
q1和q2对象(它们表示为表格),但随后尝试将它们的值作为字符串连接:q1 = native.newTextField( 290, 150, 50, 30 ) ... q2 = native.newTextField( 290, 50, 50, 30 ) ... local tablefill = [[INSERT INTO test VALUES (NULL, ']]..q1..[[',']]..q2..[['); ]]我不确定你想要做什么,但这是行不通的,因为表格值不能这样连接。
假设
q1.text给出了你想要的值,这样做应该可以:local tablefill = [[INSERT INTO test VALUES (NULL, ']]..(q1.text or "") ..[[',']]..(q2.text or "")..[['); ]]请注意,将值连接成SQL查询的方式使其容易受到SQL注入攻击的影响;你最好使用占位符而不是这种方式。