私はNewbee to Databaseのコンセプトです。私は相対的なデータベースコンセプトが必要です。私はアンドロイドのためにsqliteデータベースを使用しています。 。 私はデータベースコンセプトの初心者です誰も私にはcreate()、insert()、Query()などを理解するための良いリソースを教えていただけますか?アンドロイドで作業するサンプルプログラムを入手すると良いでしょう。 。事前sqliteのサンプルプログラムandroid
6
A
答えて
14
で
おかげで、それは以下のコードに従って非常に簡単です... たとえばという名前の3クラスの作成 - 1.私が使用定数インターフェイス、...
package com.mypackage.quaddeals;
import static android.provider.BaseColumns._ID;
import static com.mypackage.quaddeals.Constants.CITYID;
import static com.mypackage.quaddeals.Constants.TITLE;
import static com.mypackage.quaddeals.Constants.TABLE_NAME;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;
public class Bru_Press_Data extends SQLiteOpenHelper {
public static final String DATABASE_NAME = "QuadDeals.db";
public static final int DATABASE_VERSION = 1;
/** Create a helper object for the Events database */
public Bru_Press_Data(Context ctx) {
super(ctx, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
try {
db.execSQL("CREATE TABLE " + TABLE_NAME + " (" + _ID
+ " INTEGER PRIMARY KEY AUTOINCREMENT," + TITLE
+ " TEXT UNIQUE," + CITYID + " TEXT);");
} catch (Exception e) {
Log.v("Bru_Press_Data", "exception in table created");
}
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
onCreate(db);
}
}
3.Providerクラス
package com.mypackage.quaddeals;
import static android.provider.BaseColumns._ID;
import static com.mypackage.quaddeals.Constants.CONTENT_URI;
import static com.mypackage.quaddeals.Constants.AUTHORITY;
import static com.mypackage.quaddeals.Constants.TABLE_NAME;
import android.app.SearchManager;
import android.content.ContentProvider;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.UriMatcher;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri;
import android.text.TextUtils;
import android.util.Log;
public class Bru_Press_Provider extends ContentProvider {
private static final int QUADUSER = 1;
private static final int QUADUSER_ID = 2;
/** The MIME type of a directory of events */
private static final String CONTENT_TYPE = "vnd.android.cursor.dir/vnd.example.brown";
/** The MIME type of a single event */
private static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/vnd.example.brown";
private static final String CONTENT_TYPE1 = "vnd.android.cursor.dir/vnd.example.brown";
/** The MIME type of a single event */
private static final String CONTENT_ITEM_TYPE1 = "vnd.android.cursor.item/vnd.example.brown";
// private static final String CONTENT_TYPE2 = "vnd.android.cursor.dir/vnd.example.brown";
/** The MIME type of a single event */
// private static final String CONTENT_ITEM_TYPE2 = "vnd.android.cursor.item/vnd.example.brown";
private Bru_Press_Data news;
private UriMatcher uriMatcher;
private Cursor cursor;
private SQLiteDatabase db;
String[] str;
@Override
public boolean onCreate() {
uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
uriMatcher.addURI(AUTHORITY, "user_deal", QUADUSER);
uriMatcher.addURI(AUTHORITY, "user_deal/#", QUADUSER_ID);
news = new Bru_Press_Data(getContext());
return true;
}
@Override
public Cursor query(Uri uri, String[] projection, String selection,
String[] selectionArgs, String orderBy) {
SQLiteDatabase db;
Cursor cursor = null;
if (uriMatcher.match(uri) == QUADUSER_ID) {
long id = Long.parseLong(uri.getPathSegments().get(1));
selection = appendRowId(selection, id);
}
if (uriMatcher.match(uri) == QUADUSER) {
// Get the database and run the query
db = news.getReadableDatabase();
cursor = db.query(TABLE_NAME, projection, selection, selectionArgs,
null, null, orderBy);
}
cursor.setNotificationUri(getContext().getContentResolver(), uri);
return cursor;
}
@Override
public String getType(Uri uri) {
switch (uriMatcher.match(uri)) {
case QUADUSER:
return CONTENT_TYPE;
case QUADUSER_ID:
return CONTENT_ITEM_TYPE;
default:
throw new IllegalArgumentException("Unknown URI " + uri);
}
}
@Override
public Uri insert(Uri uri, ContentValues values) {
SQLiteDatabase db = news.getWritableDatabase();
Uri newUri = null;
long id = -1;
// Validate the requested uri
if (uriMatcher.match(uri) == QUADUSER) {
try {
id = db.insertOrThrow(TABLE_NAME, null, values);
// Notify any watchers of the change
newUri = ContentUris.withAppendedId(CONTENT_URI, id);
getContext().getContentResolver().notifyChange(newUri, null);
} catch (NullPointerException e) {
Log.v("Error","OnInsert"+e);
}
}
else if (uriMatcher.match(uri) != QUADUSER) {
throw new IllegalArgumentException("Unknown URI bru press " + uri);
}
return newUri;
}
@Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
SQLiteDatabase db = news.getWritableDatabase();
int count;
long id;
Log.v("Delete",selection);
switch (uriMatcher.match(uri)) {
case QUADUSER:
count = db.delete(TABLE_NAME, selection, selectionArgs);
break;
case QUADUSER_ID:
id = Long.parseLong(uri.getPathSegments().get(1));
count = db.delete(TABLE_NAME, appendRowId(selection, id),
selectionArgs);
break;
default:
throw new IllegalArgumentException("Unknown URI " + uri);
}
getContext().getContentResolver().notifyChange(uri, null);
return count;
}
@Override
public int update(Uri uri, ContentValues values, String selection,
String[] selectionArgs) {
SQLiteDatabase db = news.getWritableDatabase();
int count;
long id;
switch (uriMatcher.match(uri)) {
case QUADUSER:
count = db.update(TABLE_NAME, values, selection, selectionArgs);
break;
case QUADUSER_ID:
id = Long.parseLong(uri.getPathSegments().get(1));
count = db.update(TABLE_NAME, values, appendRowId(selection, id),
selectionArgs);
break;
default:
throw new IllegalArgumentException("Unknown URI " + uri);
}
// Notify any watchers of the change
getContext().getContentResolver().notifyChange(uri, null);
return count;
}
/** Append an id test to a SQL selection expression */
private String appendRowId(String selection, long id) {
return _ID
+ "="
+ id
+ (!TextUtils.isEmpty(selection) ? " AND (" + selection + ')'
: "");
}
}
注意を全コードを参照し、それが
package com.mypackage.quaddeals;
import android.net.Uri;
import android.provider.BaseColumns;
public interface Constants extends BaseColumns {
public static final String TABLE_NAME = "user_deal";
public static final String AUTHORITY = "com.mypackage.quaddeals";
public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY
+ "/" + TABLE_NAME);
public static final String TITLE = "title";
public static final String CITYID = "cityid";
}
2.BruPressデータクラスを使用します見つける:あなたはこれを定義すると仮定マニフェストファイルのプロバイダクラス( など)私はDBにデータを挿入して取得することができます別のクラスでは、
...が...それをこのようないくつかのことを試してみてくださいDbの
からCursor c = getContentResolver().query(Constants.CONTENT_URI,
null, null, null,null);
int a = c.getCount();
Log.v("Count",""+a);
int columnIndex = c.getColumnIndex(Constants.TITLE);
int columnIndex2 = c.getColumnIndex(Constants.CITYID);
if (c.moveToNext()) {
cityName = c.getString(columnIndex);
city_id= c.getString(columnIndex2);
}
}
を取得するための
class A extends Activity{
{
addevent(cityname,cityid); // to insert
}
private void addevent(String a1, String a2) {
try {
ContentValues values = new ContentValues();
values.put(Constants.TITLE, a1);
values.put(Constants.CITYID, a2);
getContentResolver().insert(Constants.CONTENT_URI, values);
} catch (Exception e) {
Log.v("Error",""+e);
}
}
を次のいあなたに役立つでしょう
+0
こんにちは。以下のリンクを使って同じことをする最も簡単な方法を試してみましょう。 ORMANを使用しているオブジェクトモデルに基づいています--- https://github.com/ahmetalpbalkan/orman/wiki ORMLiteは同じgoogleです.ORMANはORMLiteから拡張されています –
関連する問題
- 1. サンプルプログラムのAndroid FACE API
- 2. GDbus信号のサンプルプログラム
- 3. サンプルプログラム引数
- 4. RPI 3ハードウェアPWMのサンプルプログラム?
- 5. サンプルプログラムの大きな価値
- 6. android sqliteのNullPointerException
- 7. AndroidのSQLite Hangup
- 8. AndroidのSQLite
- 9. AndroidのSQLiteデータベースデザイン
- 10. AndroidのSQLiteライブラリ
- 11. AndroidのSQLite
- 12. AndroidのSQLiteデータベースユニットテスト
- 13. AndroidデバイスのAndroid Sqlite SELECTクエリエラー
- 14. androidのsqliteのリレーションシップテーブル
- 15. AndroidのSQLiteのgetColumnIndex
- 16. タイプは、サンプルプログラムについて
- 17. AndroidのエラーSQLiteカーソル
- 18. 同期SQLiteのAndroid
- 19. AndroidのSQLiteとNullPointer
- 20. AndroidでSQLiteのビジータイムアウト
- 21. Android SQLiteのrawqueryパラメータ
- 22. AndroidアプリケーションのSqliteエラー
- 23. SQLiteのはstudio- -android
- 24. AndroidのSQLiteは、行
- 25. Android - オープンSQLiteデータベース
- 26. Android SQLiteデータベース
- 27. Android SQLite CursorIndexOutOfBounds
- 28. Android sqlite where句
- 29. Android Sqlite Insertion error
- 30. Sqlite Xamarin android nougat
これは[Androidでのデータベースの作成と使用](http://www.devx.com/wireless/Article/40842/0)です。その良い1つです –
こんにちはこのチュートリアルを読んでくださいsqliteでデータにアクセスするhttp://www.hig herpass.com/Android/Tutorials/Accessing-Data-With-Android-Cursors/ – Narasimha
+1、17万以上のビューはまだ投票しません! – Jaguar