Android Open Source - LitePal Update Sample Activity






From Project

Back to project page LitePal.

License

The source code is released under:

Apache License

If you think the Android project LitePal listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.

Java Source Code

/*
 * Copyright (C)  Tony Green, Litepal Framework Open Source Project
 *//ww  w  .  ja  va 2  s.  c om
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.litepal.litepalsample.activity;

import java.util.ArrayList;
import java.util.List;

import org.litepal.litepalsample.R;
import org.litepal.litepalsample.adapter.DataArrayAdapter;
import org.litepal.litepalsample.model.Singer;
import org.litepal.tablemanager.Connector;

import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.database.Cursor;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.ProgressBar;
import android.widget.Toast;

public class UpdateSampleActivity extends Activity implements OnClickListener {

  private EditText mSingerIdEdit;

  private EditText mSingerNameEdit;

  private EditText mSingerAgeEdit;

  private EditText mNameToUpdateEdit;

  private EditText mAgeToUpdateEdit;

  private ProgressBar mProgressBar;

  private Button mUpdateBtn1;

  private Button mUpdateBtn2;

  private ListView mDataListView;

  private DataArrayAdapter mAdapter;

  private List<List<String>> mList = new ArrayList<List<String>>();

  public static void actionStart(Context context) {
    Intent intent = new Intent(context, UpdateSampleActivity.class);
    context.startActivity(intent);
  }

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.update_sample_layout);
    mProgressBar = (ProgressBar) findViewById(R.id.progress_bar);
    mSingerIdEdit = (EditText) findViewById(R.id.singer_id_edit);
    mSingerNameEdit = (EditText) findViewById(R.id.singer_name_edit);
    mSingerAgeEdit = (EditText) findViewById(R.id.singer_age_edit);
    mNameToUpdateEdit = (EditText) findViewById(R.id.name_to_update);
    mAgeToUpdateEdit = (EditText) findViewById(R.id.age_to_update);
    mUpdateBtn1 = (Button) findViewById(R.id.update_btn1);
    mUpdateBtn2 = (Button) findViewById(R.id.update_btn2);
    mDataListView = (ListView) findViewById(R.id.data_list_view);
    mUpdateBtn1.setOnClickListener(this);
    mUpdateBtn2.setOnClickListener(this);
    mAdapter = new DataArrayAdapter(this, 0, mList);
    mDataListView.setAdapter(mAdapter);
    populateDataFromDB();
  }

  @Override
  public void onClick(View v) {
    switch (v.getId()) {
    case R.id.update_btn1:
      try {
        Singer singer = new Singer();
        singer.setName(mSingerNameEdit.getText().toString());
        singer.setAge(Integer.parseInt(mSingerAgeEdit.getText().toString()));
        int rowsAffected = singer
            .update(Long.parseLong(mSingerIdEdit.getText().toString()));
        Toast.makeText(
            this,
            String.format(getString(R.string.number_of_rows_affected),
                String.valueOf(rowsAffected)), Toast.LENGTH_SHORT).show();
        populateDataFromDB();
      } catch (Exception e) {
        e.printStackTrace();
        Toast.makeText(this, getString(R.string.error_param_is_not_valid),
            Toast.LENGTH_SHORT).show();
      }
      break;
    case R.id.update_btn2:
      try {
        Singer singer = new Singer();
        singer.setName(mSingerNameEdit.getText().toString());
        singer.setAge(Integer.parseInt(mSingerAgeEdit.getText().toString()));
        int rowsAffected = singer.updateAll("name=? and age=?", mNameToUpdateEdit.getText()
            .toString(), mAgeToUpdateEdit.getText().toString());
        Toast.makeText(
            this,
            String.format(getString(R.string.number_of_rows_affected),
                String.valueOf(rowsAffected)), Toast.LENGTH_SHORT).show();
        populateDataFromDB();
      } catch (Exception e) {
        e.printStackTrace();
        Toast.makeText(this, getString(R.string.error_param_is_not_valid),
            Toast.LENGTH_SHORT).show();
      }
      break;
    default:
      break;
    }
  }

  private void populateDataFromDB() {
    mProgressBar.setVisibility(View.VISIBLE);
    new Thread(new Runnable() {
      @Override
      public void run() {
        mList.clear();
        List<String> columnList = new ArrayList<String>();
        columnList.add("id");
        columnList.add("name");
        columnList.add("age");
        columnList.add("ismale");
        mList.add(columnList);
        Cursor cursor = null;
        try {
          cursor = Connector.getDatabase().rawQuery("select * from singer order by id",
              null);
          if (cursor.moveToFirst()) {
            do {
              long id = cursor.getLong(cursor.getColumnIndex("id"));
              String name = cursor.getString(cursor.getColumnIndex("name"));
              int age = cursor.getInt(cursor.getColumnIndex("age"));
              int isMale = cursor.getInt(cursor.getColumnIndex("ismale"));
              List<String> stringList = new ArrayList<String>();
              stringList.add(String.valueOf(id));
              stringList.add(name);
              stringList.add(String.valueOf(age));
              stringList.add(String.valueOf(isMale));
              mList.add(stringList);
            } while (cursor.moveToNext());
          }
        } catch (Exception e) {
          e.printStackTrace();
        } finally {
          if (cursor != null) {
            cursor.close();
          }
          runOnUiThread(new Runnable() {
            @Override
            public void run() {
              mProgressBar.setVisibility(View.GONE);
              mAdapter.notifyDataSetChanged();
            }
          });
        }
      }
    }).start();
  }

}




Java Source Code List

org.litepal.LitePalApplication.java
org.litepal.LitePalBase.java
org.litepal.crud.AssociationsAnalyzer.java
org.litepal.crud.ClusterQuery.java
org.litepal.crud.DataHandler.java
org.litepal.crud.DataSupport.java
org.litepal.crud.DeleteHandler.java
org.litepal.crud.DynamicExecutor.java
org.litepal.crud.Many2ManyAnalyzer.java
org.litepal.crud.Many2OneAnalyzer.java
org.litepal.crud.One2OneAnalyzer.java
org.litepal.crud.QueryHandler.java
org.litepal.crud.SaveHandler.java
org.litepal.crud.UpdateHandler.java
org.litepal.crud.model.AssociationsInfo.java
org.litepal.exceptions.DataSupportException.java
org.litepal.exceptions.DatabaseGenerateException.java
org.litepal.exceptions.GlobalException.java
org.litepal.exceptions.InvalidAttributesException.java
org.litepal.exceptions.ParseConfigurationFileException.java
org.litepal.litepalsample.activity.AggregateActivity.java
org.litepal.litepalsample.activity.AverageSampleActivity.java
org.litepal.litepalsample.activity.CRUDActivity.java
org.litepal.litepalsample.activity.CountSampleActivity.java
org.litepal.litepalsample.activity.DeleteSampleActivity.java
org.litepal.litepalsample.activity.MainActivity.java
org.litepal.litepalsample.activity.ManageTablesActivity.java
org.litepal.litepalsample.activity.MaxSampleActivity.java
org.litepal.litepalsample.activity.MinSampleActivity.java
org.litepal.litepalsample.activity.ModelListActivity.java
org.litepal.litepalsample.activity.ModelStructureActivity.java
org.litepal.litepalsample.activity.QuerySampleActivity.java
org.litepal.litepalsample.activity.SaveSampleActivity.java
org.litepal.litepalsample.activity.SumSampleActivity.java
org.litepal.litepalsample.activity.TableListActivity.java
org.litepal.litepalsample.activity.TableStructureActivity.java
org.litepal.litepalsample.activity.UpdateSampleActivity.java
org.litepal.litepalsample.adapter.DataArrayAdapter.java
org.litepal.litepalsample.adapter.StringArrayAdapter.java
org.litepal.litepalsample.model.Album.java
org.litepal.litepalsample.model.Singer.java
org.litepal.litepalsample.model.Song.java
org.litepal.litepalsample.util.Utility.java
org.litepal.model.Table_Schema.java
org.litepal.parser.LitePalAttr.java
org.litepal.parser.LitePalContentHandler.java
org.litepal.parser.LitePalParser.java
org.litepal.tablemanager.AssociationCreator.java
org.litepal.tablemanager.AssociationUpdater.java
org.litepal.tablemanager.Connector.java
org.litepal.tablemanager.Creator.java
org.litepal.tablemanager.Dropper.java
org.litepal.tablemanager.Generator.java
org.litepal.tablemanager.LitePalOpenHelper.java
org.litepal.tablemanager.Upgrader.java
org.litepal.tablemanager.model.AssociationsModel.java
org.litepal.tablemanager.model.TableModel.java
org.litepal.tablemanager.typechange.BooleanOrm.java
org.litepal.tablemanager.typechange.DateOrm.java
org.litepal.tablemanager.typechange.DecimalOrm.java
org.litepal.tablemanager.typechange.NumericOrm.java
org.litepal.tablemanager.typechange.OrmChange.java
org.litepal.tablemanager.typechange.TextOrm.java
org.litepal.util.BaseUtility.java
org.litepal.util.Const.java
org.litepal.util.DBUtility.java
org.litepal.util.LogUtil.java
org.litepal.util.SharedUtil.java