如何解决当使用PHP和mysql在用户输入中提供默认值和null str时,如何使用统一的sql进行插入
这里我有一个像这样的mysql表:create table abc (
name varchar(20) not null,value int not null default 20
)
在php页面中,我想对所有这样的插入使用统一的sql:
insert into abc values(\'first name\',\'30\')
但有时,可能有人不输入值,插入sql就像
insert into abc values(\'a name\',\'\')
为什么它不起作用? mysql说Incorrect integer value: \'\' for column...
和
我希望它提供默认值。我怎样才能做到这一点?
解决方法
如果您已将非整数值声明为带有
NOT NULL
的整数,则不能在字段中插入非整数值。
1)如果要在两种情况下都使用相同的INSERT
语句,则可以通过代码控制值...
$var = 30;
$SQL = \"INSERT INTO abc () VALUES(\'first name\',\'\".$var.\"\')\";
2)...或者您的默认值有两个不同的INSERT
:
/* for the default value */
$SQL = \"INSERT INTO abc (somefield) VALUES(\'first name\')\";
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。