MYSQL密码加密函数的实际用途

本文介绍了在MySQL中如何使用内置函数对密码进行加密存储的方法。包括PASSWORD(), ENCRYPT(), MD5(), SHA5()等函数的使用场景及注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

点击这里使用RSS订阅本Blog: rel="alternate" href="http://feed.feedsky.com/softwave" type="application/rss+xml" title="RSS 2.0" />

在新增一条数据库记录时,有时候密码需要加密存储,此时我们采用MYSQL自带的加密算法
PASSWORD("YourPassword")经过此函数后就可以将密码加密后存储在数据库.
在修改密码时同样会用到这样的函数.
先将新输入的密码字符串,经过此函数加密码后,再与从数据库取出的密码作比较,这样才能保证相匹配,否则永远也不可能相等.
为新输入的字符串加密 select Password("YourPassowrd");用一人虚表进行此函数.
下面是一些相关的介绍
PASSWORD():创建一个经过加密的密码字符串,适合于插入到MySQL的安全系
统。该加密过程不可逆,和unix密码加密过程使用不同的算法。主要用于MySQL的认证系统。
ENCRYPT(,):使用UNIX crypt()系统加密字符串,ENCRYPT()函数接收要加密的字符串和(可选的)用于加密过程的salt(一个可以唯一确定口令的字符串,就像钥匙一样),注意,windows上不支持
ENCODE(,) DECODE(,):加密解密字符串。该函数有两个参数:被加密或解密的字符串和作为加密或解密基础的密钥。Encode结果是一个二进制字符串,以BLOB类型存储。加密成都相对比较弱
MD5():计算字符串的MD5校验和(128位)
SHA5():计算字符串的SHA5校验和(160位)
以上两个函数返回的校验和是16进制的,适合与认证系统中使用的口令。
Eg:SELECT * FROM USERS WHERE NAME=’JOHN’ AND PASSWORD=MD5(‘MYPASS’); <script type="text/javascript" src="http://www.google.com/reader/ui/publis<script type="text/javascript" src="http://www.google.com/reader/public/javascript/user/00697638153916680411/state/com.google/broadcast?n=5&callback=grc_p(%7bc%3a%22green%22%2ct%3a%22%5cu8fd9%5cu4e9b%5cu6587%5cu7ae0%5cu4e5f%5cu503c%5cu5f97%5cu4e00%5cu770b%22%2cs%3a%22false%22%7d)%3bnew%20grc"></script>se%22%7D)%3Bnew%20GRC">

### MySQL 常用内置函数汇总 #### 数学运算函数 MySQL 提供了一系列用于数学运算的函数,例如 `ABS()`、`CEIL()` 和 `FLOOR()` 等。这些函数可以帮助开发者轻松完成各种数值计算任务[^1]。 - **ABS(x)**:返回参数 x 的绝对值。 - **CEIL(x)** 或者 **CEILING(x)**:返回大于等于 x 的最小整数。 - **FLOOR(x)**:返回小于等于 x 的最大整数。 ```sql SELECT ABS(-5); -- 输出 5 SELECT CEIL(3.14); -- 输出 4 SELECT FLOOR(3.98); -- 输出 3 ``` #### 字符串处理函数 字符串处理是数据库操作中的重要部分,MySQL 支持多种字符串函数以便于数据管理和分析。 - **CONCAT(str1, str2,...)**:连接多个字符串并返回结果。 - **LOWER(str)** / **LCASE(str)**:将字符串转换成小写形式。 - **UPPER(str)** / **UCASE(str)**:将字符串转换成大写形式。 ```sql SELECT CONCAT('Hello', ' ', 'World'); -- 输出 Hello World SELECT LOWER('HELLO WORLD'); -- 输出 hello world SELECT UPPER('hello world'); -- 输出 HELLO WORLD ``` #### 时间和日期函数 时间和日期的操作在实际应用中非常频繁,因此 MySQL 设计了许多专门针对时间戳管理的功能性函数[^4]。 - **NOW()**:获取当前系统日期和时间。 - **CURDATE()**:仅返回今天的日期部分。 - **CURTIME()**:只显示现在的时间部分。 - **DATE_SUB(date, INTERVAL expr unit)**:从指定日期减去一定时间段后的结果。 ```sql SELECT NOW(); -- 当前时刻 SELECT CURDATE(); -- 只有日期 SELECT DATE_SUB(CURDATE(), INTERVAL 7 DAY); -- 计算一周之前的日期 ``` #### 杂项功能函数 除了上述类别外还有一些其他用途广泛的工具型方法值得了解: - **PASSWORD(str)**:生成哈希值以保护敏感字段比如密码存储安全[^2]。 - **BENCHMARK(count,expr)**:测试表达式性能评估其运行效率[^3]。 ```sql -- 创建加密版本的输入字符串 SELECT PASSWORD('test'); -- 测量某个简单查询耗时情况 SELECT BENCHMARK(1000000, MD5(RAND())); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值