2

我使用libpqxx在 C++ 中连接到 PostgreSQL DB。我想加密一列表并将其替换为当前列。我写这个:

int num;
cout << "Select Your COLUMN Number For Encryption: ";
cin >> num;

/* Create SQL statement */            
sql = "SELECT * from " + tbName;

/* Execute SQL query */
result R3( N.exec( sql ));

/* List down all the records */
for (result::const_iterator c = R3.begin(); c != R3.end(); ++c) {
    c[num].as<string>() = encnum->encryptionData(3,5,c[num].as<int>());
    cout << "Encryption = " << c[num].as<string>() << endl;
}

但结果就像加密之前一样。我有什么问题,如何将值替换为列中的其他值?

4

1 回答 1

0

所以我对您的问题的理解是您有一列文本或二进制数据,并且您希望将该列中的所有行更新为表示文件当前内容的加密版本的密文。

有两种方法。

  1. 一次选择并更新一行。优点是您可以更轻松地管理事务大小。换句话说,在这种情况下,您一次更新一个值并在客户端进行加密。

  2. 您可以使用类似于pg_crypto标准扩展的东西来加密数据并使用单个更新查询来执行此操作。请注意,这可能需要更长时间的打开写入事务限制 autovacuum 可以清理的内容。还需要向查询提供密钥,因此您有可能在日志中披露密钥。

这些方法之间存在巨大的权衡。在 PostgreSQL 中,由于您在后端遇到的密钥泄露和管理问题,通常会完成客户端管理的加密。然而,存在其他方法。

于 2017-01-27T08:51:04.917 回答