您好,欢迎访问一九零五行业门户网

利用DB2 V10.1中的全局变量实现全球化

本文的第 1 部分 展示了 db2 v10.1 的安全性特性如何满足将来自多个国家(行政区)的数据整合到单独一组表中的组织的关键业务需求: 1. 使本地用户仅能访问其所在国家(行政区)的数据 2. 使地区用户仅能访问其所在地区的数据 3. 针对地区用户,实现地方敏感
本文的第 1 部分 展示了 db2 v10.1 的安全性特性如何满足将来自多个国家(行政区)的数据整合到单独一组表中的组织的关键业务需求:
1. 使本地用户仅能访问其所在国家(行政区)的数据
2. 使地区用户仅能访问其所在地区的数据
3. 针对地区用户,实现“地方敏感型”,自动将不同国家(行政区)的币种值转为通用币种(例如,为了汇总分别使用新加坡货币和中国香港货币的两种商品的价格,需要进行币种转换)
4. 根据用户是本地用户还是地区用户来屏蔽列数据
本文以第1 部分作为基础,展示了如何利用全局变量和角色来降低代码复杂性、提高有用性,同时动态计算对地方敏感的日期/时间段。
提高指定日期/时间值时的有用性
全局变量可用于使 sql 更易理解。您不必再在 sql 语句中指定复杂的公式,而是可以为该公式创建一个全局变量,直接指定该变量。全局变量提供了共享的通用例程,可在任何 sql 中使用它们,这些例程消除了重复编写相同代码的需要。除此之外,利用全局变量时,只需在指定公式的位置创建变量一次,因此可减少 sql 中的错误。
全局变量支持使用描述性名称,这有助于用户或读者确定应执行哪些计算。例如,指定一周的第一天时,可以在查询中包含这样的计算:
select … from real_estate_sales
where property_type = ‘condo’
and effective_date =
current_date – (dayofweek_iso (current_date)-1) days)
我们也可以创建一个全局变量来改善可读性。这允许任何查看 sql 语句的用户确定查询执行的日期计算:
create variable first_day_of_week date
default
(current_date – (dayofweek_iso (current_date)-1) days)
现在,可将查询写为:
select … from real_estate_sales
where property_type = ‘condo’
and effective date = first_day_of_week
全局变量允许我们指定一个“常量”,全局变量的名称表示业务查询执行的操作。下面给出了几个常用的日期/时间段:
1. 今天
2. 昨天
3. 明天
4. 一个月的第一天
5. 一个月的最后一天
6. 一个星期的第一天
7. 当前季度的第一天
利用全局变量,可以通过用户友好、易于阅读的格式表示这些时间段。下面给出了上述时间段的定义。
今天:
create variable today date default current date
昨天:
create variable yesterday date default current date – 1 day
明天:
create variable tomorrow date default current date + 1 day
一个月的第一天:
create variable first_day_of_current_month date
default
(current_date – (day (current_date)-1) days)
一个月的最后一天:
create variable last_day_of_current_month date
default
(last_day (current date))
一个星期的第一天:
create variable first_day_of_week date
default
(current_date – (dayofweek_iso (current_date)-1) days)
当前季度的第一天(请注意,定义中也使用了全局变量 first_day_of_the_current_month):
create variable first_day_of_quarter date
default
(round (first_day_of_current_month,’q'))
其它类似信息

推荐信息