2011-06-13 90 views
1

我是Android新手& SQlite。我试图在Android中的SQLite数据库上创建以下触发器。SQlite触发器执行问题

final String CREATE_TRIGGER_STATES = 
      "CREATE TRIGGER fk_insert_state BEFORE " 
      + "INSERT on tbl_states" 
      + "FOR EACH ROW " 
      + "BEGIN " 
      + "SELECT RAISE(ROLLBACK, 'insert on table " 
      + "\"tbl_states\" violates foreign key constraint " 
      + "\"fk_insert_state\"') WHERE (SELECT id FROM " 
      + "tbl_countries WHERE id = NEW.country_id) IS NULL; " 
      + "END;"; 
     db.execSQL(CREATE_TRIGGER_STATES); 

错误日志:

android.database.sqlite.SQLiteException: near "EACH": syntax error: CREATE TRIGGER fk_insert_state BEFORE INSERT on tbl_statesFOR EACH ROW BEGIN SELECT RAISE(ROLLBACK, 'insert on table "tbl_states" violates foreign key constraint "fk_insert_state"') WHERE (SELECT id FROM tbl_countries WHERE id = NEW.country_id) IS NULL; END; 

是否存在与语法有问题?

回答

2

我猜,错误信息的相关部分就在这里:

... on tbl_statesFOR EACH ROW ... 
//--------------^^ 

tbl_states后缺少空间:

final String CREATE_TRIGGER_STATES = 
      "CREATE TRIGGER fk_insert_state BEFORE " 
      + "INSERT on tbl_states " // Missing space added 
      //... Continue on as before. 
+0

是的,这是问题,它现在的作品!谢谢 – 2011-06-13 06:32:32

1

你忘了空间:

+ "INSERT on tbl_states " // Space missing here 
+ "FOR EACH ROW "