您的位置:

php向mysql插入失败(php连接mysql失败)

本文目录一览:

PHP向mysql插入数据总是失败

你的conn.php是什么?也要贴出来,

首先确定数据库连接成功,成功之后,将你的sql语句在phpmyadmin中SQL测试,看看有没有SQL错误。

还有,$_POST[''],一般用单引号

sql语句明显错误,id字段要设置成自动增长,改成

$sql="insert

into

BKNV_VIDEOS(vid,type,title,image,date)

values('$vid','$type','$title','$image','$date')";

你试一试

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")';

能正确执行。

最后问题的解决方法是:

1234567$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里面执行一遍sql语句,看下能不能添加数据,先检查语句有没有问题,再看程序上的问题