没有这样的表-在SQLite Android中插入值时出错

POOJA GUPTA

我想开发一个需要在Android中使用SQLite数据库的应用程序。下面显示的代码正在实现数据库及其我的应用程序需要使用随机数据执行的所有操作(只是先成功成功实现逻辑)。

这段代码是用DBHelperDisplay.java编写的,MainActivity.java通过意图调用了该代码。

我的DBHelperDisplay.java:

package course.examples.jumboquest;

import java.util.Random;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
//import android.widget.EditText;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import android.widget.TextView;
//import android.content.Intent;
import android.os.CountDownTimer;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.DatabaseUtils;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase;

public class DBHelperDisplay extends ActionBarActivity {

TextView tv; 
DBHelper myDB;
RadioGroup radioChoices;
RadioButton rbtChoice; 
Button btSubmit;
String choice1;
String choice2;
String choice3;
String choice4;
String strAns;
CustomTimer cdt;

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

    cdt = new CustomTimer(20000, 1000);
    cdt.start();

    myDB = new DBHelper(this);

    myDB.insertQuestion(1, "who is the team member whose name starts with s?", "Vinita", "Akanksha", "Swati", "Megha", "Swati");
    myDB.insertQuestion(2, "who is the team member whose name starts with m?", "Vinita", "Akanksha", "Swati", "Megha", "Megha");
    myDB.insertQuestion(3, "who is the team member whose name starts with a?", "Vinita", "Akanksha", "Swati", "Megha", "Akanksha");
    myDB.insertQuestion(4, "who is the team member whose name starts with v?", "Vinita", "Akanksha", "Swati", "Megha", "Vinita");
    myDB.insertQuestion(5, "who is the team member whose name ends with i?", "Vinita", "Akanksha", "Swati", "Megha", "Swati");

    Cursor rs = myDB.getData();
    String Question = rs.getString(rs.getColumnIndex(DBHelper.Col_Ques));
    choice1 = rs.getString(rs.getColumnIndex(DBHelper.Col_Choice1));
    choice2 = rs.getString(rs.getColumnIndex(DBHelper.Col_Choice2));
    choice3 = rs.getString(rs.getColumnIndex(DBHelper.Col_Choice3));
    choice4 = rs.getString(rs.getColumnIndex(DBHelper.Col_Choice4));
    strAns = rs.getString(rs.getColumnIndex(DBHelper.Col_Ans));


    tv = (TextView) findViewById(R.id.timertxt);

    final TextView quest = (TextView) findViewById(R.id.quest);
    quest.setText(Question);

    //final TextView ans = (TextView) findViewById(R.id.ans);

    Button btClear = (Button)findViewById(R.id.btClear);
    btClear.setText("CLEAR");

   addListenerRadioChoices() ;

   btClear.setOnClickListener(new View.OnClickListener(){
     public void onClick(View v) {
        //ans.setText("");

       }
  });
 }
    public void addListenerRadioChoices(){ 

    radioChoices = (RadioGroup) findViewById(R.id.radioChoices);

    ((RadioButton) radioChoices.getChildAt(0)).setText(choice1); 
    ((RadioButton) radioChoices.getChildAt(1)).setText(choice2);
    ((RadioButton) radioChoices.getChildAt(2)).setText(choice3);
    ((RadioButton) radioChoices.getChildAt(3)).setText(choice4);

    btSubmit = (Button)findViewById(R.id.btSubmit); 
    btSubmit.setText("SUBMIT");
    btSubmit.setOnClickListener(new View.OnClickListener(){
     public void onClick(View v) {

        int selected = radioChoices.getCheckedRadioButtonId();
        rbtChoice = (RadioButton) findViewById(selected); 
        String Ans = rbtChoice.getText().toString();
         if(Ans.equalsIgnoreCase(strAns)){

            cdt.cancel();
            //ans.setText(" ANSWER");

         }
        /* else{
            //  ans.setText("WRONG ANSWER");
         }*/

    }
   });
  } 

public class CustomTimer extends CountDownTimer{
    //TextView ed;
    public CustomTimer(long millisInFuture, long countDownInterval){
        super(millisInFuture, countDownInterval);
    }
    @Override
    public void onTick(long millisUntilFinished){
        //current = millisUntilFinished/1000;
        tv.setText("Time Left:" + millisUntilFinished/1000);
    }
    @Override
    public void onFinish() {
        tv.setText("Time Up - lost the game!");
    }
}

public class DBHelper extends SQLiteOpenHelper {

    public static final String Database_Name = "Questions.db"; 
    public static final String Table_Name = "Comics"; 
    public static final String Col_ID = "id"; 
    public static final String Col_Ques = "question"; 
    public static final String Col_Choice1 = "choice1"; 
    public static final String Col_Choice2 = "choice2"; 
    public static final String Col_Choice3 = "choice3"; 
    public static final String Col_Choice4 = "choice4"; 
    public static final String Col_Ans = "answer"; 

    public DBHelper(Context context){
        super(context, Database_Name, null, 1);
    }
    @Override 
    public void onCreate(SQLiteDatabase db){
        // TODO Auto-generated method stub  
       db.execSQL(
       "CREATE TABLE Comics" +
       "(id integer primary key, question text, choice1 text, choice2 text, choice3 text, choice4 text, answer text)");

    }   
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
          // TODO Auto-generated method stub
          db.execSQL("DROP TABLE IF EXISTS Comics");
          onCreate(db);
    }

    public boolean insertQuestion(int id, String question, String choice1, String choice2, String choice3, String choice4, String answer){
        SQLiteDatabase db = this.getWritableDatabase();
        ContentValues contentValues = new ContentValues();

        contentValues.put("id",id);
        contentValues.put("question",question);
        contentValues.put("choice1",choice1);
        contentValues.put("choice2",choice2);
        contentValues.put("choice3",choice3);
        contentValues.put("choice4",choice4);
        contentValues.put("answer",answer);
        db.insert("Comics", null, contentValues);
        db.close();
        return true;
    }
    public Cursor getData(){
        SQLiteDatabase db = this.getReadableDatabase();
        int numRows = (int)DatabaseUtils.queryNumEntries(db,Table_Name);
        int min = 1;
        int max = numRows;
        Random r = new Random();
        int id = r.nextInt(max - min + 1) + min;
        Cursor res= db.rawQuery("Select * from Comics where id = " + id + "", null);
        return res;
    }
}

}

我的AndroidManifest.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="course.examples.jumboquest"
android:versionCode="1"
android:versionName="1.0" >

<uses-sdk
    android:minSdkVersion="8"
    android:targetSdkVersion="21" />

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name=".MainActivity"
        android:label="@string/app_name" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <activity android:name=".DBHelperDisplay"></activity>
</application>

</manifest>

在执行上述代码时,出现以下错误:

logcat文件

我进行了很多搜索,发现很多堆栈溢出链接都存在相同的问题,但仍然无法解决。我是这个主题的新手。请帮我。

logCat file2

nunoh123

我有两个适配器:

公共类DBController_for_drivinglicense扩展了SQLiteOpenHelper {

public DBController_for_drivinglicense(Context applicationcontext) {
    super(applicationcontext,"nozadb", null, 1);

}
//Creates Table
@Override
public void onCreate(SQLiteDatabase database) {

    String query;
    query = "CREATE TABLE if not exists drivinglicense ( id INTEGER PRIMARY KEY, comment TEXT,rates float,names TEXT,date DEFAULT CURRENT_TIMESTAMP, udpateStatus TEXT)";
    database.execSQL(query);
}

第一个适配器是:

public DBController_for_landregistration(Context applicationcontext) {
    super(applicationcontext,"nozadb", null, 1);
}

@Override
public void onCreate(SQLiteDatabase database) {
    String query;

    query = "CREATE TABLE if not exists landregistration ( id INTEGER PRIMARY KEY, comment TEXT,rates float,names TEXT,date DEFAULT CURRENT_TIMESTAMP, udpateStatus TEXT)";
    database.execSQL(query);

}

当我将第二个更改为:

公共类DBController_for_drivinglicense扩展了SQLiteOpenHelper {

public DBController_for_drivinglicense(Context applicationcontext) {
    super(applicationcontext,"nozadb", null, 2);
}
//Creates Table
@Override
public void onCreate(SQLiteDatabase database) {

    String query;
    query = "CREATE TABLE if not exists drivinglicense ( id INTEGER PRIMARY KEY, comment TEXT,rates float,names TEXT,date DEFAULT CURRENT_TIMESTAMP, udpateStatus TEXT)";
    database.execSQL(query);

}

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

SQLite在Android上没有这样的列错误

来自分类Dev

android.database.sqlite.SQLiteException:表中没有这样的列

来自分类Dev

SQLITE_ERROR:Node.js中没有这样的表

来自分类Dev

Android sqlitedatabase没有这样的表

来自分类Dev

无法启动活动,android.database.sqlite.SQLiteException:没有这样的表,而在编译时:SELECT * FROM table

来自分类Dev

sqlite3中没有这样的列错误

来自分类Dev

SQLite在Android上插入没有这样的列错误

来自分类Dev

Android :: SQLite错误:没有这样的表

来自分类Dev

SQLite没有这样的表异常

来自分类Dev

SQLite(1)没有这样的表

来自分类Dev

Android中的SQLite问题,“没有这样的表”错误

来自分类Dev

android sqlite没有这样的表

来自分类Dev

引起原因:android.database.sqlite.SQLiteException:没有这样的表,同时编译了DELETE FROM

来自分类Dev

无法启动活动,android.database.sqlite.SQLiteException:没有这样的表,而在编译时:SELECT * FROM table

来自分类Dev

Android SQLite(1)没有这样的表:查看错误

来自分类Dev

android.database.sqlite.SQLiteException:没有这样的表

来自分类Dev

SQLite Android没有这样的列错误

来自分类Dev

SQlite错误:“没有这样的表”

来自分类Dev

Android SQLite异常:没有这样的列

来自分类Dev

没有这样的表(Android SQLite)

来自分类Dev

进行SQLite查询时“没有这样的列”

来自分类Dev

SQlite错误:没有这样的表:使用联接时

来自分类Dev

没有这样的表:即使在初始化之后,sqlite 中的表名

来自分类Dev

Android sqlite 更新错误没有这样的列

来自分类Dev

Android Sqlite“没有这样的表”错误

来自分类Dev

Django:sqlite3.OperationalError:python shell 中没有这样的表

来自分类Dev

android P中的sqlite数据库错误“没有这样的表”

来自分类Dev

更新行时,SQLite 中没有这样的列错误

来自分类Dev

SQLite 错误:点击时没有这样的列 ListView

Related 相关文章

  1. 1

    SQLite在Android上没有这样的列错误

  2. 2

    android.database.sqlite.SQLiteException:表中没有这样的列

  3. 3

    SQLITE_ERROR:Node.js中没有这样的表

  4. 4

    Android sqlitedatabase没有这样的表

  5. 5

    无法启动活动,android.database.sqlite.SQLiteException:没有这样的表,而在编译时:SELECT * FROM table

  6. 6

    sqlite3中没有这样的列错误

  7. 7

    SQLite在Android上插入没有这样的列错误

  8. 8

    Android :: SQLite错误:没有这样的表

  9. 9

    SQLite没有这样的表异常

  10. 10

    SQLite(1)没有这样的表

  11. 11

    Android中的SQLite问题,“没有这样的表”错误

  12. 12

    android sqlite没有这样的表

  13. 13

    引起原因:android.database.sqlite.SQLiteException:没有这样的表,同时编译了DELETE FROM

  14. 14

    无法启动活动,android.database.sqlite.SQLiteException:没有这样的表,而在编译时:SELECT * FROM table

  15. 15

    Android SQLite(1)没有这样的表:查看错误

  16. 16

    android.database.sqlite.SQLiteException:没有这样的表

  17. 17

    SQLite Android没有这样的列错误

  18. 18

    SQlite错误:“没有这样的表”

  19. 19

    Android SQLite异常:没有这样的列

  20. 20

    没有这样的表(Android SQLite)

  21. 21

    进行SQLite查询时“没有这样的列”

  22. 22

    SQlite错误:没有这样的表:使用联接时

  23. 23

    没有这样的表:即使在初始化之后,sqlite 中的表名

  24. 24

    Android sqlite 更新错误没有这样的列

  25. 25

    Android Sqlite“没有这样的表”错误

  26. 26

    Django:sqlite3.OperationalError:python shell 中没有这样的表

  27. 27

    android P中的sqlite数据库错误“没有这样的表”

  28. 28

    更新行时,SQLite 中没有这样的列错误

  29. 29

    SQLite 错误:点击时没有这样的列 ListView

热门标签

归档