gpt4 book ai didi

hibernate - 使用 transient 字段在 grails 中查询和排序数据库结果

转载 作者:行者123 更新时间:2023-12-03 06:59:45 25 4
gpt4 key购买 nike

我正在尝试显示 grails 域对象中的分页数据。例如:我有一个域对象 Employee ,其属性firstName和lastName是 transient 的,当调用它们的setter/getter方法时,它们会加密/解密数据。数据以加密的二进制格式保存在数据库中,因此无法按这些字段排序。再说一遍,也不能按 transient 排序,如下所示: http://www.grails.org/GSP+Tag+-+sortableColumn .

所以现在我正在尝试找到一种以类似于以下方式使用 transient 的方法:

Employee.withCriteria( max: 10, offset: 30 ){
order 'lastName', 'asc'
order 'firstName', 'asc'
}

类(class)是:

class Employee {

byte[] encryptedFirstName
byte[] encryptedLastName

static transients = [
'firstName',
'lastName'
]


String getFirstName(){
decrypt("encryptedFirstName")
}

void setFirstName(String item){
encrypt("encryptedFirstName",item)
}

String getLastName(){
decrypt("encryptedLastName")
}

void setLastName(String item){
encrypt("encryptedLastName",item)
}

}

最佳答案

由于 GORM/hibernate 标准的执行方式,这是行不通的。这些订单指令被转换为 SQL,并且只能对非 transient 字段进行操作,因为它发生在数据库层。

您的选择是:

  1. 将查询结果加载到内存中,并使用未加密的值自行进行排序和分页。
  2. 使用数据库的加密功能和自定义查询(例如“通过 AES_DECRYPT(lastName, key) 从员工订单中选择 *”)。请注意,这会给您的数据库带来大量额外负载。
  3. 以未加密的形式存储可用于排序的内容。示例:姓氏的前几个字母。但是,这会泄露您试图确保安全的一些信息。

关于hibernate - 使用 transient 字段在 grails 中查询和排序数据库结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2433916/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com