STEP-1 : DBConnection
package jcb.heavyvehicle.app.com.jcb.adapter;
import android.content.Context;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import android.database.sqlite.SQLiteOpenHelper;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
public class DBConnectionClass extends SQLiteOpenHelper {
private static String DB_NAME = "dbJCB18";
private SQLiteDatabase myDataBase;
private final Context myContext;
private static String DB_PATH= "";
public DBConnectionClass(Context context) {
super(context, DB_NAME, null, 1);
this.myContext = context;
DB_PATH=myContext.getApplicationInfo().dataDir + "/databases/";
}
public void createDataBase() throws IOException {
boolean dbExist = checkDataBase();
if(dbExist){
//do nothing - database already exist
}else{
//By calling this method and empty database will be created into the default system path
//of your application so we are gonna be able to overwrite that database with our database.
// this.getReadableDatabase();
this.getWritableDatabase();
try {
copyDataBase();
} catch (IOException e) {
throw new Error("Error copying database");
}
}
}
/**
* Check if the database already exist to avoid re-copying the file each time you open the application.
* @return true if it exists, false if it doesn't
*/
private boolean checkDataBase(){
SQLiteDatabase checkDB = null;
try{
String myPath = DB_PATH + DB_NAME;
checkDB = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READWRITE);
}catch(SQLiteException e){
}
if(checkDB != null){
checkDB.close();
}
return checkDB != null;
}
private void copyDataBase() throws IOException{
//Open your local db as the input stream
InputStream myInput = myContext.getAssets().open("dbJCB18.sqlite");
// Path to the just created empty db
String outFileName = DB_PATH + DB_NAME;
//Open the empty db as the output stream
OutputStream myOutput = new FileOutputStream(outFileName);
//transfer bytes from the inputfile to the outputfile
byte[] buffer = new byte[1024];
int length;
while ((length = myInput.read(buffer))>0){
myOutput.write(buffer, 0, length);
}
//Close the streams
myOutput.flush();
myOutput.close();
myInput.close();
}
public void openDataBase() throws SQLException {
//Open the database
String myPath = DB_PATH + DB_NAME;
// myDataBase = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READONLY);
myDataBase = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READWRITE);
}
@Override
public synchronized void close() {
if(myDataBase != null)
myDataBase.close();
super.close();
}
@Override
public void onCreate(SQLiteDatabase db) {
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
// Add your public helper methods to access and get content from the database.
// You could return cursors by doing "return myDataBase.query(....)" so it'd be easy
// to you to create adapters for your views.
}
STEP-2 : DBAdapter
package jcb.heavyvehicle.app.com.jcb.adapter;
/**
* Created by Cyber Matrix3 on 11/18/2016.
*/
import android.content.ContentValues;
import android.content.Context;
import android.content.DialogInterface;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.support.v7.app.AlertDialog;
import android.util.Log;
import java.io.IOException;
import java.util.ArrayList;
import jcb.heavyvehicle.app.com.jcb.pojo.BannerPojo;
import jcb.heavyvehicle.app.com.jcb.pojo.CategoryPojo;
import jcb.heavyvehicle.app.com.jcb.pojo.ProductPojo;
import jcb.heavyvehicle.app.com.jcb.pojo.ProjectUpdatePojo;
import jcb.heavyvehicle.app.com.jcb.pojo.AppDescMasterPojo;
public class DBAdapterClass {
protected static final String TAG = "DataAdapter";
private final Context mContext;
private SQLiteDatabase mDb;
private DBConnectionClass mDbHelper;
public DBAdapterClass(Context context) {
this.mContext = context;
mDbHelper = new DBConnectionClass(mContext);
}
public DBAdapterClass createDatabase() throws SQLException {
try {
mDbHelper.createDataBase();
} catch (IOException mIOException) {
Log.e(TAG, mIOException.toString() + " UnableToCreateDatabase");
throw new Error("UnableToCreateDatabase");
}
return this;
}
public DBAdapterClass open() throws SQLException {
try {
mDbHelper.openDataBase();
mDbHelper.close();
//mDb = mDbHelper.getReadableDatabase();
mDb = mDbHelper.getWritableDatabase();
} catch (SQLException mSQLException) {
Log.e(TAG, "open >>" + mSQLException.toString());
throw mSQLException;
}
return this;
}
public void close() {
mDbHelper.close();
}
// --- QUERY BELOW
// PROJECT UPDATE SECTION
public ArrayList<ProjectUpdatePojo> getProjectUpdateData()
{
ArrayList<ProjectUpdatePojo> arrayListProjectUpdate = new ArrayList<>();
try {
String sql = "SELECT * FROM tblUpdate";
Cursor mCur = mDb.rawQuery(sql, null);
if (mCur != null) {
mCur.moveToNext();
}
while (mCur.isAfterLast() == false) {
String table_name = mCur.getString(mCur.getColumnIndex("table_name"));
String last_update_date = mCur.getString(mCur.getColumnIndex("last_update_date"));
ProjectUpdatePojo productUpdatePojo = new ProjectUpdatePojo(table_name,last_update_date);
arrayListProjectUpdate.add(productUpdatePojo);
mCur.moveToNext();
}
}catch (SQLException se)
{
Log.e(TAG,"Error : "+se, se);
}
return arrayListProjectUpdate;
}
// SPLASH SCREEN SECTION
public ArrayList<AppDescMasterPojo> getSplashData() {
ArrayList<AppDescMasterPojo> splashArrList = new ArrayList<>();
try {
String sql = "select msg_data from tbl_splash_screen";
Cursor mCur = mDb.rawQuery(sql, null);
if (mCur != null) {
mCur.moveToNext();
}
while (mCur.isAfterLast() == false) {
String data = mCur.getString(mCur.getColumnIndex("msg_data"));
AppDescMasterPojo splashMasterPojo = new AppDescMasterPojo(data);
splashArrList.add(splashMasterPojo);
mCur.moveToNext();
}
}catch (SQLException mSQLException)
{
Log.e(TAG," SQL Error"+mSQLException, mSQLException );
}
return splashArrList;
}
// OFFER SECTION
public ArrayList<BannerPojo> getBannerData()
{
ArrayList<BannerPojo> bannerAL = new ArrayList<>();
try {
String sql = "select * from tblOfferBanner";
Cursor mCur = mDb.rawQuery(sql, null);
if (mCur != null) {
mCur.moveToNext();
}
while (mCur.isAfterLast() == false) {
String bannerImgDir = mCur.getString(mCur.getColumnIndex("offer_img_dir"));
String bannerImg = mCur.getString(mCur.getColumnIndex("offer_img"));
BannerPojo bannerPojo = new BannerPojo(bannerImgDir, bannerImg);
bannerAL.add(bannerPojo);
mCur.moveToNext();
}
}catch (SQLException se)
{
Log.e(TAG, "Error"+se, se);
}
return bannerAL;
}
public void updateOfferTable(String dir, String image, String date)
{
try
{
ContentValues cv = new ContentValues();
// cv.put("id", 3);
// insert into tblOfferBanner (offer_img_dir, offer_img,last_update_date) values
cv.put("offer_img_dir", dir);
cv.put("offer_img", image);
// cv.put("last_update_date", date);
// cv.put("Mobile", arr.get(i).mobile);
mDb.insert("tblOfferBanner", null, cv);
}catch (SQLException se)
{
new AlertDialog.Builder(mContext)
.setTitle("OfferTable Update")
.setMessage("Something went wromg!")
.setNegativeButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
}
})
.show();
}
}
public void deleteOfferTable()
{
try
{
mDb.delete("tblOfferBanner",null,null);
}catch (SQLException se)
{
Log.e(TAG, "Error : "+se,se);
}
}
// --- CATEGORY SECTION
public ArrayList<CategoryPojo> getCategoryData()
{
ArrayList<CategoryPojo> arrayListCategory = new ArrayList<>();
try {
String sql = "SELECT * FROM tblCategory";
Cursor mCur = mDb.rawQuery(sql, null);
if (mCur != null) {
mCur.moveToNext();
}
while (mCur.isAfterLast() == false) {
// int category_id = mCur.getInt(mCur.getColumnIndex("category_id"));
String category_name = mCur.getString(mCur.getColumnIndex("category_name"));
String category_dir = mCur.getString(mCur.getColumnIndex("category_dir"));
String category_img = mCur.getString(mCur.getColumnIndex("category_img"));
CategoryPojo categoryPojo = new CategoryPojo(0, category_name, category_dir, category_img);
arrayListCategory.add(categoryPojo);
mCur.moveToNext();
}
}catch (SQLException se)
{
Log.e(TAG,"Error : "+se, se);
}
return arrayListCategory;
}
public ArrayList<CategoryPojo> getCategoryIdData(int id)
{
ArrayList<CategoryPojo> arrayListProduct = new ArrayList<>();
try {
String sql = "SELECT category_id FROM tblCategory where id='"+id+"'";
Cursor mCur = mDb.rawQuery(sql, null);
if (mCur != null) {
mCur.moveToNext();
}
while (mCur.isAfterLast() == false) {
int category_id = mCur.getInt(mCur.getColumnIndex("category_id"));
CategoryPojo categoryPojo = new CategoryPojo(category_id, null, null, null);
arrayListProduct.add(categoryPojo);
mCur.moveToNext();
}
}catch (SQLException se)
{
Log.e(TAG,"Error : "+se, se);
}
return arrayListProduct;
}
public void updateCategoryTable(String categoryID, String categoryName,String categoryImage,String categoryDir, String date)
{
try
{
ContentValues cv = new ContentValues();
cv.put("category_id", categoryID);
cv.put("category_name", categoryName);
cv.put("category_img", categoryImage);
cv.put("category_dir", categoryDir);
// cv.put("last_update_date", date);
// cv.put("Mobile", arr.get(i).mobile);
mDb.insert("tblCategory", null, cv);
}catch (SQLException se)
{
new AlertDialog.Builder(mContext)
.setTitle("OfferTable Update")
.setMessage("Something went wromg!")
.setNegativeButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
}
})
.show();
}
}
public void deleteCategoryTable()
{
try
{
mDb.delete("tblCategory",null,null);
// mDb.close();
/*String sql = "DELETE FROM tblOfferBanner";
Cursor cursor = mDb.rawQuery(sql,null);*/
}catch (SQLException se)
{
new AlertDialog.Builder(mContext)
.setTitle("Category Table Refreshing")
.setMessage("Something went wromg!")
.setNegativeButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
}
})
.show();
}
}
// ---- PRODUCT SECTION
public ArrayList<ProductPojo> getProductData(int cate_id)
{
ArrayList<ProductPojo> arrayListProduct = new ArrayList<>();
try {
String sql = "SELECT * FROM tblProduct where category_id='"+cate_id+"'";
Cursor mCur = mDb.rawQuery(sql, null);
if (mCur != null) {
mCur.moveToNext();
}
while (mCur.isAfterLast() == false) {
String product_name = mCur.getString(mCur.getColumnIndex("product_name"));
String product_dir = mCur.getString(mCur.getColumnIndex("product_dir"));
String product_img = mCur.getString(mCur.getColumnIndex("product_img"));
ProductPojo productPojo = new ProductPojo(0, product_name, product_dir, product_img,null);
arrayListProduct.add(productPojo);
mCur.moveToNext();
}
}catch (SQLException se)
{
Log.e(TAG,"Error : "+se, se);
}
return arrayListProduct;
}
public void updateProductTable(String categoryID, String productName,String productImage,String productUrl, String productDir, String date)
{
try
{
ContentValues cv = new ContentValues();
cv.put("category_id", categoryID);
cv.put("product_name", productName);
cv.put("product_img", productImage);
cv.put("product_url", productUrl);
cv.put("product_dir", productDir);
// cv.put("last_update_date", date);
// cv.put("Mobile", arr.get(i).mobile);
mDb.insert("tblProduct", null, cv);
}catch (SQLException se)
{
new AlertDialog.Builder(mContext)
.setTitle("OfferTable Update")
.setMessage("Something went wromg!")
.setNegativeButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
}
})
.show();
}
}
public void deleteProductTable()
{
try
{
mDb.delete("tblProduct",null,null);
// mDb.close();
/*String sql = "DELETE FROM tblOfferBanner";
Cursor cursor = mDb.rawQuery(sql,null);*/
}catch (SQLException se)
{
new AlertDialog.Builder(mContext)
.setTitle("Product Table Refreshing")
.setMessage("Something went wromg!")
.setNegativeButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
}
})
.show();
}
}
// -------- project update
public void projectOfferUpdate(String offer_date)
{
try
{
ContentValues cv = new ContentValues();
// cv.put("id", 3);
// insert into tblOfferBanner (offer_img_dir, offer_img,last_update_date) values
cv.put("last_update_date", offer_date);
mDb.update("tblUpdate", cv, "table_name='offer_update'", null);
/* insert(String table, String nullColumnHack, ContentValues values)
Convenience method for inserting a row into the database.
update(String table, ContentValues values, String whereCl-ause, String[] whereArgs)
Convenience method for updating rows in the database.*/
}catch (SQLException se)
{
new AlertDialog.Builder(mContext)
.setTitle("OfferTable Update")
.setMessage("Something went wromg!")
.setNegativeButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
}
})
.show();
}
}
public void projectProductUpdate(String product_date)
{
try
{
ContentValues cv = new ContentValues();
// cv.put("id", 3);
// insert into tblOfferBanner (offer_img_dir, offer_img,last_update_date) values
cv.put("last_update_date", product_date);
mDb.update("tblUpdate",cv,"table_name='product_update'",null);
/* insert(String table, String nullColumnHack, ContentValues values)
Convenience method for inserting a row into the database.
update(String table, ContentValues values, String whereClause, String[] whereArgs)
Convenience method for updating rows in the database.*/
}catch (SQLException se)
{
new AlertDialog.Builder(mContext)
.setTitle("ProductTable Update")
.setMessage("Something went wromg!")
.setNegativeButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
}
})
.show();
}
}
public ArrayList<ProductPojo> getProductKnowMoreData(String prodName)
{
ArrayList<ProductPojo> arrayListProduct = new ArrayList<>();
try {
String sql = "SELECT product_url FROM tblProduct where product_name='"+prodName+"'";
Cursor mCur = mDb.rawQuery(sql, null);
if (mCur != null) {
mCur.moveToNext();
}
while (mCur.isAfterLast() == false) {
String product_url = mCur.getString(mCur.getColumnIndex("product_url"));
ProductPojo productPojo = new ProductPojo(0,null,null,null,product_url);
arrayListProduct.add(productPojo);
mCur.moveToNext();
}
}catch (SQLException se)
{
Log.e(TAG,"Error : "+se, se);
}
return arrayListProduct;
}
}
22