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

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

ただいまの
回答率

90.03%

Java Realmでタイトルでのソートができません。

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,335

sakanasann

score 9

以下のようなコードを書きました。
年月日でのソートはできるようになりましたが、タイトルでのソートができませんでした。

タイトルでのソートを実行すると、何らかのソートをしているように見えますが、タイトルを参照したソートではありません。

繰り返しますが、年月日のソートは正常に動作し、タイトルのソートのみ正常に動作しません。

どうすれば正常に動作するでしょうか?

年月日ソートの正常な動作の定義:【年月日入力欄に入力されている数字を昇順降順に並び替える動作】(こちらは現在正常な動作をしているように見えます)

タイトルソートの正常な動作の定義:
【タイトル欄に入力されている文字を「あいうえお順」または「ABC順」に並び替える動作】(こちらが正常な動作をしていません)

・ソート処理部分(メニューから指定のボタンを押すと動作するようにしています)

 public boolean onOptionsItemSelected(MenuItem item) {
        int id = item.getItemId();

        if (id == R.id.action_settings) {
            Realm realm = Realm.getInstance(this);
            RealmResults<Schedule> schedules = realm.where(Schedule.class).findAll();
            schedules.sort("date", Sort.ASCENDING);
            ScheduleAdapter adapter = new ScheduleAdapter(this, schedules, true);
            mListView.setAdapter(adapter);
            Toast.makeText(this, "年月日を参照し昇順に並び替えました", Toast.LENGTH_SHORT).show();
            return true;
        }else if(id == R.id.action_settings2){
            Realm realm = Realm.getInstance(this);
            RealmResults<Schedule> schedules = realm.where(Schedule.class).findAll();
            schedules.sort("date", Sort.DESCENDING);
            ScheduleAdapter adapter = new ScheduleAdapter(this, schedules, true);
            mListView.setAdapter(adapter);
            Toast.makeText(this, "年月日を参照し降順に並び替えました", Toast.LENGTH_SHORT).show();
            return true;
        }else if(id == R.id.action_settings3) {
            Realm realm = Realm.getInstance(this);
            RealmResults<Schedule> schedules = realm.where(Schedule.class).findAll();
            schedules.sort("title", Sort.DESCENDING);
            ScheduleAdapter adapter = new ScheduleAdapter(this, schedules, true);
            mListView.setAdapter(adapter);
            Toast.makeText(this, "タイトルを参照し降順に並び替えました", Toast.LENGTH_SHORT).show();
            return true;
        }else if(id == R.id.action_settings4) {
            Realm realm = Realm.getInstance(this);
            RealmResults<Schedule> schedules = realm.where(Schedule.class).findAll();
            schedules.sort("title", Sort.DESCENDING);
            ScheduleAdapter adapter = new ScheduleAdapter(this, schedules, true);
            mListView.setAdapter(adapter);
            Toast.makeText(this, "タイトルを参照し降順に並び替えました", Toast.LENGTH_SHORT).show();
            return true;
        }
        return super.onOptionsItemSelected(item);
    }

・Scheduleクラス

public class Schedule extends RealmObject{
    @PrimaryKey
    private long id;
    private Date date;
    private String title;
    private String detail;

    public long getId() {
        return id;
    }

    public void setId(long id) {
        this.id = id;
    }

    public Date getDate() {
        return date;
    }

    public void setDate(Date date) {
        this.date = date;
    }

    public String getTitle() {
        return title;
    }

    public void setTitle(String title) {
        this.title = title;
    }

    public String getDetail() {
        return detail;
    }

    public void setDetail(String detail) {
        this.detail = detail;
    }
}

・ScheduleAdapterクラス

    private static class ViewHolder {
        TextView date;
        TextView title;
    }

    public ScheduleAdapter(Context context, RealmResults<Schedule> realmResults, boolean automaticUpdate) {
        super(context, realmResults, automaticUpdate);
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder viewHolder;
        if(convertView == null) {
            convertView = inflater.inflate(android.R.layout.simple_list_item_2, parent, false);
            viewHolder = new ViewHolder();
            viewHolder.date = (TextView) convertView.findViewById(android.R.id.text1);
            viewHolder.title = (TextView)convertView.findViewById(android.R.id.text2);
            convertView.setTag(viewHolder);
        } else {
            viewHolder = (ViewHolder)convertView.getTag();
        }

        Schedule schedule = realmResults.get(position);
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd");
        String formatDate = sdf.format(schedule.getDate());
        viewHolder.date.setText(formatDate);
        viewHolder.title.setText(schedule.getTitle());

        return convertView;
    }
}


・ScheduleEditActivityクラスの内容の一部

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_schedule_edit);
        mDateEdit= (EditText) findViewById(R.id.dateEdit);
        mTitleEdit= (EditText) findViewById(R.id.titleEdit);
        mDetailEdit = (EditText) findViewById(R.id.detailEdit);
        mDelete = (Button) findViewById(R.id.delete);
        long scheduleId = getIntent().getLongExtra("schedule_id", -1);
        if (scheduleId != -1) {
            Realm realm = Realm.getInstance(this);
            RealmResults<Schedule> results = realm.where(Schedule.class)
                    .equalTo("id", scheduleId).findAll();
            Schedule schedule = results.first();
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd");
            String date = sdf.format(schedule.getDate());
            mDateEdit.setText(date);
            mTitleEdit.setText(schedule.getTitle());
            mDetailEdit.setText(schedule.getDetail());
            mDelete.setVisibility(View.VISIBLE);
        } else {
            mDelete.setVisibility(View.INVISIBLE);
        }

    }
    public void onSaveTapped(View view) {
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd");
        Date date = new Date();
        try {
            date = sdf.parse(mDateEdit.getText().toString());
        } catch (ParseException e) {
            e.printStackTrace();
        }
        long scheduleId = getIntent().getLongExtra("schedule_id", -1);
        if (scheduleId != -1) {
            Realm realm = Realm.getInstance(this);
            RealmResults<Schedule> results = realm.where(Schedule.class)
                    .equalTo("id", scheduleId).findAll();
            realm.beginTransaction();
            Schedule schedule = results.first();
            schedule.setDate(date);
            schedule.setTitle(mTitleEdit.getText().toString());
            schedule.setDetail(mDetailEdit.getText().toString());
            realm.commitTransaction();
            Snackbar.make(findViewById(android.R.id.content), "更新しました"
                    , Snackbar.LENGTH_SHORT)
                    .setAction("戻る", new View.OnClickListener() {
                        @Override
                        public void onClick(View v) {
                            finish();
                        }
                    })
                    .setActionTextColor(Color.YELLOW)
                    .show();
        } else {
            Realm realm = Realm.getInstance(this);
            realm.beginTransaction();
            Number maxId = realm.where(Schedule.class).max("id");
            long nextId = 1;
            if (maxId != null) nextId = maxId.longValue() + 1;
            Schedule schedule = realm.createObject(Schedule.class);
            schedule.setId(nextId);
            schedule.setDate(date);
            schedule.setTitle(mTitleEdit.getText().toString());
            schedule.setDetail(mDetailEdit.getText().toString());
            realm.commitTransaction();
            Toast.makeText(this, "追加しました", Toast.LENGTH_SHORT).show();
            finish();


・メニューXML内の指定部分

<item
        android:id="@+id/action_settings"
        android:orderInCategory="100"
        android:title="@string/action_settings"
        app:showAsAction="never" />
    <item
        android:id="@+id/action_settings2"
        android:orderInCategory="100"
        android:title="@string/action_settings2"
        app:showAsAction="never" />
    <item
        android:id="@+id/action_settings3"
        android:orderInCategory="100"
        android:title="@string/action_settings3"
        app:showAsAction="never" />
    <item
        android:id="@+id/action_settings4"
        android:orderInCategory="100"
        android:title="@string/action_settings4"
        app:showAsAction="never" />
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

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

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

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

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

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

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

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

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • fuzzball

    2017/01/20 12:01

    「正常に動作しません」を具体的に書いて下さい。

    キャンセル

回答 1

checkベストアンサー

+1

年月日のソートは、本当に正常に動作しているのでしょうか?

sort()は、ソート結果を返値で返す関数なので、

schedules = schedules.sort("title", Sort.DESCENDING);

としないと、ソート後のデータを取得出来ないと思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/01/25 11:48 編集

    classpath "io.realm:realm-gradle-plugin:2.3.0"
    と書き換えましたが、ソート実行時に変化はありませんでした。

    なお、書き換えたことによるエラーは無く、その他の異常も無いように見えます。

    その他、説明で書き加えるべきとされていた内容は、サンプルソースの初期状態から存在しましたので変更を加えていません。

    キャンセル

  • 2017/01/25 12:07

    Androidstudioを再起動しましたところ、タイトルの降順ソートのみ正常に動くようになりましたが、昇順ソートに割り当てているボタンを押しても降順にソートされてしまいます。

    昇順ソートを実行 → 降順にソートされる
    降順ソートを実行 → 降順にソートされる

    と、なりました。

    年月日ソートについては、依然と変わらず正常な動作をしています。

    キャンセル

  • 2017/01/25 12:11 編集

    書き換えたはずのコードが一部以前の状態に戻っていたようです。
    修正したら正常に動作するようになりました。

    ありがとうございました!

    キャンセル

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

  • ただいまの回答率 90.03%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる