Hi I would like to submit the following problem to the PostgreSQL community. In my company, we have data encryption needs.
(1)
Creating a table with a bytea type column to store the encrypted data
(2)
inserting encrypted data
(3)
Querying the table pgp_sym_decrypt ----------------- test value 32 (1 row) Time: 115735.035 ms (01:55.735)
(4)
Creating an index on encrypted data
(5)
Querying the table again
SELECT pgp_sym_decrypt(cc, 'motdepasse') FROM cartedecredit WHERE pgp_sym_decrypt(cc, 'motdepasse')='test value 32'; ----------------- test value 32 (1 row) Time: 118558.485 ms (01:58.558) ->
almost 2 minutes !! QUERY PLAN ---------------------------------------------------------------------------------------------------------------------- Seq Scan
on cartedecredit (cost=0.00..3647.25 rows=500 width=32) (actual time=60711.787..102920.509 rows=1 loops=1) Filter: (pgp_sym_decrypt(cc, 'motdepasse'::text) = 'test value 32'::text) Rows Removed by Filter: 99999 Planning time: 0.112 ms Execution time: 102920.585 ms (5 rows)
è
the index is not used in the execution plan. maybe because of the use of a function in the WHERE clause. I decide to modify the SQL query
(6)
Querying the table
----------------- (0 rows) Time: 52659.571 ms (00:52.660)
è
The execution time is very long and I get no result (!?) QUERY PLAN ------------------------------------------------------------------------------------------------------------------- Seq Scan
on cartedecredit (cost=0.00..3646.00 rows=1 width=32) (actual time=61219.989..61219.989 rows=0 loops=1) Filter: (cc = pgp_sym_encrypt('test value 32'::text, 'motdepasse'::text)) Rows Removed by Filter: 100000 Planning time: 0.157 ms Execution time: 61220.035 ms (5 rows)
è
My index is not used.
-
why the index is not used? Thanks in advance Best Regards
|
Ce message et toutes les pièces jointes (ci-après le 'Message') sont établis à l'intention exclusive des destinataires et les informations qui y figurent sont strictement confidentielles. Toute utilisation de ce Message non conforme à sa destination, toute diffusion ou toute publication totale ou partielle, est interdite sauf autorisation expresse.
Si vous n'êtes pas le destinataire de ce Message, il vous est interdit de le copier, de le faire suivre, de le divulguer ou d'en utiliser tout ou partie. Si vous avez reçu ce Message par erreur, merci de le supprimer de votre système, ainsi que toutes ses copies, et de n'en garder aucune trace sur quelque support que ce soit. Nous vous remercions également d'en avertir immédiatement l'expéditeur par retour du message.
Il est impossible de garantir que les communications par messagerie électronique arrivent en temps utile, sont sécurisées ou dénuées de toute erreur ou virus.
____________________________________________________
This message and any attachments (the 'Message') are intended solely for the addressees. The information contained in this Message is confidential. Any use of information contained in this Message not in accord with its purpose, any dissemination or disclosure, either whole or partial, is prohibited except formal approval.
If you are not the addressee, you may not copy, forward, disclose or use any part of it. If you have received this message in error, please delete it and all copies from your system and notify the sender immediately by return message.
E-mail communication cannot be guaranteed to be timely secure, error or virus-free.