PHP怎么在mysql insert into语句中实现md5加密

if ($_POST["submit"]) { $sql="insert into reguser (username,password,sex,email,name,idcard,address,phone,qq,regtime)". " values ('$_POST[username]','md5($_POST[password])','$_POST[sex]','$_POST[email]','$_POST[name]','$_POST[idcard]','$_POST[address]','$_POST[phone]','$_POST[qq]',now())";

第1个回答  2012-05-04
if ($_POST["submit"]) { $sql="insert into reguser (username,password,sex,email,name,idcard,address,phone,qq,regtime)". " values ('$_POST[username]','".md5($_POST[password])."','$_POST[sex]','$_POST[email]','$_POST[name]','$_POST[idcard]','$_POST[address]','$_POST[phone]','$_POST[qq]',now())";本回答被提问者采纳
第2个回答  2012-05-06
MYSQL本身自带大量处理函数,包括字符串,日期,正则,等,当然也有MD5,你可以使用触发器自动完成,如果想深入学习MYSQL,建议看国内最好的MYSQL视频教程,在后盾网
第3个回答  2020-07-06

加锁情况与死锁原因分析

为方便大家复现,完整表结构和数据如下:

CREATE TABLE `t3` (
`c1` int(11) NOT NULL AUTO_INCREMENT,
`c2` int(11) DEFAULT NULL,
PRIMARY KEY (`c1`),
UNIQUE KEY `c2` (`c2`)
) ENGINE=InnoDB

insert into t3 values(1,1),(15,15),(20,20);


在 session1 执行 commit 的瞬间,我们会看到 session2、session3 的其中一个报死锁。这个死锁是这样产生的:

    1. session1 执行 delete  会在唯一索引 c2 的 c2 = 15 这一记录上加 X lock(也就是在MySQL 内部观测到的:X Lock but not gap);

    2. session2 和 session3 在执行 insert 的时候,由于唯一约束检测发生唯一冲突,会加 S Next-Key Lock,即对 (1,15] 这个区间加锁包括间隙,并且被 seesion1 的 X Lock 阻塞,进入等待;

    3. session1 在执行 commit 后,会释放 X Lock,session2 和 session3 都获得 S Next-Key Lock;

    4. session2 和 session3 继续执行插入操作,这个时候 INSERT INTENTION LOCK(插入意向锁)出现了,并且由于插入意向锁会被 gap 锁阻塞,所以 session2 和 session3 互相等待,造成死锁。

    死锁日志如下: 

    INSERT INTENTION LOCK

    在之前的死锁分析第四点,如果不分析插入意向锁,也是会造成死锁的,因为插入最终还是要对记录加 X Lock 的,session2 和 session3 还是会互相阻塞互相等待。

    但是插入意向锁是客观存在的,我们可以在官方手册中查到,不可忽略:

    Prior to inserting the row, a type of gap lock called an insert intention gap lock is set. This lock signals the intent to insert in such a way that multiple transactions inserting into the same index gap need not wait for each other if they are not inserting at the same position within the gap.

    插入意向锁其实是一种特殊的 gap lock,但是它不会阻塞其他锁。假设存在值为 4 和 7 的索引记录,尝试插入值 5 和 6 的两个事务在获取插入行上的排它锁之前使用插入意向锁锁定间隙,即在(4,7)上加 gap lock,但是这两个事务不会互相冲突等待。

    当插入一条记录时,会去检查当前插入位置的下一条记录上是否存在锁对象,如果下一条记录上存在锁对象,就需要判断该锁对象是否锁住了 gap。如果 gap 被锁住了,则插入意向锁与之冲突,进入等待状态(插入意向锁之间并不互斥)。总结一下这把锁的属性:

    1. 它不会阻塞其他任何锁;

    2. 它本身仅会被 gap lock 阻塞。

    在学习 MySQL 过程中,一般只有在它被阻塞的时候才能观察到,所以这也是它常常被忽略的原因吧...

    GAP LOCK

    在此例中,另外一个重要的点就是 gap lock,通常情况下我们说到 gap lock 都只会联想到 REPEATABLE-READ 隔离级别利用其解决幻读。但实际上在 READ-COMMITTED 隔离级别,也会存在 gap lock ,只发生在:唯一约束检查到有唯一冲突的时候,会加 S Next-key Lock,即对记录以及与和上一条记录之间的间隙加共享锁。

    通过下面这个例子就能验证:

    这里 session1 插入数据遇到唯一冲突,虽然报错,但是对 (15,20] 加的 S Next-Key Lock 并不会马上释放,所以 session2 被阻塞。另外一种情况就是本文开始的例子,当 session2 插入遇到唯一冲突但是因为被 X Lock 阻塞,并不会立刻报错 “Duplicate key”,但是依然要等待获取 S Next-Key Lock 。

    有个困惑很久的疑问:出现唯一冲突需要加 S Next-Key Lock 是事实,但是加锁的意义是什么?还是说是通过 S Next-Key Lock 来实现的唯一约束检查,但是这样意味着在插入没有遇到唯一冲突的时候,这个锁会立刻释放,这不符合二阶段锁原则。这点希望能与大家一起讨论得到好的解释。

    如果是在 REPEATABLE-READ,除以上所说的唯一约束冲突外,gap lock 的存在是这样的:

    普通索引(非唯一索引)的S/X Lock,都带 gap 属性,会锁住记录以及前1条记录到后1条记录的左闭右开区间,比如有[4,6,8]记录,delete 6,则会锁住[4,8)整个区间。

    对于 gap lock,相信 DBA 们的心情是一样一样的,所以我的建议是:

    1. 在绝大部分的业务场景下,都可以把 MySQL 的隔离界别设置为 READ-COMMITTED;

    2. 在业务方便控制字段值唯一的情况下,尽量减少表中唯一索引的数量。

    锁冲突矩阵

    前面我们说的 GAP LOCK 其实是锁的属性,另外我们知道 InnoDB 常规锁模式有:S 和 X,即共享锁和排他锁。锁模式和锁属性是可以随意组合的,组合之后的冲突矩阵如下,这对我们分析死锁很有帮助。

PHP怎么在mysql insert into语句中实现md5加密
if ($_POST["submit"]) { $sql="insert into reguser (username,password,sex,email,name,idcard,address,phone,qq,regtime)". " values ('$_POST[username]','".md5($_POST[password])."','$_POST[sex]','$_POST[email]','$_POST[name]','$_POST[idcard]...

MySQL中MD5加密的使用方法mysql中md5写法
在MySQL中,可以通过UPDATE语句的SET子句来更新表中的数据。下面是一个使用MD5函数加密数据库字段的示例:mysql> UPDATE users SET password=MD5(‘123456’) WHERE id=1;这个示例中,我们将users表中id为1的用户密码字段加密为MD5加密后的值’5d41402abc4b2a76b9719d911017c592R...

如何在mysql数据库中加入加密算法,使得数据库能够对数据库中的数据进行...
没有用过mysql加密,但一般都是用服务端语言把数据加密后存入数据库中,比如,在PHP里用md5函数把用户的密码加密之后存入数据中,一般都 是这么解决的。

mysql插入内容实现MD5加密,这样怎么不行啊
假设你的 $_POST[password] = "asd";sql = "... 'md5($_POST[password])' .."; 输出的肯定是 ... 'md5(asd)' ...""双引号内只处理$变量 改成这样就可以了 sql = "... '".md5($_POST['password]')."' ..";^ ^ 双引号结束 + .连接 双引号结束 + .连接 ...

mysql 在插入数据时,怎么样做到自动生成16位唯一的ID?
使用触发器 在一条insert语句触发时,使用SELECT md5(RAND() + new.id);可以生成32位唯一的ID。修改就行了

php注册页面 密码用MD5加密后无法插入数据库 不加密可以正常
你可以接受的时候不用md5加密,执行sql语句时在加密:sql="insert into table (`username`,`password`,`email`,`date`) values('".$user."','".md5($pw)."','".$em."','".$date."')";另外,给你提一个小小的建议,就是字段名最好用反引号括起来,避免和数据库中的关键字冲突,然后...

MySQL中加密函数学习--MySql语法
使用 AES 函数加密数据的示例为:INSERT INTO t VALUES (1,AES_ENCRYPT('text','password'));。AES_ENCRYPT() 和 AES_DECRYPT() 被视为 MySQL 中用于数据加密最安全的通用函数。使用 pass_str 作为密码,可解密加密字符串 crypt_str,即 crypt_str 应为 ENCODE() 返回的字符串。使用 pass_str...

找回MD5加密的密码及MD5加密数据库中数据
如果数据库中存储的是小写,需要再用lower函数转换一下。我们还可以使用存储过程来实现MD5加密:declare v_string varchar2(50);v_n number;begin v_string := utl_raw.cast_to_raw(sys.dbms_obfuscation_toolkit.md5(input_string = '123456'));v_n := length(v_string);dbms_output.put_line...

怎么做注册页面让用户输入的密码,写入数据库后变成加密的码?_百度知 ...
2.<?php user=$_POST['username'];pwd=md5($_POST['password']);\/\/加密用户密码 mysql_connect('localhost','root','');\/\/连接数据库 mysql_select_db('db');\/\/选择数据库 sql="insert into table values(".$user.",".$pwd.")";\/\/sql语句 mysql_query($sql);\/\/发送sql 大概就是...

...password的这一列全部使用md5加密,不知道怎么实现。
一般安全一点的做法是 1给user 表加一个字段PMD5;2 UPDATE USER SET pmd5=md5(password) \/\/用MD5值来更新;3 删除原来的password字段;4 pmd5 字段改名为password字段;完成.

相似回答