MySQL中二進制類型是一種非常有用的數據類型,它可以存儲任何形式的二進制數據,包括圖像、音頻、視頻等。
CREATE TABLE users ( id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(50), avatar LONGBLOB );
在上面的示例中,我們創建了一個名為users的表,其中包含id、name和avatar列。其中,avatar列使用了二進制類型,用于存儲用戶頭像。
INSERT INTO users (name, avatar) VALUES ('John Doe', LOAD_FILE('/path/to/avatar.jpg'));
在上面的示例中,我們將一個名為avatar.jpg的文件加載到二進制類型的avatar列中。這個過程使用了MySQL內置函數LOAD_FILE。
SELECT avatar FROM users WHERE id = 1;
在上面的示例中,我們從users表中選擇id為1的用戶的頭像。由于頭像存儲在avatar列中,我們可以使用SELECT語句來檢索它。
二進制類型的另一個常見用途是存儲加密數據。例如,我們可以使用AES加密算法將數據存儲為二進制類型,并在需要時對它進行解密。
CREATE TABLE secret_data ( id INT AUTO_INCREMENT PRIMARY KEY, data VARBINARY(200) NOT NULL );
在上面的示例中,我們創建了一個名為secret_data的表,其中包含id和data列。其中,data列使用了VARBINARY類型,用于存儲加密數據。
INSERT INTO secret_data (data) VALUES (AES_ENCRYPT('Hello, world!', 'secret_key'));
在上面的示例中,我們將一個字符串“Hello, world!”加密,并將結果存儲在data列中。
SELECT AES_DECRYPT(data, 'secret_key') AS decrypted_data FROM secret_data WHERE id = 1;
在上面的示例中,我們從secret_data表中選擇id為1的數據,并使用AES_DECRYPT函數將其解密。解密后的數據存儲在名為decrypted_data的列中。
上一篇微信彈窗 css