我想将数据插入数据库,但我的应用程序因为外键约束失败而被强制关闭。我试图修复,但我无法解决这个错误。
dbHelper.java
public class dbHelper {
private static final String CREATE_tbKontak = "create table "+ tbKontak
+"("+ k_id +" integer primary key autoincrement, "+ k_nama
+" text, "+ k_nomor +" text)";
private static final String CREATE_tbEnkrip = "create table "+ tbEnkrip
+"("+ e_idenkrip +" integer primary key autoincrement, "+ e_chiperteks
+" text, "+ e_kunci +" text)";
private static final String CREATE_tbPesan = "create table "+ tbPesan
+"("+ p_idpesan +" integer primary key autoincrement, "
+ p_idenkrip +" integer REFERENCES "+ tbEnkrip +"("+ e_idenkrip +") ON UPDATE CASCADE ON DELETE CASCADE, "
+ p_idkontak +" integer REFERENCES "+ tbKontak +"("+ k_id +") ON UPDATE CASCADE ON DELETE CASCADE, "
+ p_plainteks +" text)";
private static final String CREATE_tbPesanMasuk = "create table "+ tbPesanMasuk
+"("+ m_id +" integer primary key autoincrement, "+ m_idkontak +" integer REFERENCES "
+ tbKontak +"("+ k_id +") ON UPDATE CASCADE, "
+ m_chiperteks +" text , "
+ m_waktu +" not null default CURRENT_TIME)";
private static final String CREATE_tbPesanKeluar = "create table "+ tbPesanKeluar
+"("+ kel_id +" integer primary key autoincrement, "
+ kel_idpesan +" integer REFERENCES "+ tbPesan +"("+ p_idpesan +") ON UPDATE CASCADE, "
+ kel_waktu +" not null default CURRENT_TIMESTAMP)";
private final Context context;
private DatabaseOpenHelper dbHelper;
private SQLiteDatabase dba;
public dbHelper( Context ctx ) {
this.context = ctx;
dbHelper = new DatabaseOpenHelper(ctx);
dba = dbHelper.getWritableDatabase();
}
private static class DatabaseOpenHelper extends SQLiteOpenHelper {
public DatabaseOpenHelper( Context context ) {
super( context, namaDatabase, null, versiDB);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CREATE_tbKontak);
db.execSQL(CREATE_tbEnkrip);
db.execSQL(CREATE_tbPesan);
db.execSQL(CREATE_tbPesanMasuk);
db.execSQL(CREATE_tbPesanKeluar);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("DROP IF TABLE EXIST "+ tbPesanKeluar);
onCreate(db);
}
public void onOpen(SQLiteDatabase db) {
super.onOpen(db);
if(!db.isReadOnly()) {
db.execSQL("PRAGMA foreign_keys=ON;");
}
}
}
public void inputKontak( String nama, String nomor) {
dba.execSQL(" INSERT INTO tbKontak ( nama, nomor ) VALUES ( '"+nama+"', '"+nomor+"')");
}
public void inputEnkripsi( String chiperteks, String kunci ) {
dba.execSQL("INSERT INTO tbEnkrip ( e_chiperteks, e_kunci ) VALUES ( '"+chiperteks+"', '"+kunci+"')");
}
public void inputPesan( String idenkrip, String idkontak, String plainteks ) {
dba.execSQL("INSERT INTO TB_pesan ( p_idenkrip, p_idkontak, plainteks )VALUES ( '"+idenkrip+"', '"+idkontak+"', '"+plainteks+"' )");
}
public void inputPesanKeluar( String idpesan ) {
dba.execSQL("INSERT INTO tbPesanKeluar ( kel_idpes ) VALUES ('"+idpesan+"')");
}
public Cursor pilihKontak( String nomor ) {
Cursor c = dba.rawQuery("SELECT k_id FROM tbKontak where nomor = '"+nomor+"'", null);
return c;
}
public Cursor pilihEnkripsi( String chiperteks ) {
Cursor c = dba.rawQuery("SELECT e_idenkrip FROM tbEnkripsi where nomor = '"+chiperteks+"'", null);
return c;
}
public Cursor pilihPesan( String plainteks ) {
Cursor c = dba.rawQuery("SELECT p_idpesan FROM tbPesan where nomor = '"+plainteks+"'", null);
return c;
}
}
kirimpesan.java
public class KirimPesan extends Activity {
TextView pesane;
TextView namap;
String pesan;
String kunci;
String ciper;
String nama;
String nomor;
String waktu;
String idkontak;
String idenkripsi;
String idpesan;
SQLiteDatabase db;
dbHelper data;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.kirimtulispesan);
data = new dbHelper(this);
pesane = (TextView)findViewById(R.id.pesane);
namap = (TextView)findViewById(R.id.namap);
Bundle paket = getIntent().getExtras();
pesan = paket.getString("pesan");
kunci = paket.getString("kunci");
ciper = paket.getString("ciper");
nama = paket.getString("nama");
nomor = paket.getString("nomor");
namap.setText(nama);
pesane.setText(ciper);
data.inputKontak(nama, nomor);
data.inputEnkripsi(ciper, kunci);
data.inputPesan(idenkripsi, idkontak, pesan); //my line error
data.inputPesanKeluar(idpesan);
}
public void ambilKontak() {
Cursor cursorKontak = data.pilihKontak(nomor);
idkontak = cursorKontak.toString();
}
public void ambilEnkripsi() {
Cursor cursorEnkripsi = data.pilihEnkripsi(ciper);
idenkripsi = cursorEnkripsi.toString();
}
public void ambilPesan() {
Cursor cursorPesan = data.pilihPesan(pesan);
}
}
这是我的错误日志猫
Caused by: android.database.sqlite.SQLiteConstraintException: foreign key constraint failed: INSERT INTO TB_pesan ( fk_idenkripsi, fk_idkontak, plainteks )VALUES ( 'null', 'null', 'ndks' )
有人可以帮助我。我真的需要解决这个问题。我试图在互联网上搜索,但我没有得到我的申请的答案
答案 0 :(得分:0)
错误消息显示插入中使用的前两个值为null,并且这两个值是外键,我建议你看看使用的变量,它们没有得到值。 / p>
答案 1 :(得分:0)
上次我检查过:SQLite需要将所有表中的主键字段命名为“_id”。