- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 2 个日期时间选择器,允许用户选择开始日期和结束日期。所以在选择日期之后,用户必须点击一个按钮来运行 sql 查询。因此根据所选日期过滤输出。
但是当我如下声明日期时出现错误(下面的代码放在按钮点击事件下):
Dim startdate As DateTime = Format(DateTimePicker1.Value, "dd/MM/yyyy")
Dim enddate As DateTime = Format(Microsoft.VisualBasic.DateAdd(DateInterval.Day, 1, DateTimePicker2.Value), "dd/MM/yyyy")
query = "Select * from records where recorddate between '" & startdate & "' and '" & enddate & "'"
错误在这里:
Dim startdate As DateTime = Format(DateTimePicker1.Value, "dd/MM/yyyy")
错误是:
Conversion from string "13/02/2016" to type 'Date' is not valid.
我记录的样本日期是这样的:
12/2/2016 7:28:26 PM
我不知道我在这里错过了什么。请帮忙。谢谢
最佳答案
您的代码中存在多个问题。
Dim startdate As DateTime = Format(DateTimePicker1.Value, "dd/MM/yyyy")
如果您将鼠标悬停在 Format
上,Intellisense 会告诉您它返回一个字符串。由于无法将字符串结果分配给声明为 DateTime
的变量,因此会出现错误。如果你打开 Option Strict
,编译器会告诉你这些。
其次,查询还将日期转换为字符串:
"...between '" & startdate & "' and '" & enddate & "'"
标记不是通用的 SQL 分隔符,它们是一种指定文本/字符串数据的方式。 SQL 参数更安全,可以防止意外的数据类型更改以及 SQL injection attacks .它们还使代码更易于阅读。如果您的数据库中有名称列,请尝试插入一个名称,例如 Tim O'Brien
、D'Angelo Barksdale
或 Betty's Cupcake Factory
.查询将崩溃。 SQL 参数可以防止这种情况。
我不知道是哪个数据库,所以我猜是 Access。这无关紧要,因为 DB Provider 的工作方式大同小异:
' Dim startdate As DateTime = DateTimePicker1.Value
Dim enddate As DateTime = DateTimePicker2.Value.AddDays(1)
Dim SQL = "Select * from records where recorddate between @p1 AND @p2"
Using dbCon As New OleDbConnection(connstr)
Using cmd As New OleDbCommand(SQL, dbCon)
dbCon.Open()
cmd.Parameters.Add("@p1", OleDbType.DBDate).Value = startdate
cmd.Parameters.Add("@p2", OleDbType.DBDate).Value = DateTimePicker1.Value
dt = New DataTable
dt.Load(cmd.ExecuteReader)
End Using
End Using
注意 这假定数据库中的列类型是日期而不是字符串。 BETWEEN
子句不太可能将日期用作字符串。如果您希望它们充当日期,请将它们保存为 Date
。您不需要“为了在 SQL 中使用它而需要转换为字符串”。曾经。
DateTime
类型传递给数据库。DateTimePicker1.Value
分配给新变量,因为 .Value
是 DateTime
类型。Using
block 声明并创建 DB 对象,然后关闭并释放它们以释放资源OleDbType.DBDate
),然后 Value 集是一个实际的日期类型。对于 Access/OleDB,重要的是按照它们在 SQL 中出现的完全相同的顺序设置参数值。 OleDB
允许命名参数,但会按照它们在 SQL 中出现的顺序分配值。
要强调的是,MSDN(和其他人)鼓励使用 ?
代替其他形式("@p1"
、"@firstname"
,“@DateOfBirth”
)。尤其是在包含多个列的查询中,我喜欢 "@p1"
,因为数字有助于索引 SQL 中的相关列并有助于确保它们是有序的(视觉上)。
最后,您的 BETWEEN 子句是否按您希望的方式工作将取决于几个因素,包括该 DataType 参数。 DateTimePicker
中的日期将包括时间。为了不排除某些行,因为时间部分早于您从 DateTimePicker
获得的任何内容,您需要使用正确的行。
关于.net - 从字符串到类型 'Date' 的转换无效,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35377152/
如何使用 SPListCollection.Add(String, String, String, String, Int32, String, SPListTemplate.QuickLaunchO
我刚刚开始使用 C++ 并且对 C# 有一些经验,所以我有一些一般的编程经验。然而,似乎我马上就被击落了。我试过在谷歌上寻找,以免浪费任何人的时间,但没有结果。 int main(int argc,
这个问题已经有答案了: In Java 8 how do I transform a Map to another Map using a lambda? (8 个回答) Convert a Map>
我正在使用 node + typescript 和集成的 swagger 进行 API 调用。我 Swagger 提出以下要求 http://localhost:3033/employees/sear
我是 C++ 容器模板的新手。我收集了一些记录。每条记录都有一个唯一的名称,以及一个字段/值对列表。将按名称访问记录。字段/值对的顺序很重要。因此我设计如下: typedef string
我需要这两种方法,但j2me没有,我找到了一个replaceall();但这是 replaceall(string,string,string); 第二个方法是SringBuffer但在j2me中它没
If string is an alias of String in the .net framework为什么会发生这种情况,我应该如何解释它: type JustAString = string
我有两个列表(或字符串):一个大,另一个小。 我想检查较大的(A)是否包含小的(B)。 我的期望如下: 案例 1. B 是 A 的子集 A = [1,2,3] B = [1,2] contains(A
我有一个似乎无法解决的小问题。 这里...我有一个像这样创建的输入... var input = $(''); 如果我这样做......一切都很好 $(this).append(input); 如果我
我有以下代码片段 string[] lines = objects.Split(new string[] { "\r\n", "\n" }, StringSplitOptions.No
这可能真的很简单,但我已经坚持了一段时间了。 我正在尝试输出一个字符串,然后输出一个带有两位小数的 double ,后跟另一个字符串,这是我的代码。 System.out.printf("成本:%.2
以下是 Cloud Firestore 列表查询中的示例之一 citiesRef.where("state", ">=", "CA").where("state", "= 字符串,我们在Stack O
我正在尝试检查一个字符串是否包含在另一个字符串中。后面的代码非常简单。我怎样才能在 jquery 中做到这一点? function deleteRow(locName, locID) { if
这个问题在这里已经有了答案: How to implement big int in C++ (14 个答案) 关闭 9 年前。 我有 2 个字符串,都只包含数字。这些数字大于 uint64_t 的
我有一个带有自定义转换器的 Dozer 映射: com.xyz.Customer com.xyz.CustomerDAO customerName
这个问题在这里已经有了答案: How do I compare strings in Java? (23 个回答) 关闭 6 年前。 我想了解字符串池的工作原理以及一个字符串等于另一个字符串的规则是
我已阅读 this问题和其他一些问题。但它们与我的问题有些无关 对于 UILabel 如果你不指定 ? 或 ! 你会得到这样的错误: @IBOutlet property has non-option
这两种方法中哪一种在理论上更快,为什么? (指向字符串的指针必须是常量。) destination[count] 和 *destination++ 之间的确切区别是什么? destination[co
This question already has answers here: Closed 11 years ago. Possible Duplicates: Is String.Format a
我有一个Stream一个文件的,现在我想将相同的单词组合成 Map这很重要,这个词在 Stream 中出现的频率. 我知道我必须使用 collect(Collectors.groupingBy(..)
我是一名优秀的程序员,十分优秀!