SQLite查询SQLiteLog(1)没有这样的列:

use*_*585 6 sqlite android android-cursor

我有3节课.一个设置数据库和表,工作正常.DBHelper.java

private static final String TAG = "DBHelper";
public static final String DB_NAME = "pat_test.db";
public static final String TABLE5 = "sites";
public static final String S_ID = BaseColumns._ID;
public static final String S_CLIENT = "client_of_site";
public static final String S_POSTCODE = "site_postode";
public static final String S_CON_NAME = "contact_name";
public static final String S_CON_NUM = "contact_tel_num";
public static final String S_NAME = "site_name";
public static final String S_LAST_TEST = "last_test_date";

public DBHelper(Context context) {
    super(context, DB_NAME, null, DB_VERSION);

}

@Override
public void onCreate(SQLiteDatabase db) {


String sql5 = String.format("create table %s (%s INT PRIMARY KEY, %s TEXT, %s TEXT, %s TEXT, %s TEXT, %s INT, %s TEXT)",TABLE5, S_ID, S_CLIENT, S_NAME, S_POSTCODE, S_CON_NAME,S_CON_NUM,S_LAST_TEST); 
Log.d(TAG, "onCreate: " + sql5);
db.execSQL(sql5);
}
Run Code Online (Sandbox Code Playgroud)

下一个有我的功能 DBControl.java

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;    
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteException;
import android.provider.BaseColumns;

public class DBControl {

public static final String TABLE5 = "sites";

public static final String S_ID = BaseColumns._ID;
public static final String S_CLIENT = "client_of_site";
public static final String S_NAME = "site_name";
public static final String S_POSTCODE = "site_postode";
public static final String S_CON_NAME = "contact_name";
public static final String S_CON_NUM = "contact_tel_num";
public static final String S_LAST_TEST = "last_test_date";

private Context context;
private SQLiteDatabase database;
private DBHelper dbhelper;

public DBControl(Context context) {

    this.context = context;

}

  public DBControl open() throws SQLiteException {

    dbhelper = new DBHelper(context);
    database = dbhelper.getWritableDatabase();
    return this;
}

public void close() {

    dbhelper.close();

}
   public ContentValues createContentValues3(String CLIENT, 
        String NAME,    String POSTCODE, String CON_NAME, 
         long CON_NUM) {

    ContentValues values = new ContentValues();
    values.put(S_CLIENT, CLIENT);
    values.put(S_POSTCODE, POSTCODE);
    values.put(S_CON_NAME, CON_NAME);
    values.put(S_CON_NUM, CON_NUM);
    values.put(S_NAME, NAME);
    return values;
  }  
   public long addSiteDetails( String CLIENT, String NAME,
        String POSTCODE, String CON_NAME, int CON_NUM ) {

    ContentValues siteValues = createContentValues3( CLIENT, NAME,
            POSTCODE, CON_NAME, CON_NUM );

    return database.insert(TABLE5, null, siteValues);
}


public boolean updateSiteDetails(long id, String CLIENT, String NAME,
        String POSTCODE, String CON_NAME , int CON_NUM
        ) {

    ContentValues siteUpdateValues = createContentValues3( CLIENT, NAME,
            POSTCODE, CON_NAME, CON_NUM);

    return database.update(TABLE5, siteUpdateValues, S_ID + "=" + id, null) > 0;
}

}
  public long fetchSiteIdByName(String NAME){

     Cursor dbCursor; 
     long id = 0;

      try { 

     dbCursor = database.query(true, TABLE5, new String []{S_ID}, S_NAME + "= " + NAME  , null, null, null, null, null);
     dbCursor.moveToFirst(); 
     id = dbCursor.getLong(dbCursor.getColumnIndex(S_ID)); } 

      catch (SQLiteException e) { 

          id = -1;

      }

      return id;

      }
Run Code Online (Sandbox Code Playgroud)

我的第三堂课用来打电话和检查.但这是我的问题出现的地方或上一课中的fetchSiteIdByName.

  import android.app.Activity;
  import android.app.Dialog;
  import android.content.Intent;
  import android.database.sqlite.SQLiteException;
  import android.os.Bundle;
  import android.view.Menu;
  import android.view.View;
  import android.view.View.OnClickListener;
  import android.widget.AutoCompleteTextView;
  import android.widget.Button;
  import android.widget.EditText;
  import android.widget.TextView;
  import android.widget.Toast;

  public class activityStartNewTest extends Activity implements OnClickListener {

Button buttonBeginTesting;
private AutoCompleteTextView clientInput;       //Refers to input box for client
private AutoCompleteTextView siteInput;         //Refers to input box for site
private AutoCompleteTextView postcodeInput;     //Refers to input box for postcode
private EditText nameInput;                     //Refers to input box for contact name
private EditText telInput;                      //Refers to input box for contact number
  //    private EditText jobrefInput;                   //Refers to input box for Job reference number

private DBControl dbControl;                

@ Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.start_new_test);
    dbControl = new DBControl(this);
    clientInput = (AutoCompleteTextView) findViewById(R.id.autoCompleteClientNameEdit);
    siteInput = (AutoCompleteTextView) findViewById(R.id.autoCompleteSiteNameEdit);
    postcodeInput = (AutoCompleteTextView) findViewById(R.id.autoCompletePostcodeEdit);
    nameInput = (EditText) findViewById(R.id.editTextContactName);
    telInput = (EditText) findViewById(R.id.editTextContactNum);
  //        jobrefInput = (EditText)findViewById(R.id.editTextJobRef);      

    buttonBeginTesting = (Button) findViewById(R.id.buttonBeginTesting);
    buttonBeginTesting.setOnClickListener(this);
}


@Override
public boolean onCreateOptionsMenu(Menu menu) {
    getMenuInflater().inflate(R.menu.activity_main, menu);
    return true;
}


public void onClick(View arg) {

    String clientData = clientInput.getText().toString();
    String siteData = siteInput.getText().toString();
    String postcodeData = postcodeInput.getText().toString();
    String nameData = nameInput.getText().toString();
    String telData = telInput.getText().toString();
     // String jobrefData = jobrefInput.getText().toString();

    Toast toastNotice = new Toast(this);
    Dialog notice = new Dialog(this); // this needs the textview below for displaying
    TextView msgBody = new TextView(this);
    msgBody.setTextSize(20);
    long tempValue = 0;

    switch(arg.getId()){

    case R.id.buttonBeginTesting:

    try{
        int telDataAsNum = Integer.parseInt(telData);
        dbControl.open();

        if((tempValue = dbControl.fetchSiteIdByName(siteData)) != -1) {

            if(dbControl.updateSiteDetails(tempValue, clientData, siteData, postcodeData, nameData, telDataAsNum)){
                notice.setTitle("Site Updated!");
                msgBody.setText("Site detail have been updated instead");
            }
            else{
                notice.setTitle("Update failed!");
                msgBody.setText("Site already Exists, but failed!");
            }
        }
        else{
            long siteID = 0;

            siteID = dbControl.addSiteDetails( clientData, siteData, postcodeData, nameData, telDataAsNum );
            notice.setTitle("Site Added");
            msgBody.setText("Site added at row "+ siteID);
    }
    dbControl.close();

    }
    catch (SQLiteException e){ // Notifies user if SQL error occurred
        e.printStackTrace();
        notice.setTitle("Insert failed");
        msgBody.setText("SQL Error!");
    }
    catch (NumberFormatException e){ // Notifies user if NUM format error occurred
        e.printStackTrace();
        notice.setTitle("Insert failed");
        msgBody.setText("Contact number must be a number!");
    }
    notice.setContentView(msgBody);
    notice.show();
  }
  }
  }
Run Code Online (Sandbox Code Playgroud)

现在,当我运行应用程序时,我插入数据库,新的详细信息absolutley罚款.使用adb我拉数据库并在sqlite3中打开.它显示所有条目在第一列中为NULL,在最后一列中为NULL(最后一个尚未发布).我在editbox siteData的字段中使用相同的文本,它只是添加一个新条目,不会更新以前的条目.

log cat显示SQLiteLog(1)没有这样的列:xxx,其中xxx将是autocompleteTextView的入口.

为什么要查找以输入的文本命名的列?

use*_*585 1

我似乎遇到了 3 个不同的问题,但使用 Lokesh 的链接和帖子可以帮助我解决问题。

我将 DBelper.java 中的 SQL 字符串修改为这样

   String sql5 = String.format("create table %s (%s INTEGER PRIMARY KEY **AUTOINCREMENT**, %s TEXT, %s TEXT, %s TEXT, %s TEXT, %s INT, %s TEXT)",
                    TABLE5, S_ID, S_CLIENT, S_NAME, S_POSTCODE, S_CON_NAME,
                    S_CON_NUM, S_LAST_TEST);
Run Code Online (Sandbox Code Playgroud)

并添加到DBControl.java类中

  **if**(dbCursor.moveToFirst()) id = dbCursor.getLong(dbCursor.getColumnIndex(S_ID));  
Run Code Online (Sandbox Code Playgroud)

在 moveToFirst()) 之后删除分号。就像我说的,我是一个真正的菜鸟,但相信这是正确的。

当我卸载并重新安装应用程序时,添加自动增量产生了 1 个戏剧性的效果(我可以更改数据库版本,如果我也想的话,我知道)。

当重建表时,它们没有我之前见过的 _id 列。所以我认为 SQL 字符串是我失败的原因。我确信我在某处听说过 PRIMARY KEY basecolumns._ID 不需要它,但现在我知道它是必需的。

感谢洛克什的指点。如果没有一些指导,我就无法找到这个问题,我真的很感激。

我尝试添加到向上箭头,但还没有足够的评级。哦。

希望这对其他人有帮助。