『行式报表』通过方法对数据进行过滤
2014-06-20 17:04
267 查看
(关于Scriptcase产品,请查看 http://www.phpscriptcase.com 查看相关功能)
Scriptcase提供了方便的方式直接创建行式报表,可以一键生成简单、直接的报表。Scriptcase会根据数据机构,自动判断其数据类型,并且生成相应格式的字段(如整形、字符型、图片型等等)。
使用Scriptcase创建行式报表虽然方便,但是实际的工作中我们一定会遇到这样的问题:
当前用户只允许查看自己的记录;
组管理员(或者部门管理员)允许查看本组(部门)的数据,对自己的数据可修改、删除,对其他人的数据只能查看(或者可以增加评论);
系统管理员可以查看全部的数据;
这样的需求常见于各类业务系统中,要实现这样的需求并不复杂,只需要一小部分的代码工作就可以完成。
我们假设你使用了Scriptcase提供的『安全』模块作为系统的登录模块,安全模块登录系统后,会生成一个名为[usr_login]的全局变量,如果在任何一个界面该全局变量丢失,系统会提示当前登录已经失效并要求用户重新登录。
我们同时需要做的是当存储数据的时候,需要存储当前用户的用户名,比如,该字段名为createuser。
当Scriptcase自动生成行式报表的时候,在行式报表的『SQL设置』功能可以查看其自动生成的SQL语句,如下图所示:
为了实现『仅查看用户自己的数据』这一功能,非常简单,只需要为上面的SQL语句增加一个条件即可,条件语句为: WHERE createuser='[usr_login]' ,如下图所示:
这样,当行式报表加载的时候,只显示当前用户创建的数据,其他数据将不会显示。
当然,这是最简单的方法,往往在实际情况中无法根据这种方法来对数据进行过滤。比如,如果是普通用户,只能查看个人数据;如果是管理员,则可以查看其所在组的所有成员的数据。这又如何实现呢?
Scriptcase仍然有方法可以实现,就是OnScriptInit事件。
OnScriptInit在页面加载或重载时运行,在运行SQL语句之前执行,因此可以在此事件中对SQL条件进行设置,生成你需要的SQL条件,并且拼凑成最终的SQL语句。
Scriptcase提供了方便的方式直接创建行式报表,可以一键生成简单、直接的报表。Scriptcase会根据数据机构,自动判断其数据类型,并且生成相应格式的字段(如整形、字符型、图片型等等)。
使用Scriptcase创建行式报表虽然方便,但是实际的工作中我们一定会遇到这样的问题:
当前用户只允许查看自己的记录;
组管理员(或者部门管理员)允许查看本组(部门)的数据,对自己的数据可修改、删除,对其他人的数据只能查看(或者可以增加评论);
系统管理员可以查看全部的数据;
这样的需求常见于各类业务系统中,要实现这样的需求并不复杂,只需要一小部分的代码工作就可以完成。
我们假设你使用了Scriptcase提供的『安全』模块作为系统的登录模块,安全模块登录系统后,会生成一个名为[usr_login]的全局变量,如果在任何一个界面该全局变量丢失,系统会提示当前登录已经失效并要求用户重新登录。
我们同时需要做的是当存储数据的时候,需要存储当前用户的用户名,比如,该字段名为createuser。
当Scriptcase自动生成行式报表的时候,在行式报表的『SQL设置』功能可以查看其自动生成的SQL语句,如下图所示:
为了实现『仅查看用户自己的数据』这一功能,非常简单,只需要为上面的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; } }
相关文章推荐
- 『行式报表』通过方法对数据进行过滤
- 通过Ajax进行POST提交JSON类型的数据到SpringMVC Controller的方法
- 思达报表工具Style Report基础教程—用组合框进行数据过滤
- jquery通过select列表选择框对表格数据进行过滤示例
- Matlab函数间通过workspace进行数据共享的方法
- PatentTips - 在物联网中进行数据过滤的方法和装置
- 通过httpclient进行打包进行采集数据方法。
- Java通过MyBatis框架对MySQL数据进行增删查改的基本方法
- 思达报表工具Style Report基础教程—用选择列表,选择树进行数据过滤
- PHP calss类与extends继承、通过调用类的方法与表单数据进行交互
- 通过Ajax进行Post提交Json数据的方法
- 通过Ajax进行POST提交JSON类型的数据到SpringMVC Controller的方法
- JAVA中通过自定义注解进行数据验证的方法
- jQuery的ajax()检验用户名;通过jQuery的load()/get()/post()方法实现;使用XMLHTTPRequest对象来进行AJAX的异步数据交互
- JS对大量数据进行多重过滤的方法
- 通过Ajax进行POST提交JSON类型的数据到SpringMVC Controller的方法
- jquery通过select列表选择框对表格数据进行过滤示例
- 利用GPGPU方法将大量数据通过纹理传输至GPU进行计算
- 通过一次查询按类别输出数据的两种方法
- 通过一次查询按类别输出数据的两种方法