我正在学习使用Android中的数据库。似乎无法让它发挥作用。 我已经提供了Log(最后)以帮助您更好地理解。
这是我的 dbHadler.java
XJ
这是我的 Activity_Main.java
package todo.do2.com.todo;
import java.util.ArrayList;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;
public class dbHandler extends SQLiteOpenHelper{
//VERSION
private static final int DATABASE_VERSION = 1;
//NAME
private static final String DATABASE_NAME = "Mydb";
//DATABASE TABLE NAME
private static final String TABLE_LIST = "Mylist";
//TABLE COLUMN NAMES
private static final String KEY_ID = "id";
private static final String KEY_ListItem = "listitems";
public dbHandler(Context context) {
super(context,DATABASE_NAME,null,DATABASE_VERSION);
}
//CREATING TABLES
@Override
public void onCreate(SQLiteDatabase db) {
String CREATE_LIST_TABLE = "CREATE TABLE " + TABLE_LIST + "(" + KEY_ID + " INTEGER," + KEY_ListItem + " TEXT" + ")";
db.execSQL(CREATE_LIST_TABLE);
}
//UPGRADING DATABASE
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion,int newVersion){
//drop old table if exist
db.execSQL("DROP TABLE IF EXIST" + TABLE_LIST);
onCreate(db);
}
void addListItem(ArrayList<String> listitems) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
for (int i = 1; i < listitems.size(); i++)
{
Log.e("Value inserting == ","" + listitems.get(i));
db.insert(TABLE_LIST,null,values);
}
db.close(); //closing database connection
}
Cursor getListItem() {
String selectQuery = "SELECT * FROM " + TABLE_LIST;
SQLiteDatabase db = this.getWritableDatabase();
Cursor cursor = db.rawQuery(selectQuery,null);
return cursor;
}
}
这是我的 activity_main.xml
package todo.do2.com.todo;
import android.support.design.widget.FloatingActionButton;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.ListView;
import java.util.ArrayList;
import android.database.Cursor;
import android.util.Log;
public class MainActivity extends AppCompatActivity {
FloatingActionButton btn;
ListView list;
EditText editText;
ArrayList<String> listItems;
ArrayAdapter<String> adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
editText = (EditText) findViewById(R.id.edit);
btn = (FloatingActionButton) findViewById(R.id.addBtn);
list = (ListView) findViewById(R.id.list);
listItems = new ArrayList<>();
listItems.add("Welcome");
listItems.add("second");
adapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, listItems);
list.setAdapter(adapter);
dbHandler db = new dbHandler(this);
db.addListItem(listItems);
Cursor cursor = db.getListItem();
Log.e("count", " " + cursor.getCount());
if(cursor != null)
{
cursor.moveToNext();
do{
Log.e("values == ", "" + cursor.getString(1));
}while(cursor.moveToNext());
}
}
}
这是生成的日志
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingEnd="@dimen/activity_vertical_margin"
android:paddingStart="@dimen/activity_vertical_margin"
android:isScrollContainer="false">
<android.support.design.widget.FloatingActionButton
android:id="@+id/addBtn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentEnd="true"
android:layout_marginLeft="12dp"
android:layout_marginStart="12dp"
android:layout_marginBottom="12dp"
android:clickable="true"
android:onClick="addItems"
app:fabSize="normal"
android:isScrollContainer="true"/>
<EditText
android:id="@+id/edit"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentStart="true"
android:layout_marginTop="18dp"
android:layout_marginBottom="12dp"
android:layout_toLeftOf="@+id/addBtn"
android:hint="Add New Item"
android:isScrollContainer="true"/>
<ListView
android:id="@+id/list"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_above="@+id/edit"
android:drawSelectorOnTop="false"
android:scrollbars="none"
android:isScrollContainer="false"/>
答案 0 :(得分:1)
我认为这是问题
ContentValues values = new ContentValues();
for (int i = 1; i < listitems.size(); i++)
{
Log.e("Value inserting == ","" + listitems.get(i));
db.insert(TABLE_LIST,null,values);
}
values
始终为空
试试这个
for (int i = 1; i < listitems.size(); i++)
{
Log.e("Value inserting == ","" + listitems.get(i));
values.put(KEY_ID,i);
values.put(KEY_ListItem,listitems.get(i));
db.insert(TABLE_LIST,null,values);
}