本文目录一览:
php向mysql插入数据出错
mysql语句在执行insert,update时,对于非数字的值,必须加引号,比如
1update tablename set attrA='valueA'
1update tablename set attrA=valueA;
这样就会报错。对于数字的值,可以不加,加上也不会影响插入效果,比如
1update tablename set intAttrA = 1;
1update tablename set intAttrA = '1';
这两种都是可以的。
你这里报错的一行代码,假设输入的$_POST['username']
= 'a'; $_POST['pwd']
= 'b'; $_POST['content']
= 'c'; 在处理后,最后执行的是
INSERT
INTO
userinfo
(username,
pwd,
content)
VALUES
(a,
b,
c);
它的错误就是上面说的非数字类的值,没带引号。 但实际上,正确的语句应该是
INSERT
INTO
userinfo
(username,
pwd,
content)
VALUES
('a',
'b',
'c');
所以你测试的
$query = 'INSERT
INTO
userinfo
(username,
pwd,
content)
VALUES
("username",
"pwd",
"content")';
能正确执行。 最后问题的解决方法是:
$query = "INSERT INTO userinfo (username, pwd, content) VALUES ('".$_POST['username']."', '".$_POST['pwd']."', '".$_POST['content']."')";
另外,为了看起来舒服点,可以这么写:
$query = sprintf("INSERT INTO userinfo (username, pwd, content) VALUES ('%s', '%s', '%s');", $_POST['username'], $_POST['pwd'], $_POST['content']);
最后,你这种写法,有SQL注入的风险,从安全角度来讲是不可取的。所以应该这么写:
$query = sprintf("INSERT INTO userinfo (username, pwd, content) VALUES (unhex('%s'), unhex('%s'), unhex('%s'));", bin2hex($_POST['username']), bin2hex($_POST['pwd']), bin2hex($_POST['content']));
PHP插入mysql数据问题
这个报错的含义是输入的长度和MySQL设置的字段长度不符。如果直接执行能成功,那可以看看是不是编码的问题。
php插入数据到MYSQL中出错,怎么正确插入
① 首先把MySQL的服务停掉,在运行窗口输入:net stop mysql
② 把服务器和客户端的字符集改成自己想用的字符集:GB2312或是utf8等……
具体操作为:打开mysql安装目录下的my.ini
文件;
找到default-character-set
,将其改为自己想用的字符集:GB2312或是utf8等……,要注意的是这里有两个default-character-set
,用Ctrl+F
定位,在文件最前面输入default
就会找到,都要改过来;
③ 重启MySQL服务器,在运行窗口输入:net start mysql
④ 最重要的一点是,到这里我们已经能够解决乱码问题了,可问题是我们依然还会出现乱码问题,这是因为我们现在的表被创建的时候用的是默认的字符集(latin1),所以这时候我们要把表删除,然后重建就可以了。