资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

php插入数据错误,php连接数据库失败怎么办

php显示数据库插入错误额

在phpadmin 里插入 以下语句 看看报不报错。看是不是引号报错

创新互联建站主营石峰网站建设的网络公司,主营网站建设方案,app软件开发,石峰h5微信小程序定制开发搭建,石峰网站营销推广欢迎石峰等地区企业咨询

insert into user(username,pwd,email) values(111,222,333)

php脚本连接mysql数据库成功了,但插入数据总是出错怎么办

检查你的mysql表设置的字段,字段类型,是否为空等是否与你插入的数据类型信息相符,如果插入失败,数据库应该会报错,你仔细查看一下报错信息。

php插入数据到MYSQL中出错,怎么正确插入

① 首先把MySQL的服务停掉 在运行窗口输入:net stop mysql

② 把服务器和客户端的字符集改成自己想用的字符集:GB2312或是utf8等……

具体操作为:打开mysql安装目录下的myini.tet;

找到default-character-set,将其改为自己想用的字符集:GB2312或是utf8等……,要注意的是这里有两个default-character-set,用ctrl+f定位在文件最前面输入default就会找到,都要改过来;

③ 重启MySQL服务器,在运行窗口输入:net start mysql

④ 最重要的是一点是,到这里我们已经能够解决乱码问题了,可问题是我们依然还会出现乱码问题,这是因为我们现在的表被创建的时候用的是默认的字符集(latin1),所以这时候我们要把表删除,然后重建就可以了

php为什么在表单中插入数据会失败

$sql = "INSERT INTO t_user (f_username, f_password, f_name,f_email)VALUES()";

$sql = "('$username ','$pwd ','$name ','$email ')";

这一部分错了吧。应该是这样、

$sql = "INSERT INTO t_user (f_username, f_password, f_name,f_email)VALUES";

$sql. = "('$username ','$pwd ','$name ','$email ')";

第二个sql是$sql.不要忘记后面还有一个点,表示和上面的sql语句链接起来,因为你下面是和上面链接起来的,所以第一个$sql后面values后面就不用加()括号了。

phpadmin 插入数据报错

这么简单啊?看来分是我的了。

按我下面写好的代码再试下。保你成功。

?php

$conn=mysql_connect("localhost","root","tianyu");

mysql_select_db("userman");

if($conn-query("insert into users values('tianyu',111111,'yun')"))

{

echo("true");

}

?

我找到你的代码里有两处错误:

一:是你的$conn=mysqli_connect连数据库那里多了个i,应该为:mysql_connect();

二:是你的值给错了。varchar类型的也就是汉字入库时必须在引号里面。而int类型字段也就是数字入库时不用加引号。

三:就是给分了。

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插入数据错误,php连接数据库失败怎么办
网页地址:http://cdkjz.cn/article/hsopih.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220