• 『行式报表』通过方法对数据进行过滤


    (关于Scriptcase产品,请查看 http://www.phpscriptcase.com 查看相关功能)

    Scriptcase提供了方便的方式直接创建行式报表,能够一键生成简单、直接的报表。

    Scriptcase会依据数据机构,自己主动推断其数据类型,而且生成对应格式的字段(如整形、字符型、图片型等等)。


    使用Scriptcase创建行式报表尽管方便,可是实际的工作中我们一定会遇到这种问题:

    • 当前用户仅仅同意查看自己的记录;
    • 组管理员(或者部门管理员)同意查看本组(部门)的数据,对自己的数据可改动、删除,对其它人的数据仅仅能查看(或者能够添加评论);
    • 系统管理员能够查看所有的数据。

    这种需求常见于各类业务系统中,要实现这种需求并不复杂,仅仅须要一小部分的代码工作就能够完毕。


    我们假设你使用了Scriptcase提供的『安全』模块作为系统的登录模块。安全模块登录系统后,会生成一个名为[usr_login]的全局变量,假设在不论什么一个界面该全局变量丢失,系统会提示当前登录已经失效并要求用户又一次登录。


    我们同一时候须要做的是当存储数据的时候。须要存储当前用户的username。比方,该字段名为createuser。


    当Scriptcase自己主动生成行式报表的时候。在行式报表的『SQL设置』功能能够查看其自己主动生成的SQL语句。例如以下图所看到的:



    为了实现『仅查看用户自己的数据』这一功能,很easy。仅仅须要为上面的SQL语句添加一个条件就可以。条件语句为: WHERE createuser='[usr_login]' 。例如以下图所看到的:




    这样,当行式报表载入的时候。仅仅显示当前用户创建的数据,其它数据将不会显示。


    当然。这是最简单的方法,往往在实际情况中无法依据这个方案来对数据进行过滤。比方,假设是普通用户,仅仅能查看个人数据。假设是管理员。则能够查看其所在组的所有成员的数据。这又怎样实现呢?


    Scriptcase仍然有方法能够实现,就是OnScriptInit事件。


    OnScriptInit在页面载入或重载时执行。在执行SQL语句之前执行,因此能够在此事件中对SQL条件进行设置,生成你须要的SQL条件。而且拼凑成终于的SQL语句。


    if ($condition != ""){ 
                 if (empty({sc_where_current})) 
                 { 
                     sc_select_where(add) = " where " . $condition; 
                 } 
                 else 
                 { 
                     sc_select_where(add) = " AND " . $condition; 
                 } 
             } 
    



  • 相关阅读:
    TCP心跳包
    interesting site
    TestNG环境搭建以及框架初识
    lambda表达式
    subprocess学习
    使用psutil模块获取电脑运行信息
    使用ssh和putty操控远程的linux server
    ubuntu系统源的更新
    将python的程序包装成windows下的service
    使用python进行re拆分网页内容
  • 原文地址:https://www.cnblogs.com/zhchoutai/p/8559296.html
Copyright © 2020-2023  润新知