質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Q&A

解決済

1回答

17368閲覧

SELECT文でsyntax errorが出ます。なにが間違えているのでしょうか?

edoooooo

総合スコア478

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

0グッド

0クリップ

投稿2017/04/18 12:18

編集2017/04/19 08:33

".": syntax error となっています。このコード内の"."はすべて、他のSQLの文にも使っているため、必要だと思うのですが、errorの原因は"."ではないのでしょうか?

//"."のエラーを解決し、現在新たな問題が出ています。

java

1 String title1= mList.get(pos).get("title"); 2 String content1=mList.get(pos).get("content"); 3 String data1=mList.get(pos).get("data"); 4 5 6 String table2=UserContract.Users.TABLE_NAME; 7 8 Log.v(title1,data1); 9 10 11 12 String sql="SELECT * FROM " +table2 + 13 " WHERE TITLE= " +title1 + 14 " AND CONTENT ="+ content1 + 15 " AND DATA =" +data1 ; 16 17 Cursor c =db.rawQuery(sql,null);

//android.database.sqlite.SQLiteException: unrecognized token: "4月19日" (code 1): , というエラーが出ます。

java

1 String sql="SELECT * FROM UserContract.Users.TABLE_NAME " + 2 " WHERE UserContract.Users.COL_TITLE== title1 " + 3 " AND UserContract.Users.COL_CONTENT == content1 " + 4 " AND UserContract.Users.COL_DATA==data1 "; 5 6 Cursor c =db.rawQuery(sql,null); 7 8

java

1 E/AndroidRuntime: FATAL EXCEPTION: main 2 android.database.sqlite.SQLiteException: near ".": syntax error (code 1): , while compiling: SELECT * FROM UserContract.Users.TABLE_NAME WHERE UserContract.Users.COL_TITLE== title1 AND UserContract.Users.COL_CONTENT == content1 AND UserContract.Users.COL_DATA==data1 3 at android.database.sqlite.SQLiteConnection.nativePrepareStatement(Native Method) 4 at android.database.sqlite.SQLiteConnection.acquirePreparedStatement(SQLiteConnection.java:893) 5 at android.database.sqlite.SQLiteConnection.prepare(SQLiteConnection.java:504) 6 at android.database.sqlite.SQLiteSession.prepare(SQLiteSession.java:588) 7 at android.database.sqlite.SQLiteProgram.<init>(SQLiteProgram.java:58) 8 at android.database.sqlite.SQLiteQuery.<init>(SQLiteQuery.java:37) 9 at android.database.sqlite.SQLiteDirectCursorDriver.query(SQLiteDirectCursorDriver.java:44) 10 at android.database.sqlite.SQLiteDatabase.rawQueryWithFactory(SQLiteDatabase.java:1322) 11 at android.database.sqlite.SQLiteDatabase.rawQuery(SQLiteDatabase.java:1261) 12 at com.example.android.sample.memo.MainActivity$1.onItemClick(MainActivity.java:148) 13 at android.widget.AdapterView.performItemClick(AdapterView.java:298) 14 at android.widget.AbsListView.performItemClick(AbsListView.java:1086) 15 at android.widget.AbsListView$PerformClick.run(AbsListView.java:2859) 16 at android.widget.AbsListView$1.run(AbsListView.java:3533) 17 at android.os.Handler.handleCallback(Handler.java:615) 18 at android.os.Handler.dispatchMessage(Handler.java:92) 19 at android.os.Looper.loop(Looper.java:213) 20 at android.app.ActivityThread.main(ActivityThread.java:4786) 21 at java.lang.reflect.Method.invokeNative(Native Method) 22 at java.lang.reflect.Method.invoke(Method.java:511) 23 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789) 24 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556) 25 at dalvik.system.NativeStart.main(Native Method) 26 27

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

自分でデバッグすべき内容です。
SQLの中に.はどこにありますか?

投稿2017/04/18 12:24

yona

総合スコア18155

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

edoooooo

2017/04/18 12:26

UserContract.Users. この中の 2箇所です。
yona

2017/04/18 12:28

じゃあそれはSQLの中でどのような意味があるんですか?
edoooooo

2017/04/18 12:37

確かに今までこのような SQLは見たことがありませんでした。 UserContract.Users.の部分を消したところ、syntax errorがなくなりました。
yona

2017/04/18 12:41

今回もエラーの原因を理解せず、解決したと思い込み。またよくわからないことになっていくんですね。
edoooooo

2017/04/19 08:11 編集

すみません。コメントをいただいていたことに今気づきました。 徐々に解決に向かっているとは思うのですが、今はこの段階です。 String title2=UserContract.Users.COL_TITLE; String content2= UserContract.Users.COL_CONTENT; String data2=UserContract.Users.COL_DATA; String table2=UserContract.Users.TABLE_NAME; Log.v(title1,data1); Log.v(title2,data2); String sql="SELECT * FROM " +table2 + " WHERE "+ title2+ "==" +title1 + "AND "+ content2 +"=="+ content1 + "AND "+ data2+"=="+data1 ; Cursor c =db.rawQuery(sql,null);
yona

2017/04/19 08:10

なにをしたいのかわからない上に一連の質問の回答が見事に反映されていません。解決には向かっていないようです。
edoooooo

2017/04/19 08:31 編集

やりたいこととしましては、sqlでtitle、content、dataの同じデータを取得し その中のデータから取得したidをitnentに附属させそれをupdateの時に使うことです
edoooooo

2017/04/19 08:30 編集

String title1= mList.get(pos).get("title"); String content1=mList.get(pos).get("content"); String data1=mList.get(pos).get("data"); String table2=UserContract.Users.TABLE_NAME; String sql="SELECT * FROM " +table2 + " WHERE TITLE= " +title1 + " AND CONTENT ="+ content1 + " AND DATA =" +data1 ; 確かにやりたいことが変わってるように見えていました。
edoooooo

2017/04/19 08:31

android.database.sqlite.SQLiteException: unrecognized token: "4月19日" (code 1): , と出るのですが、4月19 はString 型にしているのですが、使え無いのでしょうか?
yona

2017/04/19 08:35

デバッグは自分でやりましょう。 あと、この質問は閉じているので回答はしません。
edoooooo

2017/04/19 08:38

わかりました。このようなエラーの前例を調べてみます。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問