Below are examples of three different encryption methods to encrypt data inserted into a MySQL database table.
A test table is created where field1 will store data in plain text and field2 will store encrypted data.
CREATE TABLE encrypt_test
(field1 varchar(255) null,
field2 varchar(255));
SHA1 Example
INSERT INTO encrypt_test(field1,field2) VALUES ('dd',SHA1('yoda'));
SELECT * FROM encrypt_test WHERE field2=SHA1('yoda');
data:image/s3,"s3://crabby-images/20a0f/20a0fd09bf470b941e1480a0f5336e61ad00a698" alt=""
SHA2
INSERT INTO encrypt_test(field1,field2) VALUES ('a',sha2('password',224));
SELECT * FROM encrypt_test WHERE field2 = sha3('password',224));
data:image/s3,"s3://crabby-images/7078c/7078c2690724c9dfcdfe99411760b631eaadf30e" alt=""
SELECT * FROM encrypt_test WHERE field2 = sha2('password',224));
data:image/s3,"s3://crabby-images/9bdf1/9bdf1ccd2434296ab1d81c15444af77bb31f1d94" alt=""
AES_ENCRYPT
CREATE TABLE demodb
(value blob);
INSERT INTO demodb (demo) VALUES (AES_ENCRYPT('test to encrypt','PasswordKey'));
SELECT CAST(AES_DECRYPT(value,'PasswordKey') as CHAR) FROM demodb;
data:image/s3,"s3://crabby-images/97a6e/97a6ee2aa9826508901ff0f2d4f46f751969c486" alt=""
SELECT CAST(AES_DECRYPT(value,'PasswordKey') as CHAR) = 'test to encrypt' FROM demodb;
data:image/s3,"s3://crabby-images/ea0e8/ea0e866ceea567e96926898a0ee3c70d95f90e3d" alt=""