Android 为什么不在单击“详细信息”按钮时显示listview数据

Android 为什么不在单击“详细信息”按钮时显示listview数据,android,android-sqlite,Android,Android Sqlite,我正在设计简单提交和获取详细信息表单。数据存储在数据库中,获取数据库中的数据并显示在listview中 但所有的东西都正常工作,但当我点击detial按钮时,他并没有显示数据库的细节 请帮帮我 DBAdapter.java package com.example.anew.demo; import android.content.ContentValues; import android.content.Context; import android.database.Cursor; impo

我正在设计简单提交和获取详细信息表单。数据存储在数据库中,获取数据库中的数据并显示在listview中

但所有的东西都正常工作,但当我点击detial按钮时,他并没有显示数据库的细节

请帮帮我

DBAdapter.java

package com.example.anew.demo;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;


public class DBAdapter {
//COLUMNS
static final String NAME = "name";
static final String E_Mail = "email";
static final String PHONE = "phone";

//DB PROPERTIES
static final String DBNAME = "employee_DB";
static final String TBNAME = "employee_TB";
static final int DBVERSION = '1';

static final String CREATE_TB = ("CREATE TABLE IF NOT EXISTS employee_TB(name VARCHAR, phone VARCHAR, email VARCHAR);");
final Context context;
SQLiteDatabase sqLiteDatabase;
DBHelper helper;

public DBAdapter(Context ctx) {
    this.context = ctx;
    helper = new DBHelper(context);
}

//INNER HELPER DB CLASS
private static class DBHelper extends SQLiteOpenHelper {
    public DBHelper(Context context) {
        super(context, DBNAME, null, DBVERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
            db.execSQL(CREATE_TB);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }
}
    // OPEN THE DB
    public DBAdapter openDB() {
        try {
            sqLiteDatabase = helper.getWritableDatabase();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return this;
    }
//CLOSE THE DB
public void close()
{
    helper.close();
}

//INSERT INTO TABLE
public long add(String name,String email, String phone){
    try{
        ContentValues contentValues = new ContentValues();
        contentValues.put(NAME,name);
        contentValues.put(E_Mail,email);
        contentValues.put(PHONE,phone);
        return sqLiteDatabase.insert(TBNAME,null,contentValues);
    }catch (SQLException e){
        e.printStackTrace();
    }
    return 0;
}

//GET ALL VALUES
public Cursor getAllNames(){
    String[] columns={NAME,E_Mail,PHONE};
    String query="select * from "+TBNAME;
    return sqLiteDatabase.rawQuery(query,null);
}
}

MainActivity.java

package com.example.anew.demo;

import android.database.Cursor;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.Toast;

import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {

ListView lv;
EditText nametext,emailtext,phonetext;
Button submitbtn,detailbtn;
ArrayList<String> details = new ArrayList<String>();
ArrayAdapter<String> adapter;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    nametext = (EditText)findViewById(R.id.nametext);
    emailtext = (EditText)findViewById(R.id.emailtext);
    phonetext = (EditText)findViewById(R.id.phonetext);
    submitbtn = (Button)findViewById(R.id.submitbtn);
    detailbtn = (Button)findViewById(R.id.detailbtn);
    lv = (ListView)findViewById(R.id.listview1);

    adapter = new ArrayAdapter<String>(this,android.R.layout.simple_selectable_list_item);

    final DBAdapter db = new DBAdapter(this);

    //EVEMTS
    submitbtn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            //OPEN
            db.openDB();

            //INSERT
            long result=db.add(nametext.getText().toString(),emailtext.getText().toString(),phonetext.getText().toString());
            if(result>0){
                nametext.setText("");
                emailtext.setText("");
                phonetext.setText("");
            }else{
                Toast.makeText(MainActivity.this, "Failure", Toast.LENGTH_SHORT).show();
            }
            db.close();;
        }
    });
    //Retrieve
    detailbtn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            details.clear();
            //OPEN
            db.openDB();

            //RETRIEVE
            Cursor cursor = db.getAllNames();
            while (cursor.moveToNext()) {
                String name = cursor.getString(0);
                details.add(name);
            }
            lv.setAdapter(adapter);
            db.close();
        }
    });

}
package com.example.anew.demo;
导入android.database.Cursor;
导入android.support.v7.app.AppActivity;
导入android.os.Bundle;
导入android.view.view;
导入android.widget.AdapterView;
导入android.widget.ArrayAdapter;
导入android.widget.Button;
导入android.widget.EditText;
导入android.widget.ListView;
导入android.widget.Toast;
导入java.util.ArrayList;
公共类MainActivity扩展了AppCompatActivity{
ListView lv;
编辑文本名称文本、电子邮件文本、电话文本;
按钮提交tn,详情btn;
ArrayList details=新的ArrayList();
阵列适配器;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
nametext=(EditText)findViewById(R.id.nametext);
emailtext=(EditText)findViewById(R.id.emailtext);
phonetext=(EditText)findViewById(R.id.phonetext);
submitbtn=(按钮)findViewById(R.id.submitbtn);
detailbtn=(按钮)findViewById(R.id.detailbtn);
lv=(ListView)findViewById(R.id.listview1);
adapter=newarrayadapter(这是android.R.layout.simple\u可选的\u列表\u项);
最终DBAdapter db=新的DBAdapter(本);
//伊夫姆斯
submitbtn.setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图v){
//打开
db.openDB();
//插入
long result=db.add(nametext.getText().toString(),emailtext.getText().toString(),phonetext.getText().toString());
如果(结果>0){
nametext.setText(“”);
emailtext.setText(“”);
phonetext.setText(“”);
}否则{
Toast.makeText(MainActivity.this,“Failure”,Toast.LENGTH_SHORT.show();
}
db.close();;
}
});
//取回
detailbtn.setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图v){
详细信息。清除();
//打开
db.openDB();
//取回
Cursor Cursor=db.getAllNames();
while(cursor.moveToNext()){
字符串名称=cursor.getString(0);
详细信息。添加(名称);
}
低压设置适配器(适配器);
db.close();
}
});
}
}

主要活动

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.anew.demo.MainActivity">


<LinearLayout
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_alignParentTop="true"
    android:layout_centerHorizontal="true">


    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:text="Details"
        android:id="@+id/textView"
        android:layout_gravity="center_horizontal"
        android:textSize="35sp" />

    <LinearLayout
        android:orientation="horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:layout_marginRight="10dp"
        android:layout_marginTop="40dp">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Name"
            android:id="@+id/nameView"
            android:textSize="30sp" />

        <EditText
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:inputType="textPersonName"
            android:ems="10"
            android:id="@+id/nametext"
            android:layout_weight="1"
            android:layout_marginLeft="50dp"/>
    </LinearLayout>

    <LinearLayout
        android:orientation="horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:layout_marginRight="10dp"
        android:layout_marginTop="20dp">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="E-Mail"
            android:id="@+id/emailView"
            android:textSize="30sp" />

        <EditText
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:inputType="textEmailAddress"
            android:ems="10"
            android:id="@+id/emailtext"
            android:layout_weight="1"
            android:layout_marginLeft="45dp"/>
    </LinearLayout>

    <LinearLayout
        android:orientation="horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:layout_marginRight="10dp"
        android:layout_marginTop="20dp">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Phone"
            android:id="@+id/phoneView"
            android:textSize="30sp" />

        <EditText
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:inputType="phone"
            android:ems="10"
            android:id="@+id/phonetext"
            android:layout_weight="1"
            android:layout_marginLeft="45dp"/>
    </LinearLayout>

    <LinearLayout
        android:id="@+id/linearlayput1"
        android:orientation="horizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:layout_marginRight="10dp"
        android:layout_marginTop="10dp">

        <Button
            android:layout_width="match_parent"
            android:layout_height="20dp"
            android:text="Submit"
            android:id="@+id/submitbtn"
            android:layout_weight="1"/>

        <Button
            android:layout_width="match_parent"
            android:layout_height="20dp"
            android:text="Details"
            android:id="@+id/detailbtn"
            android:layout_weight="1"/>

    </LinearLayout>

    <LinearLayout
        android:orientation="horizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_below="@+id/linearlayput1"
        android:layout_marginLeft="10dp">

        <ListView
            android:id="@+id/listview1"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"></ListView>
    </LinearLayout>
</LinearLayout>


在DB类中尝试此方法

public Cursor getAllNames(){

    sqLiteDatabase = helper.getReadableDatabase();
    return sqLiteDatabase.query(TBNAME,new String[] {NAME,E_Mail,PHONE},null,null,null,null,null);
}

哦,是的…它起作用了,谢谢你,所以麦考赫是的。。。实际上,我是新用户。所以我不知道你能不能添加更多的信息,比如你尝试了什么,做了什么,等等?当你说它“没有显示”细节时,你是什么意思?你有空的对话吗?程序崩溃了吗?您是否收到特定的错误消息?