当使用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\')\";
    

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...