- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为这项工作做一个小申请,它包括一个表格。当使用表单的人没有在数据类型“数字”(比如 PIN 码)中输入值,甚至没有在我的“日期”数据类型字段之一(比如他的周年纪念日)中输入日期时,它会返回我错误如下:
Error Type – Type d'erreur _Microsoft OLE DB Provider for ODBC Drivers (0x80004005)_ ERROR: invalid input syntax for type numeric: ""; Error while executing the query
Error Type – Type d'erreur _Microsoft OLE DB Provider for ODBC Drivers (0x80004005)_ ERROR: syntax error at or near ")"; Error while executing the query
所以看起来当使用表单的人什么都不输入时,它返回字符串“空”即“”。为什么数字类型和数据类型不能将其读取为 NULL 条目?这些字段不是强制性的,因此有时我需要将它们留空。
我怎样才能让它成为可能?他们是继续使用“数字”和“日期”类型的一种方式,以便当用户在这些字段中不输入任何内容时,表格会填满空白,而不是给我这个错误吗?
这是我的sql语句:
trsConn.EXECUTE "INSERT INTO ""TRS"".employeetbl ( "& _
"""firstName"", " & _
"""lastName"" , " & _
"""detContract"", " & _
"sle, " & _
"""posNumber"" "& _
") VALUES (" & _
"'" & Request.Form("empFirst") & "', " & _**
"'" & Replace(Request.Form("empLast"), "'", "`") & "', " & _
"'" & Request.Form("dateContract") & "', " & _
"'" & Request.Form("sle") & "', " & _
"'" & Request.Form("posNum") & "');"
(posNum和dateContract分别是“numeric”和“date”类型
非常感谢您的帮助。期待听到你们这些天才所说的话。
最佳答案
The concept of NULL in SQL is pretty muddled and inconsistent ...但是很明显 ''
与 NULL
不同。
''
不是 NULL
,它是 ''
,空字符串。您不能将其转换为日期、数字等:
regress=# SELECT CAST('' AS DATE);
ERROR: invalid input syntax for type date: ""
LINE 1: SELECT CAST('' AS DATE);
^
regress=# SELECT CAST('' AS NUMERIC);
ERROR: invalid input syntax for type numeric: ""
LINE 1: SELECT CAST('' AS NUMERIC);
^
一些产品——特别是 Microsoft Access 和旧版本的 MySQL——对这个问题感到困惑。 NULL
为NULL,''
为空串;他们不是一回事。您不能将一个转换为另一个。
So it seems that when the person using the form enters nothing, it returns the string "empty" that is "". Why can't the numeric type and data type read that as a NULL entry? These fields are not mandatory and so I need to have them be sometimes blank.
那是您的应用程序的工作。当您的应用发现空字符串出现在数字、日期或类似的表单字段中时,它应该将 NULL
发送到数据库,而不是 ''
。这通常是在将数据提供给数据库之前从用户输入转换数据的例行部分。您进行此类转换是至关重要的;您永远不应该直接将用户的值直接发送到数据库。
快速搜索表明 asp classic 使用 null
或 undefined
作为它的 null 值;当某些内容为空时,您应该能够将它们传递到准备好的语句中。
在关于 ''
的错误之后出现语法错误的事实表明您将 SQL 语句构建为字符串,而不是使用 prepared statements with placeholders . (感谢 JayC 的 SO 问题引用)。这是求SQL injection ;换句话说,您的应用程序极度不安全。想象一下如果用户输入“日期”会发生什么:
2012-01-01'); DROP SCHEMA public;--
然后您的应用很乐意将其变成
INSERT INTO sometable (blah, blah, blah) VALUES (1, 2, DATE '2012-01-01'); DROP SCHEMA public;--');
DROP SCHEMA
然后愉快地执行,哇哦,砰的一声,你的数据库就在那里。这也是最愚蠢、最简单的一种 SQL 注入(inject)攻击。
关于postgresql - 为什么我不能在 Postgresql 中使用数字或日期类型输入 NULL 值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11944899/
我正在尝试编写一个相当多态的库。我遇到了一种更容易表现出来却很难说出来的情况。它看起来有点像这样: {-# LANGUAGE ScopedTypeVariables #-} {-# LANGUAGE
谁能解释一下这个表达式是如何工作的? type = type || 'any'; 这是否意味着如果类型未定义则使用“任意”? 最佳答案 如果 type 为“falsy”(即 false,或 undef
我有一个界面,在IAnimal.fs中, namespace Kingdom type IAnimal = abstract member Eat : Food -> unit 以及另一个成功
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: What is the difference between (type)value and type(va
在 C# 中,default(Nullable) 之间有区别吗? (或 default(long?) )和 default(long) ? Long只是一个例子,它可以是任何其他struct类型。 最
假设我有一个案例类: case class Foo(num: Int, str: String, bool: Boolean) 现在我还有一个简单的包装器: sealed trait Wrapper[
这个问题在这里已经有了答案: Create C# delegate type with ref parameter at runtime (1 个回答) 关闭 2 年前。 为了即时创建委托(dele
我正在尝试获取图像的 dct。一开始我遇到了错误 The function/feature is not implemented (Odd-size DCT's are not implemented
我正在尝试使用 AFNetworking 的 AFPropertyListRequestOperation,但是当我尝试下载它时,出现错误 预期的内容类型{( “应用程序/x-plist” )}, 得
我在下面收到错误。我知道这段代码的意思,但我不知道界面应该是什么样子: Element implicitly has an 'any' type because index expression is
我尝试将 SignalType 从 ReactiveCocoa 扩展为自定义 ErrorType,代码如下所示 enum MyError: ErrorType { // .. cases }
我无法在任何其他问题中找到答案。假设我有一个抽象父类(super class) Abstract0,它有两个子类 Concrete1 和 Concrete1。我希望能够在 Abstract0 中定义类
我想知道为什么这个索引没有用在 RANGE 类型中,而是用在 INDEX 中: 索引: CREATE INDEX myindex ON orders(order_date); 查询: EXPLAIN
我正在使用 RxJava,现在我尝试通过提供 lambda 来订阅可观察对象: observableProvider.stringForKey(CURRENT_DELETED_ID) .sub
我已经尝试了几乎所有解决问题的方法,其中包括。为 提供类型使用app.use(express.static('public'))还有更多,但我似乎无法为此找到解决方案。 index.js : imp
以下哪个 CSS 选择器更快? input[type="submit"] { /* styles */ } 或 [type="submit"] { /* styles */ } 只是好
我不知道这个设置有什么问题,我在 IDEA 中获得了所有注释(@Controller、@Repository、@Service),它在行号左侧显示 bean,然后转到该 bean。 这是错误: 14-
我听从了建议 registering java function as a callback in C function并且可以使用“简单”类型(例如整数和字符串)进行回调,例如: jstring j
有一些 java 类,加载到 Oracle 数据库(版本 11g)和 pl/sql 函数包装器: create or replace function getDataFromJava( in_uLis
我已经从 David Walsh 的 css 动画回调中获取代码并将其修改为 TypeScript。但是,我收到一个错误,我不知道为什么: interface IBrowserPrefix { [
我是一名优秀的程序员,十分优秀!