历史版本2 :与数据库中数据对比校验 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

1. 问题描述编辑

在填报模板中,往往会遇到一般的校验可能无法满足您的需求。例如:用户更改密码时,要先输入原始密码,输入的密码要和数据库中对应的值进行校验,若相同则更新,若不同则报错。下面以这个实例简单介绍一下。

2. 实现思路编辑

数据校验可以使用公式对单元格进行校验,例子中的问题可以使用sql公式将对应的字段取出,。

3. 实现步骤编辑

这里我们使用服务器数据集里的用户信息表userinfo,内容如下:
3.1 模板设计
这里我们使用默认参数$fr_username(用于修改密码使用),然后表样设计如下:
3.2 报表填报属性设置
按照下图设置报表填报属性:
3.3 数据校验设置
选择模板>报表填报属性>数据校验,在校验公式内输入:B2==sql("FRDemo","select * from userinfo where username='"+$fr_username+"'",3),在校验出错信息中输入:密码与原始密码不同,不能修改!如下图:
校验的意义:B2里面的数据必须和当前用户的密码相同,若不同则报错。
注:这个例子只是说明将单元格中的数据和数据库的数据进行匹配校验,您也可以对单元格进行其它校验设置。
3.4 填报预览
点击填报预览,以用户名为Anna进行登录,访问该模板,当输入的旧密码不是123456时,点击提交就会弹出如下对话框:
当输入旧密码123456,新密码1234,点击提交,用户名Anna的密码已修改为1234,如下图: