當前位置: 首頁>>代碼示例>>Java>>正文


Java ContentValues.getAsLong方法代碼示例

本文整理匯總了Java中android.content.ContentValues.getAsLong方法的典型用法代碼示例。如果您正苦於以下問題:Java ContentValues.getAsLong方法的具體用法?Java ContentValues.getAsLong怎麽用?Java ContentValues.getAsLong使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在android.content.ContentValues的用法示例。


在下文中一共展示了ContentValues.getAsLong方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: fromContentValues

import android.content.ContentValues; //導入方法依賴的package包/類
static SearchRow fromContentValues(ContentValues values) {
    SearchRow row = new SearchRow();
    if (values.containsKey(SearchColumns.SEARCH)) {
        row.mTerm = values.getAsString(SearchColumns.SEARCH);
    }
    if (values.containsKey(SearchColumns.DATE)) {
        row.mDate = values.getAsLong(SearchColumns.DATE);
    }
    return row;
}
 
開發者ID:rkshuai,項目名稱:chromium-for-android-56-debug-video,代碼行數:11,代碼來源:ChromeBrowserProvider.java

示例2: bulkInsert

import android.content.ContentValues; //導入方法依賴的package包/類
/**
 * Handles requests to insert a set of new rows. In Sunshine, we are only going to be
 * inserting multiple rows of data at a time from a weather forecast. There is no use case
 * for inserting a single row of data into our ContentProvider, and so we are only going to
 * implement bulkInsert. In a normal ContentProvider's implementation, you will probably want
 * to provide proper functionality for the insert method as well.
 *
 * @param uri    The content:// URI of the insertion request.
 * @param values An array of sets of column_name/value pairs to add to the database.
 *               This must not be {@code null}.
 *
 * @return The number of values that were inserted.
 */
@Override
public int bulkInsert(@NonNull Uri uri, @NonNull ContentValues[] values) {
    final SQLiteDatabase db = mOpenHelper.getWritableDatabase();

    switch (sUriMatcher.match(uri)) {

        case CODE_WEATHER:
            db.beginTransaction();
            int rowsInserted = 0;
            try {
                for (ContentValues value : values) {
                    long weatherDate =
                            value.getAsLong(WeatherContract.WeatherEntry.COLUMN_DATE);
                    if (!SunshineDateUtils.isDateNormalized(weatherDate)) {
                        throw new IllegalArgumentException("Date must be normalized to insert");
                    }

                    long _id = db.insert(WeatherContract.WeatherEntry.TABLE_NAME, null, value);
                    if (_id != -1) {
                        rowsInserted++;
                    }
                }
                db.setTransactionSuccessful();
            } finally {
                db.endTransaction();
            }

            if (rowsInserted > 0) {
                getContext().getContentResolver().notifyChange(uri, null);
            }

            return rowsInserted;

        default:
            return super.bulkInsert(uri, values);
    }
}
 
開發者ID:fjoglar,項目名稱:android-dev-challenge,代碼行數:51,代碼來源:WeatherProvider.java

示例3: fromContentValues

import android.content.ContentValues; //導入方法依賴的package包/類
/**
 * Create a new {@link Cheese} from the specified {@link ContentValues}.
 *
 * @param values A {@link ContentValues} that at least contain {@link #COLUMN_NAME}.
 * @return A newly created {@link Cheese} instance.
 */
public static Cheese fromContentValues(ContentValues values) {
    final Cheese cheese = new Cheese();
    if (values.containsKey(COLUMN_ID)) {
        cheese.id = values.getAsLong(COLUMN_ID);
    }
    if (values.containsKey(COLUMN_NAME)) {
        cheese.name = values.getAsString(COLUMN_NAME);
    }
    return cheese;
}
 
開發者ID:googlesamples,項目名稱:android-architecture-components,代碼行數:17,代碼來源:Cheese.java

示例4: validateExpenseAndInsert

import android.content.ContentValues; //導入方法依賴的package包/類
private Uri validateExpenseAndInsert(Uri uri, ContentValues contentValues) {

        String info = contentValues.getAsString(ExpenseEntry.COLUMN_INFO).trim();
        if (info.isEmpty()) {
            throw new IllegalArgumentException("Expense info must be set.");
        }

        Double price = contentValues.getAsDouble(ExpenseEntry.COLUMN_PRICE);
        if (price == null || price < 0) {
            throw new IllegalArgumentException("Wrong price " + price);
        }

        Long vehicleId = contentValues.getAsLong(ExpenseEntry.COLUMN_VEHICLE);
        String selection = VehicleEntry._ID + "=?";
        String[] selectionArgs = new String[] { String.valueOf(vehicleId) };
        Cursor cursor = mDbHelper.getReadableDatabase().query(VehicleEntry.TABLE_NAME, FuelUpContract.ALL_COLUMNS_VEHICLES, selection, selectionArgs, null, null, null);
        if (cursor == null || cursor.getCount() != 1) {
            if (cursor != null)
                cursor.close();
            throw new IllegalArgumentException("Vehicle with id=" + vehicleId + " does not exist.");
        }
        cursor.close();

        SQLiteDatabase database = mDbHelper.getWritableDatabase();
        long id = database.insert(ExpenseEntry.TABLE_NAME, null, contentValues);

        if (id == -1) {
            Log.e(LOG_TAG, "Failed to insert row for " + uri);
            return null;
        }

        getContext().getContentResolver().notifyChange(uri, null);
        return ContentUris.withAppendedId(uri, id);
    }
 
開發者ID:piskula,項目名稱:FuelUp,代碼行數:35,代碼來源:VehicleProvider.java

示例5: createFromContentValues

import android.content.ContentValues; //導入方法依賴的package包/類
/**
 * Create a WordListMetadata from the contents of a ContentValues.
 *
 * If this lacks any required field, IllegalArgumentException is thrown.
 */
public static WordListMetadata createFromContentValues(@Nonnull final ContentValues values) {
    final String id = values.getAsString(MetadataDbHelper.WORDLISTID_COLUMN);
    final Integer type = values.getAsInteger(MetadataDbHelper.TYPE_COLUMN);
    final String description = values.getAsString(MetadataDbHelper.DESCRIPTION_COLUMN);
    final Long lastUpdate = values.getAsLong(MetadataDbHelper.DATE_COLUMN);
    final Long fileSize = values.getAsLong(MetadataDbHelper.FILESIZE_COLUMN);
    final String rawChecksum = values.getAsString(MetadataDbHelper.RAW_CHECKSUM_COLUMN);
    final String checksum = values.getAsString(MetadataDbHelper.CHECKSUM_COLUMN);
    final int retryCount = values.getAsInteger(MetadataDbHelper.RETRY_COUNT_COLUMN);
    final String localFilename = values.getAsString(MetadataDbHelper.LOCAL_FILENAME_COLUMN);
    final String remoteFilename = values.getAsString(MetadataDbHelper.REMOTE_FILENAME_COLUMN);
    final Integer version = values.getAsInteger(MetadataDbHelper.VERSION_COLUMN);
    final Integer formatVersion = values.getAsInteger(MetadataDbHelper.FORMATVERSION_COLUMN);
    final Integer flags = values.getAsInteger(MetadataDbHelper.FLAGS_COLUMN);
    final String locale = values.getAsString(MetadataDbHelper.LOCALE_COLUMN);
    if (null == id
            || null == type
            || null == description
            || null == lastUpdate
            || null == fileSize
            || null == checksum
            || null == localFilename
            || null == remoteFilename
            || null == version
            || null == formatVersion
            || null == flags
            || null == locale) {
        throw new IllegalArgumentException();
    }
    return new WordListMetadata(id, type, description, lastUpdate, fileSize, rawChecksum,
            checksum, retryCount, localFilename, remoteFilename, version, formatVersion,
            flags, locale);
}
 
開發者ID:sergeychilingaryan,項目名稱:AOSP-Kayboard-7.1.2,代碼行數:39,代碼來源:WordListMetadata.java

示例6: readFromValues

import android.content.ContentValues; //導入方法依賴的package包/類
public void readFromValues(ContentValues values) {
    itemType = values.getAsInteger(LauncherSettings.Favorites.ITEM_TYPE);
    container = values.getAsLong(LauncherSettings.Favorites.CONTAINER);
    screenId = values.getAsLong(LauncherSettings.Favorites.SCREEN);
    cellX = values.getAsInteger(LauncherSettings.Favorites.CELLX);
    cellY = values.getAsInteger(LauncherSettings.Favorites.CELLY);
    spanX = values.getAsInteger(LauncherSettings.Favorites.SPANX);
    spanY = values.getAsInteger(LauncherSettings.Favorites.SPANY);
    rank = values.getAsInteger(LauncherSettings.Favorites.RANK);
}
 
開發者ID:TeamBrainStorm,項目名稱:SimpleUILauncher,代碼行數:11,代碼來源:ItemInfo.java

示例7: bulkInsert

import android.content.ContentValues; //導入方法依賴的package包/類
/**
     * Handles requests to insert a set of new rows. In Sunshine, we are only going to be
     * inserting multiple rows of data at a time from a weather forecast. There is no use case
     * for inserting a single row of data into our ContentProvider, and so we are only going to
     * implement bulkInsert. In a normal ContentProvider's implementation, you will probably want
     * to provide proper functionality for the insert method as well.
     *
     * @param uri    The content:// URI of the insertion request.
     * @param values An array of sets of column_name/value pairs to add to the database.
     *               This must not be {@code null}.
     *
     * @return The number of values that were inserted.
     */
    @Override
    public int bulkInsert(@NonNull Uri uri, @NonNull ContentValues[] values) {

        final SQLiteDatabase db = mOpenHelper.getWritableDatabase();

        switch (sUriMatcher.match(uri)) {
//          COMPLETED (2) Only perform our implementation of bulkInsert if the URI matches the CODE_WEATHER code
            case CODE_WEATHER:
                db.beginTransaction();
                int rowsInserted = 0;

                try {
                    for (ContentValues value : values) {
                        long weatherDate = value.getAsLong(WeatherContract.WeatherEntry.COLUMN_DATE);
                        if (!SunshineDateUtils.isDateNormalized(weatherDate)) {
                            throw new IllegalArgumentException("Date must be normalized to insert");
                        }

                        long _id = db.insert(WeatherContract.WeatherEntry.TABLE_NAME, null, value);
                        if (_id != 0) {
                            rowsInserted++;
                        }
                    }
                    db.setTransactionSuccessful();
                } finally {
                    db.endTransaction();
                }

                if (rowsInserted > 0) {
                    getContext().getContentResolver().notifyChange(uri, null);
                }

//              COMPLETED (3) Return the number of rows inserted from our implementation of bulkInsert
                return rowsInserted;

//          COMPLETED (4) If the URI does match match CODE_WEATHER, return the super implementation of bulkInsert
            default:
                return super.bulkInsert(uri, values);
        }
    }
 
開發者ID:fjoglar,項目名稱:android-dev-challenge,代碼行數:54,代碼來源:WeatherProvider.java

示例8: testDuplicateDateInsertBehaviorShouldReplace

import android.content.ContentValues; //導入方法依賴的package包/類
/**
 * Tests to ensure that inserts into your database results in automatically incrementing row
 * IDs and that row IDs are not reused.
 * <p>
 * If the INTEGER PRIMARY KEY column is not explicitly given a value, then it will be filled
 * automatically with an unused integer, usually one more than the largest _ID currently in
 * use. This is true regardless of whether or not the AUTOINCREMENT keyword is used.
 * <p>
 * If the AUTOINCREMENT keyword appears after INTEGER PRIMARY KEY, that changes the automatic
 * _ID assignment algorithm to prevent the reuse of _IDs over the lifetime of the database.
 * In other words, the purpose of AUTOINCREMENT is to prevent the reuse of _IDs from previously
 * deleted rows.
 * <p>
 * To test this, we first insert a row into the database and get its _ID. Then, we'll delete
 * that row, change the data that we're going to insert, and insert the changed data into the
 * database again. If AUTOINCREMENT isn't set up properly in the WeatherDbHelper's table
 * create statement, then the _ID of the first insert will be reused. However, if AUTOINCREMENT
 * is setup properly, that older ID will NOT be reused, and the test will pass.
 */
@Test
public void testDuplicateDateInsertBehaviorShouldReplace() {

    /* Obtain weather values from TestUtilities */
    ContentValues testWeatherValues = TestUtilities.createTestWeatherContentValues();

    /*
     * Get the original weather ID of the testWeatherValues to ensure we use a different
     * weather ID for our next insert.
     */
    long originalWeatherId = testWeatherValues.getAsLong(REFLECTED_COLUMN_WEATHER_ID);

    /* Insert the ContentValues with old weather ID into database */
    database.insert(
            WeatherContract.WeatherEntry.TABLE_NAME,
            null,
            testWeatherValues);

    /*
     * We don't really care what this ID is, just that it is different than the original and
     * that we can use it to verify our "new" weather entry has been made.
     */
    long newWeatherId = originalWeatherId + 1;

    testWeatherValues.put(REFLECTED_COLUMN_WEATHER_ID, newWeatherId);

    /* Insert the ContentValues with new weather ID into database */
    database.insert(
            WeatherContract.WeatherEntry.TABLE_NAME,
            null,
            testWeatherValues);

    /* Query for a weather record with our new weather ID */
    Cursor newWeatherIdCursor = database.query(
            REFLECTED_TABLE_NAME,
            new String[]{REFLECTED_COLUMN_DATE},
            null,
            null,
            null,
            null,
            null);

    String recordWithNewIdNotFound =
            "New record did not overwrite the previous record for the same date.";
    assertTrue(recordWithNewIdNotFound,
            newWeatherIdCursor.getCount() == 1);

    /* Always close the cursor after you're done with it */
    newWeatherIdCursor.close();
}
 
開發者ID:fjoglar,項目名稱:android-dev-challenge,代碼行數:70,代碼來源:TestSunshineDatabase.java

示例9: findSelfInfo

import android.content.ContentValues; //導入方法依賴的package包/類
@Override
public CallerInfo findSelfInfo(Context ctxt) {
    
    
    CallerInfo callerInfo = new CallerInfo();

    String[] projection = new String[] {
                Profile._ID,
                Profile.DISPLAY_NAME,
                Profile.PHOTO_ID,
                Profile.PHOTO_URI
        };
    Cursor cursor = ctxt.getContentResolver().query(Profile.CONTENT_URI, projection, null, null, null);
    if(cursor != null) {
        try {
            if(cursor.getCount() > 0) {
                cursor.moveToFirst();
                
                ContentValues cv = new ContentValues();
                DatabaseUtils.cursorRowToContentValues(cursor, cv);
                callerInfo.contactExists = true;
                if(cv.containsKey(Profile.DISPLAY_NAME) ) {
                    callerInfo.name = cv.getAsString(Profile.DISPLAY_NAME);
                }
                

                if(cv.containsKey(Profile._ID) ) {
                    callerInfo.personId = cv.getAsLong(Profile._ID);
                    callerInfo.contactContentUri = ContentUris.withAppendedId(Contacts.CONTENT_URI, callerInfo.personId);
                }
                
                if(cv.containsKey(Profile.PHOTO_ID)) {
                    Long photoId = cv.getAsLong(Profile.PHOTO_ID);
                    if(photoId != null) {
                        callerInfo.photoId = photoId;
                    }
                }
                
                if(cv.containsKey(Profile.PHOTO_URI)) {
                    String photoUri = cv.getAsString(Profile.PHOTO_URI);
                    if(!TextUtils.isEmpty(photoUri)) {
                        callerInfo.photoUri = Uri.parse(photoUri);
                    }
                }

                if(callerInfo.name != null && callerInfo.name.length() == 0) {
                    callerInfo.name = null;
                }
                
            }
        }catch(Exception e) {
            Log.e(THIS_FILE, "Exception while retrieving cursor infos", e);
        }finally {
            cursor.close();
        }
    }
    
    
    return callerInfo;
}
 
開發者ID:treasure-lau,項目名稱:CSipSimple,代碼行數:61,代碼來源:ContactsUtils14.java

示例10: insertUnderTransaction

import android.content.ContentValues; //導入方法依賴的package包/類
private Uri insertUnderTransaction(SQLiteDatabase db, Uri uri, ContentValues contentValues) {
    long id, noteId;
    String table;
    Uri resultUri;

    switch (uris.matcher.match(uri)) {
        case ProviderUris.LOCAL_DB_REPO:
            table = DbDbRepo.TABLE;
            break;

        case ProviderUris.REPOS:
            id = DbRepo.insert(db, contentValues.getAsString(ProviderContract.Repos.Param.REPO_URL));
            return ContentUris.withAppendedId(uri, id);

        case ProviderUris.BOOKS:
            table = DbBook.TABLE;
            long bid = db.insertOrThrow(table, null, contentValues);
            insertRootNote(db, bid);
            return ContentUris.withAppendedId(uri, bid);

        case ProviderUris.FILTERS:
            table = DbSearch.TABLE;
            ProviderFilters.updateWithNextPosition(db, contentValues);
            break;

        case ProviderUris.NOTES:
            return insertNote(db, uri, contentValues, Place.UNSPECIFIED);

        case ProviderUris.NOTE_ABOVE:
            return insertNote(db, uri, contentValues, Place.ABOVE);

        case ProviderUris.NOTE_UNDER:
            return insertNote(db, uri, contentValues, Place.UNDER);

        case ProviderUris.NOTE_BELOW:
            return insertNote(db, uri, contentValues, Place.BELOW);

        case ProviderUris.NOTES_PROPERTIES:
            noteId = contentValues.getAsLong(ProviderContract.NoteProperties.Param.NOTE_ID);
            String name = contentValues.getAsString(ProviderContract.NoteProperties.Param.NAME);
            String value = contentValues.getAsString(ProviderContract.NoteProperties.Param.VALUE);
            int pos = contentValues.getAsInteger(ProviderContract.NoteProperties.Param.POSITION);

            long nameId = DbPropertyName.getOrInsert(db, name);
            long valueId = DbPropertyValue.getOrInsert(db, value);
            long propertyId = DbProperty.getOrInsert(db, nameId, valueId);
            long notePropertyId = DbNoteProperty.getOrInsert(db, noteId, pos, propertyId);

            return ContentUris.withAppendedId(uri, notePropertyId);

        case ProviderUris.LOAD_BOOK_FROM_FILE:
            resultUri = loadBookFromFile(contentValues);

            return resultUri;

        case ProviderUris.CURRENT_ROOKS:
            resultUri = insertCurrentRook(db, uri, contentValues);
            return resultUri;

        case ProviderUris.BOOKS_ID_SAVED:
            resultUri = bookSavedToRepo(db, uri, contentValues);
            return resultUri;

        default:
            throw new IllegalArgumentException("URI is not recognized: " + uri);
    }

    id = db.insertOrThrow(table, null, contentValues);

    return ContentUris.withAppendedId(uri, id);
}
 
開發者ID:orgzly,項目名稱:orgzly-android,代碼行數:72,代碼來源:Provider.java

示例11: testIntegerAutoincrement

import android.content.ContentValues; //導入方法依賴的package包/類
/**
     * Tests to ensure that inserts into your database results in automatically
     * incrementing row IDs.
>>>>>>> 4174cf2... S07.02-Exercise-PreventInvalidInserts
     */
    @Test
    public void testIntegerAutoincrement() {

        /* First, let's ensure we have some values in our table initially */
        testInsertSingleRecordIntoWeatherTable();

        /* Obtain weather values from TestUtilities */
        ContentValues testWeatherValues = TestUtilities.createTestWeatherContentValues();

        /* Get the date of the testWeatherValues to ensure we use a different date later */
        long originalDate = testWeatherValues.getAsLong(REFLECTED_COLUMN_DATE);

        /* Insert ContentValues into database and get a row ID back */
        long firstRowId = database.insert(
                REFLECTED_TABLE_NAME,
                null,
                testWeatherValues);

        /* Delete the row we just inserted to see if the database will reuse the rowID */
        database.delete(
                REFLECTED_TABLE_NAME,
                "_ID == " + firstRowId,
                null);

        /*
         * Now we need to change the date associated with our test content values because the
         * database policy is to replace identical dates on conflict.
         */
        long dayAfterOriginalDate = originalDate + TimeUnit.DAYS.toMillis(1);
        testWeatherValues.put(REFLECTED_COLUMN_DATE, dayAfterOriginalDate);

        /* Insert ContentValues into database and get another row ID back */
        long secondRowId = database.insert(
                REFLECTED_TABLE_NAME,
                null,
                testWeatherValues);

        String sequentialInsertsDoNotAutoIncrementId =
                "IDs were reused and shouldn't be if autoincrement is setup properly.";
        assertNotSame(sequentialInsertsDoNotAutoIncrementId,
                firstRowId, secondRowId);
    }
 
開發者ID:fjoglar,項目名稱:android-dev-challenge,代碼行數:48,代碼來源:TestSunshineDatabase.java


注:本文中的android.content.ContentValues.getAsLong方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。