【1】问题场景原代码

引起问题的原代码,访问数据库,汇总数据后,使用汇总结果报异常:

     local function amount_sum_fee(cycleid)
         local select_productid = "select product_id from np_cdr_" .. cycleid .. " group by product_id;"
         local rtn, productid_set = executeSql(select_productid)
         if rtn then

             local sql_const = "insert into compare_fee_" .. cycleid .. " (product_id, np_id, np_sum_duration, np_total_times, " ..
             " np_sum_qty, np_sum_fee, un_sum_duration, un_total_times, un_sum_fee, sum_np_fee, sum_original_fee) values "
             if type(productid_set) == 'table' and next(productid_set) ~= nil then
                 for key, record in pairs(productid_set) do
                     local amount_table = {}
                     amount_table["product_id"] = record["product_id"]
                     amount_table["np_id"] = 'all'
                     -- np总费用统计
                     local np_sum_fee = "SELECT product_id, SUM(duration) AS np_sum_duration, " ..
                     " COUNT(id) AS np_sum_cdrCnt, " ..
                     " SUM(service_qty) AS np_service_qty, " ..
                     " SUM(service_fee) AS np_service_fee, " ..
                     " SUM(np_fee) AS np_sum_fee, " ..
                     " SUM(original_fee) AS np_sum_original_fee " ..
                     " FROM np_cdr_" .. cycleid .. " WHERE product_id = '" .. record["product_id"] .. "';"
                     local rtn, desc = executeSql(np_sum_fee)
                     if rtn and next(desc) ~= nil then
                         amount_table[]["np_sum_duration"]
                         amount_table[]["np_sum_cdrCnt"]
                         amount_table[]["np_service_qty"]
                         amount_table[]["np_service_fee"]
                         amount_table[]["np_sum_fee"]
                         amount_table[]["np_sum_original_fee"]
                     end
                     -- un总费用统计
                     local un_sum_fee = "SELECT product_id, SUM(total_duration) AS un_sum_duration, " ..
                     " SUM(total_times) AS un_sum_cdrCnt, " ..
                     " SUM(total_fee) AS un_sum_fee " ..
                     " FROM dat_bill_" .. cycleid .. " WHERE call_type & 4097 > 0 AND product_id = '" .. record["product_id"] .. "';"
                     local rtn, desc = executeSql(un_sum_fee)
                     if rtn and next(desc) ~= nil then
                         amount_table[]["un_sum_duration"]
                         amount_table[]["un_sum_cdrCnt"]
                         amount_table[]["un_sum_fee"]
                     end
                     -- 构建sql语句
                      then
                         insert_sql = insert_sql .. ","
                     else
                         insert_sql = sql_const
                     end
                     insert_sql = insert_sql .. "('" ..
                     amount_table["product_id"] .. "', '" ..
                     amount_table["np_id"] .. "', " ..
                     amount_table["np_sum_duration"] .. ", " ..
                     amount_table["np_total_times"] .. ", " ..
                     amount_table["np_sum_qty"] .. ", " ..
                     amount_table["np_sum_fee"] .. ", " ..
                     amount_table["un_sum_duration"] .. ", " ..
                     amount_table["un_total_times"].. ", " ..
                     amount_table["un_sum_fee"] .. ", " ..
                     amount_table["sum_np_fee"] .. ", " ..
                     amount_table["sum_original_fee"] .. ")"
                     value_count = value_count +
                      == value_count then
                         sum_count = sum_count + value_count
                         insert_sql = insert_sql .. "; commit;"
                         local rtn, result = executeSql(insert_sql)
                         if not rtn then
                             rtnstr[
                             rtnstr["msg"] = "Error. amount_sum_fee insert into sum_fee num : " .. sum_count .. " sql : " .. insert_sql
                             return false
                         else
                             local result = "compare: success to amount_sum_fee insert into sum_fee num : " .. sum_count
                             ngx.log(ngx.ERR, result)
                         end
                         insert_sql = ""
                         value_count =
                     end
                 end
                  then
                     sum_count = sum_count + value_count
                     insert_sql = insert_sql .. "; commit;"
                     local rtn, result = executeSql(insert_sql)
                     if not rtn then
                         rtnstr[
                         rtnstr["msg"] = "Error. amount_sum_fee insert into sum_fee num : " .. sum_count .. " sql : " .. insert_sql
                         return false
                     else
                         local result = "compare: success to amount_sum_fee insert into sum_fee num : " .. sum_count
                         ngx.log(ngx.ERR, result)
                     end
                     insert_sql = ""
                     value_count =
                 end
             end
         else
             rtnstr[
             rtnstr["msg"] = "Failed to select product_id amount_sum_fee error : " .. productid_set
             return false
         end
         return true
     end

使用的是SQL中的sum函数

【2】分析原因

数据库访问汇总数据时,SUM函数的结果可能为NULL值。如下图:

修改SQL语句,添加IFNULL判断,若为NULL,则为0即可。如下图:

如上原因分析。

【3】修复后代码

     local function amount_sum_fee(cycleid)
         local select_productid = "select product_id from np_cdr_" .. cycleid .. " group by product_id;"
         local rtn, productid_set = executeSql(select_productid)
         if rtn then

             local sql_const = "insert into compare_fee_" .. cycleid .. " (product_id, np_id, np_sum_duration, np_total_times, " ..
             " np_sum_qty, np_sum_fee, un_sum_duration, un_total_times, un_sum_fee, sum_np_fee, sum_original_fee) values "
             if type(productid_set) == 'table' and next(productid_set) ~= nil then
                 for key, record in pairs(productid_set) do
                     local amount_table = {}
                     amount_table["product_id"] = record["product_id"]
                     amount_table["np_id"] = 'all'
                     -- np总费用统计
                     local np_sum_fee = "SELECT product_id, IFNULL(SUM(duration), 0) AS np_sum_duration, " ..
                     " COUNT(id) AS np_sum_cdrCnt, " ..
                     " IFNULL(SUM(service_qty), 0) AS np_service_qty, " ..
                     " IFNULL(SUM(service_fee), 0) AS np_service_fee, " ..
                     " IFNULL(SUM(np_fee), 0) AS np_sum_fee, " ..
                     " IFNULL(SUM(original_fee), 0) AS np_sum_original_fee " ..
                     " FROM np_cdr_" .. cycleid .. " WHERE product_id = '" .. record["product_id"] .. "';"
                     local rtn, desc = executeSql(np_sum_fee)
                     if rtn and next(desc) ~= nil then
                         amount_table[]["np_sum_duration"]
                         amount_table[]["np_sum_cdrCnt"]
                         amount_table[]["np_service_qty"]
                         amount_table[]["np_service_fee"]
                         amount_table[]["np_sum_fee"]
                         amount_table[]["np_sum_original_fee"]
                     end
                     -- un总费用统计
                     local un_sum_fee = "SELECT product_id, IFNULL(SUM(total_duration), 0) AS un_sum_duration, " ..
                     " IFNULL(SUM(total_times), 0) AS un_sum_cdrCnt, " ..
                     " IFNULL(SUM(total_fee), 0) AS un_sum_fee " ..
                     " FROM dat_bill_" .. cycleid .. " WHERE call_type & 4097 > 0 AND product_id = '" .. record["product_id"] .. "';"
                     local rtn, desc = executeSql(un_sum_fee)
                     if rtn and next(desc) ~= nil then
                         amount_table[]["un_sum_duration"]
                         amount_table[]["un_sum_cdrCnt"]
                         amount_table[]["un_sum_fee"]
                     end
                     -- 构建sql语句
                      then
                         insert_sql = insert_sql .. ","
                     else
                         insert_sql = sql_const
                     end
                     insert_sql = insert_sql .. "('" ..
                     amount_table["product_id"] .. "', '" ..
                     amount_table["np_id"] .. "', " ..
                     amount_table["np_sum_duration"] .. ", " ..
                     amount_table["np_total_times"] .. ", " ..
                     amount_table["np_sum_qty"] .. ", " ..
                     amount_table["np_sum_fee"] .. ", " ..
                     amount_table["un_sum_duration"] .. ", " ..
                     amount_table["un_total_times"].. ", " ..
                     amount_table["un_sum_fee"] .. ", " ..
                     amount_table["sum_np_fee"] .. ", " ..
                     amount_table["sum_original_fee"] .. ")"
                     value_count = value_count +
                      == value_count then
                         sum_count = sum_count + value_count
                         insert_sql = insert_sql .. "; commit;"
                         local rtn, result = executeSql(insert_sql)
                         if not rtn then
                             rtnstr[
                             rtnstr["msg"] = "Error. amount_sum_fee insert into sum_fee num : " .. sum_count .. " sql : " .. insert_sql
                             return false
                         else
                             local result = "compare: success to amount_sum_fee insert into sum_fee num : " .. sum_count
                             ngx.log(ngx.ERR, result)
                         end
                         insert_sql = ""
                         value_count =
                     end
                 end
                  then
                     sum_count = sum_count + value_count
                     insert_sql = insert_sql .. "; commit;"
                     local rtn, result = executeSql(insert_sql)
                     if not rtn then
                         rtnstr[
                         rtnstr["msg"] = "Error. amount_sum_fee insert into sum_fee num : " .. sum_count .. " sql : " .. insert_sql
                         return false
                     else
                         local result = "compare: success to amount_sum_fee insert into sum_fee num : " .. sum_count
                         ngx.log(ngx.ERR, result)
                     end
                     insert_sql = ""
                     value_count =
                 end
             end
         else
             rtnstr[
             rtnstr["msg"] = "Failed to select product_id amount_sum_fee error : " .. productid_set
             return false
         end
         return true
     end

【4】总结

Lua中使用SQL语句进行汇总数据时,切记需要作NULL判断。

Good Good Study, Day Day Up.

顺序 选择 循环 总结

lua entry thread aborted: runtime error: /usr/../process.lua:448: attempt to concatenate field 'np_sum_duration' (a userdata value)的更多相关文章

  1. openresty 报错:lua entry thread aborted: runtime error

    [1]问题现象 (1)本地openresty系统 (2)报错信息 2019/09/10 08:13:55 [error] 2385#2385: *4 lua entry thread aborted: ...

  2. /usr/bin/docker-current: Error response from daemon: oci runtime error: container_linux.go:247: starting container process caused "process_linux.go:245: running exec setns .....

    docker创建容器时报错如下: containerd: start container" error="oci runtime error: container_linux.go ...

  3. centos7.2部署docker-17.06.0-ce的bug:Error response from daemon: oci runtime error: container_linux.go:262: starting container process caused "process_linux.go:339: container init caused \"\"".

    现象: 操作系统:centos 7.2 kernel 3.10.0-327.el7.x86_64 mesos:1.3.0 docker:docker-17.06.0-ce 在做mesos验证时,通过m ...

  4. error: /usr/include/objc/objc-class.h: No such file or directory

    When i use the example of ShareKit package,i have come across this error:"error: /usr/include/o ...

  5. Heka 编译安装后 运行报错 panic: runtime error: cgo argument has Go pointer to Go pointer

    Heka 编译安装后 运行报错 panic: runtime error: cgo argument has Go pointer to Go pointer 解决办法: 1.  Start heka ...

  6. ERROR: child process failed, exited with error number 100

    [root@localhost ~]# mongod --dbpath=/usr/local/mongodb/data --logpath=/usr/local/mongodb/logs --loga ...

  7. mongodb启动时报错ERROR: child process failed, exited with error number 1

    不多说,直接上干货! 前期博客 Ubuntu14.04下Mongodb安装部署步骤(图文详解) Ubuntu16.04下Mongodb安装部署步骤(图文详解) root@zhouls-virtual- ...

  8. Finished with error: ProcessException: Process "D:\FlutterAPP\flutter_appfive\android\gradlew.bat" exited abnormally:

    在使用Flutter进行开发是遇到这样一个问题 Finished with error: ProcessException: Process "D:\FlutterAPP\flutter_a ...

  9. lua.c:82:10: fatal error: readline/readline.h: No such file or directory #include <readline/readline.h>

    make linuxcd src && make linuxmake[1]: Entering directory `/root/lua/lua-5.3.2/src'make all ...

随机推荐

  1. Python Lab Assignments

    引用: https://github.com/saismaran33/Python-Lab-Assignments/wiki/Python-Lab-Assignment-2 Lab 1 对于任何Web ...

  2. java--Date时间

    Date: 表示特定的瞬间,精确到毫秒,通过方法设定自己所表示的时间,可以表示任意的时间 System.currentTimeMillis() :返回的当前系统时间, 1970-1-1 至今的毫秒数 ...

  3. 【微信小程序】抽象组件使用示例

        1.配置页面路径 ./app.json { "pages":[ "pages/index/index", "pages/logs/logs&q ...

  4. Django的视图系统:View

    一.CBV和FBV FBV:functoin based view,基于函数的view 我们之前写过的都是基于函数的view CBV:class based view,基于类的view 定义CBV: ...

  5. 不懂APS系统?十个问答让你对APS瞬间明明白白

    本文为您解答APS自动排程系统导入中客户常见的问题,帮助您评估企业是否适合导入APS,并了解需要的人力和资金的投入. Q1:哪些企业需要导入APS? A1: 编制生产计划有困难的企业都可以开始考虑导入 ...

  6. 【前端_js】jQuery动态设置元素的样式

    1.用css()方法查询元素的某个样式 $("div").css("padding-left")); 2.用css()方法设置元素的样式 法一: $(" ...

  7. min25筛学习总结

    前言 杜教筛学了,顺便把min25筛也学了吧= =刚好多校也有一道题需要补. 下面推荐几篇博客,我之后写一点自己的理解就是了. 传送门1 传送门2 传送门3 这几篇写得都还是挺好的,接下来我就写下自己 ...

  8. 2019徐州网络赛H :function (min25筛)

    题意:f(i)=i的幂次之和. 求(N+1-i)*f(i)之和. 思路:可以推论得对于一个素数p^k,其贡献是ans=(N+1)[N/(P^k)]+P^k(1+2+3...N/(P^k)); 我们分两 ...

  9. django 修改 request 对象中的请求参数, 并重新赋值给 request 对象

    直接上代码, 实现流程看代码及注释 def your_view(self, request): method = request.method if method == "GET" ...

  10. mysql数据库锁的机制-one

    锁概念 : 当高并发访问同一个资源时,可能会导致数据不一致,需要一种机制将用户访问数据的顺序进行规范化,以保证数据库数据的一致性.锁就是其中的一种机制. 举例 :以买火车票为例,火车票可面向广大消费者 ...