java - Android 数据库(SQLite)连接

标签 java android database sqlite

我正在尝试创建一个Android应用程序,它可以使用他选择的名称存储用户位置(手机信号塔代码),即例如手机信号塔代码是405673,我想将其存储为“家庭”位置。 所以,基本上我的程序包含以下模块

  1. 获取用户塔代码。
  2. 创建数据库。
  3. 从用户处获取位置名称的输入字符串。
  4. 将这些值存储在数据库中。
  5. 根据请求显示这些值。

模块 1 和 2 单独工作得很好,但是当我集成它们时,我得到了致命的 main 和空指针异常。

我的代码如下

package my.project.mil;

import android.content.Context;
import android.content.Intent;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class Cbdata extends MainActivity {

    public String str;

    public void onReceive(Context context, Intent intent) {
        //---get the CB message passed in---
        Bundle bundle = intent.getExtras();        
        SmsCbMessage[] msgs = null;
        str = "";            
        if (bundle != null)  {
            //---retrieve the SMS message received---
            Object[] pdus = (Object[]) bundle.get("pdus");
            msgs = new SmsCbMessage[pdus.length];            
            for (int i=0; i<msgs.length; i++) {
                msgs[i] = SmsCbMessage.createFromPdu((byte[])pdus[i]);                
                str += "CB " + msgs[i].getGeographicalScope() + msgs[i].getMessageCode() + msgs[i].getMessageIdentifier() + msgs[i].getUpdateNumber();                     
                str += " :";
                str += msgs[i].getMessageBody().toString();
                str += "\n";        
            }}
}

    SQLiteDatabase cd = openOrCreateDatabase("mydata", MODE_WORLD_READABLE, null);



Button submit;
Button viewdb;
EditText name;

@Override
public void onCreate(Bundle savedInstanceState)
{
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    setContentView(R.layout.seventh);

    viewdb = (Button) findViewById(R.id.viewdb);
    submit = (Button) findViewById(R.id.submit);
    name = (EditText) findViewById(R.id.name);

    submit.setOnClickListener(new View.OnClickListener() 
    {

        public void onClick(View arg0) {

            String locname = name.getText().toString();
            if (locname.length()>0)
            {

                cd.execSQL("CREATE TABLE IF NOT EXITSTS MLITable     (CblocationCode INT(10), CblocationName VARCHAR);");
                cd.execSQL("INSERT INTO MLITable VALUES (' ',' ');" +str +locname);
                Toast.makeText(getBaseContext(), "value successfully entered.", Toast.LENGTH_LONG).show();
            }
            else
            {
                Toast.makeText(getBaseContext(), "Please enter the location name, for example 'Home'.", Toast.LENGTH_LONG).show();
            }

        }
    });

    cd.close();

    viewdb.setOnClickListener(new View.OnClickListener() 
    {

        public void onClick(View arg0) {
            // TODO Auto-generated method stub
            // here comes the code for viewing the database


        }
    });
}



} 

我的logcat如下

logcat

有趣的是,我删除了数据库命令来查看我的代码是否正常工作,从中我可以得出结论,我在数据库连接行中犯了错误。

现在,我的疑问是

  1. 为什么我的数据库连接出现空点异常错误以及如何解决该错误?
  2. 我使用以下代码将值插入表中,

    cd.execSQL("如果不退出则创建表 MLITable (CblocationCode INT(10), CblocationName VARCHAR);"); cd.execSQL("INSERT INTO MLITable VALUES (' ',' ');"+str +locname); 将用户值传递到数据库的正确方法是吗?

谢谢。

最佳答案

CREATE 语句的 EXISTS 拼写错误。

INSERT 语句应为

cd.execSQL("INSERT INTO MLITable VALUES('" + str + "', '" + locname + "');");

但我认为最可能的原因是 openOrCreateDatabase 调用尚未运行,因此没有为 cd 分配任何内容。

关于java - Android 数据库(SQLite)连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13202269/

相关文章:

java - fork /加入 : optimal threads count

java - Skybox 是全黑的

java - Docker 卷映射 + windows = 令人难以置信的慢?

java - 如何使用服务访问每个 Activity 的值

java - 如何在 Java 中消除改造 react 请求?

java - 检查 Java 中的 MySQL DB 中是否存在值?

java - 无双向实体的 Hibernate 关系问题

android - ionic 1 onesignal 有没有办法知道从后台打开应用程序到前台或启动应用程序时是否有推送通知

mysql主键,是哈希索引还是b树?

mysql - 删除/更新表记录的时间/创建日期有什么好处?