目錄結構以下:java
java代碼>>
Book.java
BookActivity.java
BookAdapter.java
MainActivity.java
MyDatabaseHelper.java
UpdateBookActivity.java
layout>> activity_book.xml activity_main.xml activity_update_book.xml book_item.xml
Book.javaandroid
package com.example.p229; import java.io.Serializable; public class Book implements Serializable{ private int id; private String author; private double price; private int pages; private String name; public Book(int id, String author, double price, int pages, String name) { super(); this.id = id; this.author = author; this.price=price; this.pages = pages; this.name = name; } public Book(String author, double price, int pages, String name) { super(); this.author = author; this.price=price; this.pages = pages; this.name = name; } public Book() { super(); } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getAuthor() { return author; } public void setAuthor(String author) { this.author = author; } public int getPages() { return pages; } public void setPages(int pages) { this.pages = pages; } public String getName() { return name; } public void setName(String name) { this.name = name; } public double getPrice() { return price; } public void setPrice(double price) { this.price = price; } }
BookActivitysql
package com.example.p229; import android.content.DialogInterface; import android.content.Intent; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.preference.DialogPreference; import android.support.v7.app.AlertDialog; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.ButtonBarLayout; import android.util.Log; import android.view.View; import android.widget.AdapterView; import android.widget.Button; import android.widget.ListView; import android.widget.Toast; import java.util.ArrayList; import java.util.List; public class BookActivity extends AppCompatActivity { private List<Book> bookList = new ArrayList<>(); private ListView lv_book; private MyDatabaseHelper dbhelper; private Button data_clear; private BookAdapter adapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_book); dbhelper = new MyDatabaseHelper(this, "BookStore.db", null, 1); //給數據源賦值 initBooks(); //建立適配器 //獲取列表並設置適配器 lv_book = (ListView) findViewById(R.id.lv_book); if (adapter == null) { adapter = new BookAdapter(BookActivity.this, R.layout.book_item, bookList); lv_book.setAdapter(adapter); } else { adapter.notifyDataSetChanged(); } //短期選中該書觸發的事件———彈出修改對話框 lv_book.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { Book book = bookList.get(position); showBookInfoDialog(book); // Toast.makeText(BookActivity.this,book.getName(),Toast.LENGTH_SHORT).show(); } }); //長時間選中該書觸發的事件———彈出刪除對話框 lv_book.setOnItemLongClickListener(new AdapterView.OnItemLongClickListener() { @Override public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) { Book book = bookList.get(position); //Toast.makeText(BookActivity.this,book.getName(),Toast.LENGTH_SHORT).show(); showDeleteInfoDialog(book); return false; } }); data_clear = (Button) findViewById(R.id.data_clear); data_clear.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { clear(); } }); } @Override protected void onResume() { super.onResume(); initBooks(); } protected void showBookInfoDialog(final Book book) { AlertDialog.Builder dialog = new AlertDialog.Builder(this); dialog.setIcon(R.mipmap.ic_launcher); dialog.setTitle("圖書信息"); dialog.setMessage("" + "id:" + book.getId() + "\n做者:" + book.getAuthor() + "\n單價:" + book.getPrice() + "\n頁數:" + book.getPages() + "\n書名:" + book.getName() ); dialog.setPositiveButton("修改", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { //由當前活動跳轉到UpdateBookActivity活動,病傳遞數據book Intent intent=new Intent(BookActivity.this,UpdateBookActivity.class); intent.putExtra("book",book); startActivity(intent); } }); dialog.setNegativeButton("取消", null); dialog.show(); } protected void showDeleteInfoDialog(final Book book) { AlertDialog.Builder dialog = new AlertDialog.Builder(this); dialog.setIcon(R.mipmap.ic_launcher); dialog.setTitle("提示信息"); dialog.setMessage("請問您要刪除這條數據嗎"); dialog.setPositiveButton("確認", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { //刪除圖書,首先從數據課表中刪除,其次從集合中刪除,目的就是讓lv能同步顯示刪除後的狀態或結果 SQLiteDatabase db=dbhelper.getWritableDatabase(); int count=db.delete("Book","id=?",new String[]{book.getId()+""}); if(count!=0){ Toast.makeText(BookActivity.this, "數據庫中刪除成功!!", Toast.LENGTH_SHORT).show(); bookList.remove(book); adapter.notifyDataSetChanged(); } else{ Toast.makeText(BookActivity.this, "沒有刪除!!", Toast.LENGTH_SHORT).show(); } db.close(); } }); dialog.setNegativeButton("取消", null); dialog.show(); } public void clear() { SQLiteDatabase db = dbhelper.getWritableDatabase(); int count = db.delete("Book", null, null); if (count!= 0) { Toast.makeText(this, "數據庫表刪除成功!!", Toast.LENGTH_SHORT).show(); bookList.clear(); adapter.notifyDataSetChanged(); } else { Toast.makeText(this, "沒有內容能夠刪除!!", Toast.LENGTH_SHORT).show(); } db.close(); } private void initBooks() { SQLiteDatabase db = dbhelper.getWritableDatabase(); bookList.clear(); //給數據源賦值 Cursor cursor = db.query("Book", null, null, null, null, null, null); //2.進行遍歷 if (cursor.moveToFirst()) { do { // String name=cursor.getString(cursor.getColumnIndex("name")); // String author=cursor.getString(cursor.getColumnIndex("author")); // int pages=cursor.getInt(cursor.getColumnIndex("pages")); // int id=cursor.getInt(cursor.getColumnIndex("id")); // double price=cursor.getDouble(cursor.getColumnIndex("price")); //id列的索引號爲0 int id = cursor.getInt(0); String author = cursor.getString(cursor.getColumnIndex("author")); double price = cursor.getDouble(cursor.getColumnIndex("price")); int pages = cursor.getInt(cursor.getColumnIndex("pages")); String name = cursor.getString(cursor.getColumnIndex("name")); //Book book=new Book(id,author,price,pages,name); Book book = new Book(); book.setId(id); book.setName(name); book.setPages(pages); book.setPrice(price); book.setAuthor(author); bookList.add(book); } while (cursor.moveToNext()); } // 3.關閉遊標 cursor.close(); db.close(); } }
BookAdapter數據庫
package com.example.p229; import android.content.Context; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.ArrayAdapter; import android.widget.ImageView; import android.widget.TextView; import java.util.List; public class BookAdapter extends ArrayAdapter<Book> { private int resourceId; public BookAdapter(Context context, int resource, List<Book> objects) { super(context, resource, objects); resourceId = resource; } @Override public View getView(int position, View convertView, ViewGroup parent) { Book book = getItem(position); View view; ViewHolder viewHolder; if (convertView == null) { //是否有佈局緩存,否 view = LayoutInflater.from(getContext()).inflate(resourceId, parent, false); //建立viewHolder viewHolder = new ViewHolder(); //獲取ViewHolder的控件 viewHolder.bookId = (TextView) view.findViewById(R.id.book_id); viewHolder.bookAuthor = (TextView) view.findViewById(R.id.book_author); viewHolder.bookPrice = (TextView) view.findViewById(R.id.book_price); viewHolder.bookPages = (TextView) view.findViewById(R.id.book_pages); viewHolder.bookName = (TextView) view.findViewById(R.id.book_name); //將viewHolder對象存儲view中 view.setTag(viewHolder); } else { //有緩存 view = convertView; viewHolder = (ViewHolder) view.getTag(); } viewHolder.bookId.setText(book.getId() + ""); viewHolder.bookAuthor.setText(book.getAuthor() + ""); viewHolder.bookPrice.setText(book.getPrice() + ""); viewHolder.bookPages.setText(book.getPages() + ""); viewHolder.bookName.setText(book.getName() + ""); //fruitImage.setImageResource(fruit.getImageId()); // fruitname.setText(fruit.getName()); return view; } class ViewHolder { TextView bookId; TextView bookAuthor; TextView bookPrice; TextView bookPages; TextView bookName; } }
MainActivity緩存
package com.example.p229; import android.content.ContentValues; import android.content.Intent; import android.database.sqlite.SQLiteDatabase; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.EditText; import android.widget.Toast; public class MainActivity extends AppCompatActivity implements View.OnClickListener { private EditText author_et; private EditText price_et; private EditText pages_et; private EditText name_et; private Button insert_data; private Button query_data; private MyDatabaseHelper dbhelper; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); dbhelper = new MyDatabaseHelper(this, "BookStore.db", null, 1); dbhelper.getWritableDatabase(); author_et = (EditText) findViewById(R.id.author_et); price_et = (EditText) findViewById(R.id.price_et); pages_et = (EditText) findViewById(R.id.pages_et); name_et = (EditText) findViewById(R.id.name_et); insert_data = (Button) findViewById(R.id.add_data); insert_data.setOnClickListener(this); query_data = (Button) findViewById(R.id.query_data); query_data.setOnClickListener(this); } @Override public void onClick(View v) { switch (v.getId()) { case R.id.add_data: insertData(); break; case R.id.query_data: Intent intent = new Intent(MainActivity.this, BookActivity.class); startActivity(intent); break; } } private void insertData() { SQLiteDatabase db = dbhelper.getWritableDatabase(); ContentValues values = new ContentValues(); String author = author_et.getText().toString(); String name = name_et.getText().toString(); String price = price_et.getText().toString(); String pages = pages_et.getText().toString(); values.put("name", name); values.put("author", author); values.put("price", Double.parseDouble(price)); values.put("pages", Integer.parseInt(pages)); long count = db.insert("Book", null, values); if (count != -1) { Toast.makeText(this, "插入成功!!", Toast.LENGTH_SHORT).show(); author_et.setText(""); name_et.setText(""); price_et.setText(""); pages_et.setText(""); } else { Toast.makeText(this, "插入失敗!!", Toast.LENGTH_SHORT).show(); } db.close(); } }
MyDatabaseHelperapp
package com.example.p229; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.widget.Toast; /** * Created by user on 2019/4/27. */ public class MyDatabaseHelper extends SQLiteOpenHelper { public static final String CREATE_BOOK="create table Book(" +"id integer primary key autoincrement," + "author text," + "price real," + "pages integer," +"name text)"; private Context mContext; public MyDatabaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) { super(context, name, factory, version); mContext=context; } @Override public void onCreate(SQLiteDatabase db) { db.execSQL(CREATE_BOOK); Toast.makeText(mContext,"成功建表!!",Toast.LENGTH_SHORT).show(); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { } }
UpdateBookActivityide
package com.example.p229; import android.content.ContentValues; import android.content.Intent; import android.database.sqlite.SQLiteDatabase; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.text.TextUtils; import android.view.View; import android.widget.Button; import android.widget.EditText; import android.widget.Toast; public class UpdateBookActivity extends AppCompatActivity { private EditText update_author_et; private EditText update_price_et; private EditText update_pages_et; private EditText update_name_et; private MyDatabaseHelper dbhelper; private Book book; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_update_book); //第一步:獲取上一個活動傳遞過來的序列化book Intent intent=getIntent(); book=(Book)intent.getSerializableExtra("book"); //第二步:獲取控件並顯示數據 update_author_et=(EditText) findViewById(R.id.update_author_et); update_price_et=(EditText) findViewById(R.id.update_price_et); update_pages_et=(EditText) findViewById(R.id.update_pages_et); update_name_et=(EditText) findViewById(R.id.update_name_et); update_author_et.setText(book.getAuthor()); update_price_et.setText(book.getPrice()+""); update_pages_et.setText(book.getPages()+""); update_name_et.setText(book.getName()); dbhelper=new MyDatabaseHelper(this,"BookStore.db",null,1); } //按照頁面上從新輸入的信息去庫中修改該書 public void updateInfo(View view){ //獲取從新輸入的信息 String authorStr=update_author_et.getText().toString(); String nameStr=update_name_et.getText().toString(); String priceStr=update_price_et.getText().toString(); String pagesStr=update_pages_et.getText().toString(); //按照獲取的信息是否合法決定進行的操做 if(TextUtils.isEmpty(authorStr)||TextUtils.isEmpty(nameStr) ||TextUtils.isEmpty(pagesStr)||TextUtils.isEmpty(priceStr)){ Toast.makeText(this, "數據不完整,從新輸入!", Toast.LENGTH_SHORT).show(); } else { //打開數據庫 SQLiteDatabase db=dbhelper.getWritableDatabase(); ContentValues values=new ContentValues(); values.put("name",nameStr); values.put("author",authorStr); values.put("pages",Integer.parseInt(pagesStr)); values.put("price",Double.parseDouble(priceStr)); int count=db.update("Book",values,"id=?",new String[]{book.getId()+""}); if(count!=0){ Toast.makeText(this, "修改爲功!!", Toast.LENGTH_SHORT).show(); finish(); } else{ Toast.makeText(this, "修改失敗!!", Toast.LENGTH_SHORT).show(); } db.close(); } } //關閉頁面 public void cancel(View view){ finish(); } }
activity_book.xml佈局
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" > <Button android:id="@+id/data_clear" android:text="清空" android:layout_width="match_parent" android:layout_height="wrap_content" /> <LinearLayout android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content"> <TextView android:text="id" android:layout_weight="1" android:layout_width="0dp" android:layout_height="wrap_content" /> <TextView android:text="name" android:layout_weight="1" android:layout_width="0dp" android:layout_height="wrap_content" /> <TextView android:text="price" android:layout_weight="1" android:layout_width="0dp" android:layout_height="wrap_content" /> <TextView android:text="author" android:layout_weight="1" android:layout_width="0dp" android:layout_height="wrap_content" /> <TextView android:text="pages" android:layout_weight="1" android:layout_width="0dp" android:layout_height="wrap_content" /> </LinearLayout> <ListView android:id="@+id/lv_book" android:layout_width="match_parent" android:layout_height="wrap_content"></ListView> </LinearLayout>
activity_main.xmlui
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context="com.example.p229.MainActivity"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:text="做者" android:textSize="18dp" /> <EditText android:id="@+id/author_et" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="4" android:hint="輸入做者" /> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:text="單價" android:textSize="18dp" /> <EditText android:id="@+id/price_et" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="4" android:hint="輸入單價" /> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:text="頁數" android:textSize="18dp" /> <EditText android:id="@+id/pages_et" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="4" android:hint="輸入頁數" /> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <TextView android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:text="書名" android:textSize="18dp" /> <EditText android:id="@+id/name_et" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="4" android:hint="輸入書名" /> </LinearLayout> <Button android:id="@+id/add_data" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="添加記錄" /> <Button android:id="@+id/query_data" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="顯示數據庫信息" /> </LinearLayout>
activity_update_book.xmlthis
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_update_book" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context="com.example.p229.UpdateBookActivity"> <LinearLayout android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content"> <TextView android:text="做者" android:textSize="18dp" android:layout_width="0dp" android:layout_weight="1" android:layout_height="wrap_content" /> <EditText android:id="@+id/update_author_et" android:layout_width="0dp" android:layout_weight="4" android:layout_height="wrap_content" /> </LinearLayout> <LinearLayout android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content"> <TextView android:text="單價" android:textSize="18dp" android:layout_width="0dp" android:layout_weight="1" android:layout_height="wrap_content" /> <EditText android:id="@+id/update_price_et" android:layout_width="0dp" android:layout_weight="4" android:layout_height="wrap_content" /> </LinearLayout> <LinearLayout android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content"> <TextView android:text="頁數" android:textSize="18dp" android:layout_width="0dp" android:layout_weight="1" android:layout_height="wrap_content" /> <EditText android:id="@+id/update_pages_et" android:layout_width="0dp" android:layout_weight="4" android:layout_height="wrap_content" /> </LinearLayout> <LinearLayout android:orientation="horizontal" android:layout_width="match_parent" android:layout_height="wrap_content"> <TextView android:text="書名" android:textSize="18dp" android:layout_width="0dp" android:layout_weight="1" android:layout_height="wrap_content" /> <EditText android:id="@+id/update_name_et" android:layout_width="0dp" android:layout_weight="4" android:layout_height="wrap_content" /> </LinearLayout> <Button android:onClick="updateInfo" android:textSize="18sp" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="修改" /> <Button android:onClick="cancel" android:textSize="18sp" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="取消" /> </LinearLayout>
book_item.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:id="@+id/book_id" android:layout_weight="1" android:layout_width="0dp" android:layout_height="wrap_content" /> <TextView android:id="@+id/book_name" android:layout_weight="1" android:layout_width="0dp" android:layout_height="wrap_content" /> <TextView android:id="@+id/book_price" android:layout_weight="1" android:layout_width="0dp" android:layout_height="wrap_content" /> <TextView android:id="@+id/book_author" android:layout_weight="1" android:layout_width="0dp" android:layout_height="wrap_content" /> <TextView android:id="@+id/book_pages" android:layout_weight="1" android:layout_width="0dp" android:layout_height="wrap_content" /> </LinearLayout>
完!