内置提交校验使用公式示例一

编辑
  • 文档创建者:文档助手1
  • 浏览次数:10209次
  • 编辑次数:13次
  • 最近更新:先知 于 2019-06-10
  • 1. 问题描述

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

    2. 实现思路

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

    3. 实现步骤

    这里我们使用服务器数据集里的用户信息表 userinfo,内容如下:

    3.1 模板设计

    这里我们使用默认参数$fr_username(用于修改密码使用),然后表样设计如下:

    注:$fr_username具体应用可参考权限细粒度之参数控制

    3.2 报表填报属性设置

    按照下图设置报表填报属性,数据库为 FRDemo,表为 userinfo,只能添加 username 和 userpass,值分别为参数$fr_username和 B3 单元格:

    3.3 数据校验设置

    选择模板>报表填报属性>数据校验,在校验公式内输入:B2==sql("FRDemo","select * from userinfo where username='"+$fr_username+"'",3),这里公式的含义是在userinfo 表中查询用户名对应的密码,详细公式解释查看SQL 函数,在校验出错信息中输入:"輸入的原始密码与數據庫中的原始密码不同,不能修改!"如下图:

    校验的意义:B2 里面的数据必须和当前用户的密码相同,若不同则报错。

    注:这个例子只是说明将单元格中的数据和数据库的数据进行匹配校验,您也可以对单元格进行其它校验设置。

    3.4 填报预览

    点击填报预览,以用户名 Anna 进行登录,访问该模板,当输入的旧密码不是 123456 时,点击提交就会弹出如下对话框:

    当输入旧密码 123456,新密码 1234,点击提交,用户名 Anna 的密码已修改为 1234,如下图:


    附件列表


    主题: 填报应用
    标签: 暂无标签 编辑/添加标签
    如果您认为本文档还有待完善,请编辑

    文档内容仅供参考,如果你需要获取更多帮助,付费/准付费客户请咨询帆软技术支持
    关于技术问题,您还可以前往帆软社区,点击顶部搜索框旁边的提问按钮
    若您还有其他非技术类问题,可以联系帆软传说哥(qq:1745114201

    此页面有帮助吗?只是浏览 [ 去社区提问 ]