我在android中创建了一个带有单个活动的项目,我想通过按下“插入按钮”向数据库添加一条新记录,如图所示,但我希望新记录保存到数据库后,ListView更新并将添加的记录显示在最后一个位置的列表中......
当我运行此代码时发生意外错误并关闭 哪里有错误或任何建议......
我把所有的代码和布局放在这里......
MainActivity.java
package com.example.db;
import java.util.ArrayList;
import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
import android.widget.Toast;
public class MainActivity extends Activity implements OnClickListener {
Button Btninser;
SQLiteDatabase db;
EditText etName, etPhone;
ListView lv;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
etName = (EditText) findViewById(R.id.etName);
etPhone = (EditText) findViewById(R.id.etPhone);
Btninsert = (Button) findViewById(R.id.btnInsert);
lv = (ListView) findViewById(R.id.listView1);
Btninsert.setOnClickListener(this);
Open_Create();
}
public void Open_Create() {
db = openOrCreateDatabase("MyDB1", MODE_PRIVATE, null);
db.execSQL("CREATE TABLE IF NOT EXISTS MyTable (_id INTEGER PRIMARY KEY AUTOINCREMENT, LastName VARCHAR,Phone VARCHAR);");
}
public void Insert_Info() {
db.execSQL("INSERT INTO MyTable (LastName,Phone) VALUES('" + etName.getText().toString()
+ "','" + etPhone.getText().toString() + "');");
Populate_ListView();
// db.close();
Toast.makeText(this, "Data has been saved!", Toast.LENGTH_LONG).show();
}
public void Populate_ListView() {
Cursor cursor = db.rawQuery("SELECT LastName,Phone FROM MyTable", null);
startManagingCursor(cursor);
String[] from = new String[] { "LastName", "Phone" };
int[] to = new int[] { R.id.tvItemListName, R.id.tvItemListPhone };
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this,
R.layout.item_list, cursor, from, to);
lv.setAdapter(adapter);
}
这是XML文件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:text="Name" />
<EditText
android:id="@+id/etName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_toRightOf="@+id/textView1"
android:ems="10" >
<requestFocus />
</EditText>
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:text="Phone" />
<EditText
android:id="@+id/etPhone"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_toRightOf="@+id/textView1"
android:ems="10" >
</EditText>
<Button
android:id="@+id/btnInsert"
style="?android:attr/buttonStyleSmall"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:text="Insert" />
<ListView
android:id="@+id/listView1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="21dp" >
</ListView>
</RelativeLayout>
我也从DDMS添加了错误 你可以在错误页面中看到它提到了一个字段“ _id ”,我从来没有过!!!! :( 我太困惑了......
答案 0 :(得分:1)
您是否尝试从Open_Create()
方法中删除onClick()
来电?您连续两次拨打openOrCreateDatabase()
,中间没有任何close()
。不要忘记try { ... } catch (SQLiteException) { ... }
。你测试了。
答案 1 :(得分:1)
如果您想使用Cursor,Android会自动假设您的表有一个名为_id
的列,该列充当行的唯一主要标识符,有关详细信息,请参阅{“类概述”部分{ {3}}说:
将数据从Cursor公开给ListView小部件的适配器。 Cursor必须包含一个名为“_id”的列,否则此类将无效。
基本上您需要做的就是将CREATE TABLE
来电替换为:
db.execSQL("CREATE TABLE IF NOT EXISTS MyTable (_id INTEGER PRIMARY KEY AUTOINCREMENT, LastName VARCHAR,Phone VARCHAR);");
这应该能解决你的崩溃问题。要让它自动刷新列表,请参阅我的评论重新定位notifyDatasetChanged()
。
作为旁注:我强烈建议使用CursorAdapter's documentation实例来处理表的打开和创建,而不是现在正在做的事情,重复调用CREATE TABLE IF NOT EXISTS
是不好的形式只有在你知道需要调用它的时候才能调用它。 SQLiteOpenHelper
修改:根据您上次编辑的代码:您仍然没有请求您创建的_id
字段。如果在SELECT语句中没有它,则光标无法访问它!
将rawQuery
中的Populate_ListView
替换为SELECT * FROM MyTable
,以便光标也返回_id
字段。