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

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

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

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

Java

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

Android

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

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Q&A

解決済

1回答

3350閲覧

androidで予測変換機能を実装したい

aaaaaaaaaaaaaa

総合スコア77

SQLite

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

Java

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

Android

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

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

0グッド

0クリップ

投稿2016/01/15 10:45

http://d.hatena.ne.jp/sy-2010/touch/20100203/1265196762
を参考にしてandroidのsqliteからデータを取得しデータを参照し予測変換機能を実装したいのですが、sqliteの”n_data”カラムの値が同じ物も出力されてしまいます。
重複させないためにはどのようにすればよいですか。

AutoCompleteTextView inputTextView = (AutoCompleteTextView) findViewById(R.id.m_name); Cursor m_cursor = db3.query(DB_TABLE, new String[]{"rowid as _id", "n_data" },null, null,null, null, null); SimpleCursorAdapter M_adapter2 = new SimpleCursorAdapter(getApplicationContext(), android.R.layout.simple_spinner_dropdown_item, m_cursor, new String[]{"n_data"}, new int[]{android.R.id.text1}, 0) { }; M_adapter2.setCursorToStringConverter(new SimpleCursorAdapter.CursorToStringConverter() { @Override public String convertToString(Cursor m_cursor) { return m_cursor.getString(m_cursor.getColumnIndex("n_data")); } M_adapter2.setFilterQueryProvider(new FilterQueryProvider() { public Cursor runQuery(CharSequence constraint) { String str = constraint.toString(); str = "%" + str + "%"; helper = new DBOpenHelper(ItemListActivity.this);// DB作成 Cursor m_cursor = helper.getReadableDatabase().query( DB_TABLE4, new String[]{"rowid as _id", "n_data"}, "n_data LIKE '' || ? || '%' ", new String[]{str}, null,null, null); return m_cursor; } }); inputTextView2.setAdapter(M_adapter2);

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

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

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

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

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

guest

回答1

0

ベストアンサー

SQLに条件を追加して、重複しないように指定すればよいのではないでしょうか。

SQL

1AND n_data NOT LIKE 文字列

投稿2016/01/16 08:41

coba-coba

総合スコア1409

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

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

aaaaaaaaaaaaaa

2016/01/18 00:43

ソースにsqlの部分が二つありますがどの部分をおっしゃっているのですか、 またどのような文字列を入れてやればよいのですか。
coba-coba

2016/01/18 03:20

public Cursor runQuery(CharSequence constraint) { 以下の、 str = "%" + str + "%"; を削除して、 その下のSQLを、"n_data LIKE '%' || ? || '%' AND n_data NOT LIKE ?", new String[]{str, str}と変更します。 やりたいことですが、 1. inputTextViewに入力された文字列を取得し、strに入れる。 2. n_dataが文字列strを含み、かつn_dataがstrと完全一致しないレコードを取得する。 自分で試せていないので、もし違っていたらすみません。
aaaaaaaaaaaaaa

2016/01/18 09:48

Cursor m_cursor = helper.getReadableDatabase().query( DB_TABLE4, new String[]{"rowid as _id", "n_data"}, "n_data LIKE '' || ? || '%' ", new String[]{str}, n_data,null, null); と記入すると思うような動きになりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問