1. 单主键
Employee 表的主键为 empno,那么脚本中的 update 函数配置为:
A1.update@k(employee:employee_old,employee,empno,ename,salary,sex;empno)
在英文分号前面配置主键 empno,报表在做更新解决时,会以 empno 为主键比照 employee 和 employee_old 对象的数据,而后将差别数据更新到表 employee 中。
完整版脚本内容如下图所示:
2. 多主键
个别状况下,物理表只设置一个主键字段就能够将数据记录辨别开来,非凡状况下会设置两个及以上主键字段,例如上述 employee 表咱们能够通过 empno 字段来辨别数据记录,也能够通过 ename+sex 两个字段来锁定惟一一条符合条件的记录,此时咱们的脚本中应该如何设置主键呢?
很简略,只须要用英文逗号隔开多个主键字段就能够了:
A1.update@k(employee:employee_old,employee,empno,ename,salary,sex;ename,sex)
完整版脚本内容如下图所示:
3. 自增主键
自增主键能够晋升查问效率、节俭磁盘空间,在填报中也有广泛应用。以 mysql 设置为例:能够通过第三方工具(如 Navicat)或者 sql 语句设置某个主键字段的数据主动增长。
在数据库端很容易配置主键字段的主动增长,那么在润乾报表中如何实现主动增长字段的数据更新呢?很简略,只须要增加一个 @1 选项就搞定了。
A1.update@1k(employee:employee_old,employee,empno,ename,salary,sex;empno)
其中,@1 选项示意第一个字段是自增字段,没有对应更新值表达式
留神:这里是数字 1 而不是字母 l
完整版脚本内容如下图所示:
4.“动静”主键
“动静”主键咱们了解成通常说的 UUID,示意主键的值是一个不反复的随机数,这种形式比主动增长形式更平安、反复率更低。
咱们以 mysql 数据库为例,将随机生成的四位数字作为主键 empno 的数据,并将数据更新入库。在润乾报表中只须要多一步 run 操作给主键字段赋值,剩下的和惯例更新配置一样。
=employee.run(if(empno==null,~.empno=A1.query(“select round(round(rand(),4)*10000) as xuhao”).xuhao)) // 当 employee 对象中的主键 empno 字段为空的时候,咱们将随机生成的四位数字赋值给主键字段
(这里为什么条件是判断为空呢?因为个别自增主键或者 UUID 主键都不容许编辑或者间接设置用户不可见,所以此时新增的记录中主键字段为空。)
完整版脚本内容如下图所示: