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

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

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

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

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

解決済

SQLiteを用いたAndroid開発でORDER BYが効かない

hoge1110100
hoge1110100

総合スコア2

SQLite

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

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

3回答

0評価

0クリップ

453閲覧

投稿2022/03/24 04:33

発生している問題・エラーメッセージ

AndroidJavaで簡単なタスク管理システムを作っています。
ソート機能を付けようと思ってSQLiteに入ってるデータを降順にして画面に反映させようとしましたが、
cursorインスタンスから取り出してnumberListに入れたときに降順になっていませんでした。
実際の画面はこんな感じです。オプションメニューをタップして列を選んだら降順になるようにしたいです。
イメージ説明

該当のソースコード

Java

package com.example.taskmanagement; import androidx.appcompat.app.AppCompatActivity; import android.content.Intent; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.view.Menu; import android.view.MenuInflater; import android.view.MenuItem; import android.widget.ArrayAdapter; import android.widget.ListView; import java.util.ArrayList; import java.util.Collections; import java.util.List; public class TaskList extends AppCompatActivity { private UserDatabaseHelper helper; private int userId; private boolean tap = false; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_task_list); setList(ColumnTask.number, SortType.ASC); } public void setList(ColumnTask column, SortType sortType) { ListView lvNumber = findViewById(R.id.lvNumber); ListView lvTask = findViewById(R.id.lvTask); ListView lvUrgency = findViewById(R.id.lvUrgency); ListView lvImportance = findViewById(R.id.lvImportance); List<Integer> numberList = new ArrayList<>(); List<String> taskList = new ArrayList<>(); List<Integer> urgencyList = new ArrayList<>(); List<Integer> importanceList = new ArrayList<>(); Intent intentFromRegisterTask = getIntent(); userId = intentFromRegisterTask.getIntExtra("userId", 0); helper = new UserDatabaseHelper(TaskList.this); SQLiteDatabase db = helper.getWritableDatabase(); String selectSQL = "SELECT * FROM task WHERE userId = ? ORDER BY ? " + sortType; String[] params = {String.valueOf(userId), String.valueOf(column)}; Cursor cursor = db.rawQuery(selectSQL, params); while (cursor.moveToNext()) { int numberIdx = cursor.getColumnIndex("number"); numberList.add(cursor.getInt(numberIdx)); int taskIdx = cursor.getColumnIndex("task"); taskList.add(cursor.getString(taskIdx)); int urgencyIdx = cursor.getColumnIndex("urgency"); urgencyList.add(cursor.getInt(urgencyIdx)); int importanceIdx = cursor.getColumnIndex("importance"); importanceList.add(cursor.getInt(importanceIdx)); } ArrayAdapter<Integer> numberAdapter = new ArrayAdapter<>(TaskList.this, android.R.layout.simple_list_item_1, numberList); lvNumber.setAdapter(numberAdapter); ArrayAdapter<String> taskAdapter = new ArrayAdapter<>(TaskList.this, android.R.layout.simple_list_item_1, taskList); lvTask.setAdapter(taskAdapter); ArrayAdapter<Integer> urgencyAdapter = new ArrayAdapter<>(TaskList.this, android.R.layout.simple_list_item_1, urgencyList); lvUrgency.setAdapter(urgencyAdapter); ArrayAdapter<Integer> importanceAdapter = new ArrayAdapter<>(TaskList.this, android.R.layout.simple_list_item_1, importanceList); lvImportance.setAdapter(importanceAdapter); } @Override public boolean onCreateOptionsMenu(Menu menu) { MenuInflater inflater = getMenuInflater(); inflater.inflate(R.menu.menu_sort, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { boolean returnValue = true; switch (item.getItemId()) { case R.id.menuSortNumber: if (tap == false) { setList(ColumnTask.number, SortType.DESC); tap = true; } else { setList(ColumnTask.number, SortType.ASC); tap = false; } break; case R.id.menuSortTask: if (tap == false) { setList(ColumnTask.task, SortType.DESC); tap = true; } else { setList(ColumnTask.task, SortType.ASC); tap = false; } break; case R.id.menuSortUrgency: if (tap == false) { setList(ColumnTask.urgency, SortType.DESC); tap = true; } else { setList(ColumnTask.urgency, SortType.ASC); tap = false; } break; case R.id.menuSortImportance: if (tap == false) { setList(ColumnTask.importance, SortType.DESC); tap = true; } else { setList(ColumnTask.importance, SortType.ASC); tap = false; } break; default: returnValue = super.onOptionsItemSelected(item); break; } return returnValue; } @Override public void onDestroy() { super.onDestroy(); helper.close(); } }

試したこと

SQLiteのDBブラウザで実際にSQL実行したところ以下のSQL文は効いて降順になっていました。
→SELECT * FROM task WHERE userId = 1 ORDER BY number DESC;
whereやlimit等を試しましたが、order byのみが効いていない状態です。
原因等心当たりありましたら教えていただきたいです。
(まだ作成途中のため色々と疑問に思う書き方はあると思いますが、何卒ご容赦ください…)

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

SQLite

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

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。