- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 android ORMLite 的初学者,我有一个查询,它根据其“日期”字段值应在给定字符串日期之间的条件,使用其模型类从两个表中选择特定数据。下面是我的查询。
SimpleDateFormat sdf = new SimpleDateFormat("dd/MM/yyyy");
try{
int month = Calendar.getInstance().get(Calendar.MONTH) + 1;
int year = Calendar.getInstance().get(Calendar.YEAR);
String startDate="",endDate="";
startDate=1+"/"+month+"/"+year;
endDate =31+"/"+month+"/"+year;
String[] resultArray;
if(parid==4){
GenericRawResults<String[]> valueResult=dbHelper.getTransDetDao().queryRaw(
"SELECT T.amount FROM TransactionDetails T,TransactionHeaders H "
+ "WHERE H.id=T.transaction_id AND T.account_id=" + id
+ " AND H.date BETWEEN " + startDate + " AND " + endDate);
List<String[]> results = valueResult.getResults();
}
}catch(Exception es){
es.printStackTrace();
}
但其结果SQLException如下。
07-29 11:38:10.653: I/Database(627): sqlite returned: error code = 1, msg = near "Jul": syntax error
07-29 11:38:10.653: W/System.err(627): java.sql.SQLException: Could not perform raw query for select T.amount from TransactionDetails T,TransactionHeaders H where H.id=T.transaction_id AND T.account_id==109 AND H.date BETWEEN Wed Jul 01 00:00:00 GMT+05:30 2015 AND Fri Jul 31 00:00:00 GMT+05:30 2015
07-29 11:38:10.673: W/System.err(627): at com.j256.ormlite.misc.SqlExceptionUtil.create(SqlExceptionUtil.java:22)
07-29 11:38:10.673: W/System.err(627): at com.j256.ormlite.dao.BaseDaoImpl.queryRaw(BaseDaoImpl.java:542)
07-29 11:38:10.683: W/System.err(627): at com.example.fort.db.SaveMoneyController.getMonthTotal(SaveMoneyController.java:232)
07-29 11:38:10.683: W/System.err(627): at com.example.fort.db.SaveMoneyController.getListData(SaveMoneyController.java:199)
07-29 11:38:10.703: W/System.err(627): at com.example.fort.view.MainActivity.loadExpense(MainActivity.java:398)
07-29 11:38:10.703: W/System.err(627): at com.example.fort.view.MainActivity.listClicked(MainActivity.java:316)
07-29 11:38:10.713: W/System.err(627): at com.example.fort.view.MainActivity.access$10(MainActivity.java:259)
07-29 11:38:10.713: W/System.err(627): at com.example.fort.view.MainActivity$8.onItemClick(MainActivity.java:227)
07-29 11:38:10.733: W/System.err(627): at android.widget.AdapterView.performItemClick(AdapterView.java:284)
07-29 11:38:10.733: W/System.err(627): at android.widget.ListView.performItemClick(ListView.java:3513)
07-29 11:38:10.743: W/System.err(627): at android.widget.AbsListView$PerformClick.run(AbsListView.java:1812)
07-29 11:38:10.753: W/System.err(627): at android.os.Handler.handleCallback(Handler.java:587)
07-29 11:38:10.753: W/System.err(627): at android.os.Handler.dispatchMessage(Handler.java:92)
07-29 11:38:10.763: W/System.err(627): at android.os.Looper.loop(Looper.java:123)
07-29 11:38:10.783: W/System.err(627): at android.app.ActivityThread.main(ActivityThread.java:3683)
07-29 11:38:10.783: W/System.err(627): at java.lang.reflect.Method.invokeNative(Native Method)
07-29 11:38:10.783: W/System.err(627): at java.lang.reflect.Method.invoke(Method.java:507)
07-29 11:38:10.783: W/System.err(627): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
07-29 11:38:10.783: W/System.err(627): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
07-29 11:38:10.803: W/System.err(627): at dalvik.system.NativeStart.main(Native Method)
07-29 11:38:10.803: W/System.err(627): Caused by: java.sql.SQLException: Problems executing Android query: select T.amount from TransactionDetails T,TransactionHeaders H where H.id=T.transaction_id AND T.account_id==109 AND H.date BETWEEN Wed Jul 01 00:00:00 GMT+05:30 2015 AND Fri Jul 31 00:00:00 GMT+05:30 2015
07-29 11:38:10.833: W/System.err(627): at com.j256.ormlite.misc.SqlExceptionUtil.create(SqlExceptionUtil.java:22)
07-29 11:38:10.833: W/System.err(627): at com.j256.ormlite.android.AndroidCompiledStatement.getCursor(AndroidCompiledStatement.java:184)
07-29 11:38:10.853: W/System.err(627): at com.j256.ormlite.android.AndroidCompiledStatement.runQuery(AndroidCompiledStatement.java:65)
07-29 11:38:10.853: W/System.err(627): at com.j256.ormlite.stmt.SelectIterator.<init>(SelectIterator.java:55)
07-29 11:38:10.872: W/System.err(627): at com.j256.ormlite.stmt.RawResultsImpl.<init>(RawResultsImpl.java:28)
07-29 11:38:10.872: W/System.err(627): at com.j256.ormlite.stmt.StatementExecutor.queryRaw(StatementExecutor.java:280)
07-29 11:38:10.885: W/System.err(627): at com.j256.ormlite.dao.BaseDaoImpl.queryRaw(BaseDaoImpl.java:540)
07-29 11:38:10.885: W/System.err(627): ... 18 more
07-29 11:38:10.885: W/System.err(627): Caused by: android.database.sqlite.SQLiteException: near "Jul": syntax error: , while compiling: select T.amount from TransactionDetails T,TransactionHeaders H where H.id=T.transaction_id AND T.account_id==109 AND H.date BETWEEN Wed Jul 01 00:00:00 GMT+05:30 2015 AND Fri Jul 31 00:00:00 GMT+05:30 2015
07-29 11:38:10.913: W/System.err(627): at android.database.sqlite.SQLiteCompiledSql.native_compile(Native Method)
07-29 11:38:10.913: W/System.err(627): at android.database.sqlite.SQLiteCompiledSql.compile(SQLiteCompiledSql.java:92)
07-29 11:38:10.933: W/System.err(627): at android.database.sqlite.SQLiteCompiledSql.<init>(SQLiteCompiledSql.java:65)
07-29 11:38:10.933: W/System.err(627): at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:83)
07-29 11:38:10.985: W/System.err(627): at android.database.sqlite.SQLiteQuery.<init>(SQLiteQuery.java:49)
07-29 11:38:10.985: W/System.err(627): at android.database.sqlite.SQLiteDirectCursorDriver.query(SQLiteDirectCursorDriver.java:42)
07-29 11:38:11.013: W/System.err(627): at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory(SQLiteDatabase.java:1356)
07-29 11:38:11.013: W/System.err(627): at android.database.sqlite.SQLiteDatabase.rawQuery(SQLiteDatabase.java:1324)
07-29 11:38:11.023: W/System.err(627): at com.j256.ormlite.android.compat.BasicApiCompatibility.rawQuery(BasicApiCompatibility.java:15)
07-29 11:38:11.034: W/System.err(627): at com.j256.ormlite.android.AndroidCompiledStatement.getCursor(AndroidCompiledStatement.java:180)
07-29 11:38:11.053: W/System.err(627): ... 23 more
下面是 TransactionHeaders 类。
TransactionHeaders.java:
public class TransactionHeaders implements Serializable {
@DatabaseField(generatedId = true, columnName = "id")
private Integer id;
@DatabaseField(columnName = "user_id")
private Integer userID;
@DatabaseField(columnName = "description")
private String description;
@DatabaseField(columnName = "date",dataType=DataType.DATE)
private Date date;
public TransactionHeaders() {
super();
// TODO Auto-generated constructor stub
}
public TransactionHeaders(Integer id, Integer userID, String description,
Date date) {
super();
this.id = id;
this.userID = userID;
this.description = description;
this.date = date;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public Integer getUserID() {
return userID;
}
public void setUserID(Integer userID) {
this.userID = userID;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public Date getDate() {
return date;
}
public void setDate(Date date) {
this.date = date;
}
}
是否是因为任何字符串或日期类型不匹配?请有人帮我离开这里。
最佳答案
Caused by: SQLiteException: near "Jul": syntax error: , while compiling: select T.amount from TransactionDetails T,TransactionHeaders H where H.id=T.transaction_id AND T.account_id==109 AND H.date BETWEEN Wed Jul 01 00:00:00 GMT+05:30 2015 AND Fri Jul 31 00:00:00 GMT+05:30 2015
此异常试图向您展示问题所在。 SQL 查询无法构建为字符串,因为它将日期对象扩展为其字符串形式。用单引号将它们引起来可以解决 SQL 问题,但我认为您不会因为这个答案而得到结果:
您确实需要使用日期格式化程序尝试不同的日期格式。请参阅Sqlite date formats 。如果您将日期格式更改为受支持的格式之一,则可能会起作用,例如:
YYYY-MM-DD HH:MM:SS
要传递日期字符串,我将使用 SQL ?
参数,并将格式化的日期作为查询后的参数传递给 queryRaw(...)
字符串。
关于java - 在 ORMLite queryRaw 方法中获取两个日期字符串之间的日期时出现 SQLException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31693278/
如何使用 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(..)
我是一名优秀的程序员,十分优秀!