繁体   English   中英

从SQLite数据库提取数据(Android)

[英]Extracting data from SQLite database (Android)

我无法在主要活动中将数据写入数据库,但是在其他活动中读取和显示数据时遇到问题。 我正在将SQLHelperDatabase类与“ addData”方法(根据调试器工作正常)和showData方法(这就是问题所在)一起使用。 在主要活动中输入数据后,我希望能够按发送消息按钮,并在新活动中显示数据。 我已经在这个问题上停留了一个星期,我一直在搜索WWW,每个教程都说我的代码应该可以工作。 请有人可以帮助我深入了解这一令人沮丧的磨难。

package com.doors.waynderful.myapp;

import android.content.Intent;
import android.database.Cursor;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.TextView;


public class DisplayMessageActivity extends ActionBarActivity {
DatabaseHelper db;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
        db = new DatabaseHelper(this);
        Cursor cursor = db.showData();
        cursor.moveToFirst();

        String nam = cursor.getString(cursor.getColumnIndex(DatabaseHelper.THE_TABLE_COLUMN_NAME));

        if (!cursor.isClosed()){
            cursor.close();
        }




    TextView textView = new TextView(this);
    textView.setTextSize(40);
    textView.setText(nam);

   setContentView(textView);
    //setContentView(R.layout.activity_display_message);

}


@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.menu_display_message, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();

    //noinspection SimplifiableIfStatement
    if (id == R.id.action_settings) {
        return true;
    }

    return super.onOptionsItemSelected(item);
   }
}

下面是SQLHelperDatabase。

package com.doors.waynderful.myapp;

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


public class DatabaseHelper extends SQLiteOpenHelper
{
public static final String THE_DATABASE = "theDatabase";
public static final String THE_TABLE = "infoTable";
public static final String THE_TABLE_COLUMN_ID = "id";
public static final String THE_TABLE_COLUMN_NAME = "name";
public static final String THE_TABLE_COLUMN_DETAILS = "details";

DatabaseHelper(Context context)
{
    super(context,THE_DATABASE, null, 1);
}

@Override
public void onCreate(SQLiteDatabase db) {
    db.execSQL("create table " +THE_TABLE+"(id integer primary key, name text,     details text) ");
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    db.execSQL("drop table if exists " + THE_TABLE + "");

    onCreate(db);
}

public void addData(String nameIn, String detailsIn)
{
    SQLiteDatabase db = this.getWritableDatabase();
    ContentValues data = new ContentValues();

    data.put("name", nameIn);
    data.put("details", detailsIn);

    db.insert(THE_TABLE,null,data);

    }

    public Cursor showData()
    {
    SQLiteDatabase db = this.getReadableDatabase();

    Cursor cursor;
    cursor = db.rawQuery("select * from "+THE_TABLE+"", null);
    return cursor;

    }
}

以下是MainActivity

package com.doors.waynderful.myapp;

import android.content.Intent;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.EditText;



public class MainActivity extends ActionBarActivity {

public final static String EXTRA_MESSAGE = "com.doors.waynderful.myapp.MESSAGE";
DatabaseHelper myDb;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
}


@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.menu_main, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();

    //noinspection SimplifiableIfStatement
    if (id == R.id.action_settings) {
        return true;
    }

    return super.onOptionsItemSelected(item);
}

public void sendMessage(View view){
    myDb = new DatabaseHelper(this);


    Intent intent = new Intent(this,DisplayMessageActivity.class);

    EditText editText = (EditText) findViewById(R.id.edit_name);
    EditText editText1 = (EditText) findViewById(R.id.edit_details);

    String name = editText.getText().toString();
    String details = editText1.getText().toString();

    myDb.addData(name, details);
    //intent.putExtra(EXTRA_MESSAGE,message);

   startActivity(intent);

}
}

LOGCAT显示

03-31 09:40:31.100 1351-1351 / com.doors.waynderful.myapp E / SQLiteLog:(1)没有这样的表:infoTable

我不确定为什么您认为必须在数据库中必须有一个id为1的行

如果要查找具有特定名称的行,请使用sql语句选择具有该名称的行。

如果要列出所有行,请选择所有行。

但是插入一行,然后假设您知道它的id根本行不通。

另外,您应该使用使用布局的(当前已注释掉)代码,而不是创建新的文本视图并将其设置为内容视图。

最后,您似乎没有任何代码可以在数据库中实际创建表?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM