1

如何xpcall error像 assert 一样从 LuaSQL 驱动程序获取错误输出作为函数的参数?

例如,通过运行以下代码:

local conn =  assert (env:connect("demo_database",config.db.username,config.db.password,config.db.host))

我收到以下错误:

LuaSQL: error connecting to database. MySQL: Access denied for user 'user_1'@'host1' (using password: YES)

但是当我运行以下代码时:

local function myerrorhandler( err )
    local file = assert( io.open( "/tmp/testout.txt", "w" ) )
    file:write( err.." - error\n" )
    file:close()
end

local conn = xpcall (env:connect("demo_database",config.db.username,config.db.password,config.db.host), myerrorhandler)

我在日志文件中得到的错误是:attempt to call a nil value - error

4

1 回答 1

1

xpcall期望第一个参数是一个函数,它将调用并从中捕获错误。你基本上是在做xpcall(func(), handler),即调用func而不是仅仅将它传递给xpcall,类似于pcall期望函数作为第一个参数的方式。

您基本上想将代码包装在一个函数中:

local conn = xpcall(function()
    return env:connect("demo_database", config.db.username, config.db.password, config.db.host)
end, myerrorhandler)
于 2021-08-05T18:15:28.683 回答