execSQL不能使用insert

时间:2013-12-08 21:27:17

标签: android sqlite

我知道文档说在这种情况下使用insert而不是execSQL会更好,但我有一个非常大的sql文件,包含6000条记录,而且我更容易使用execSQL,但它不能正常工作

public class CitiesHandler extends SQLiteOpenHelper {

    // All Static variables
    // Database Version
    private static final int DATABASE_VERSION = 1;

    // Database Name
    private static final String DATABASE_NAME = "cities";

    // Login table name
    private static final String TABLE_REGION= "region";
    private static final String TABLE_CITY= "city";
    // Login Table Columns names
    private static final String KEY_ID = "id";
    private static final String KEY_NAME = "name";
    private static final String KEY_REGION_ID = "region_id";
    private static final String KEY_PHONE = "phone_code";

    public CitiesHandler(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }

    // Creating Tables
    @Override
    public void onCreate(SQLiteDatabase db) {
        String strRegion="CREATE TABLE region (id INTEGER PRIMARY KEY,name TEXT)";
        db.execSQL(strRegion);
        String insertRegion="INSERT INTO region Values   (1, 'АР Крым') , (2, 'Винницкая область') , (3, 'Волынская область') , (4, 'Днепропетровская область') , (5, 'Донецкая область') , (6, 'Житомирская область') , (7, 'Закарпатская область') , (8, 'Запорожская область') , (9, 'Ивано-Франковская область') , (10, 'Киевская область') , (11, 'Кировоградская область') , (12, 'Луганская область') , (13, 'Львовская область') , (14, 'Николаевская область') , (15, 'Одесская область') , (16, 'Полтавская область') , (17, 'Ровенская область') , (18, 'Сумская область') , (19, 'Тернопольская область') , (20, 'Харьковская область') , (21, 'Херсонская область') , (22, 'Хмельницкая область') , (23, 'Черкасская область') , (24, 'Черниговская область') , (25, 'Черновицкая область')";
        db.execSQL(insertRegion);
    }

    // Upgrading database
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // Drop older table if existed
        db.execSQL("DROP TABLE IF EXISTS " + TABLE_CITY);
        db.execSQL("DROP TABLE IF EXISTS " + TABLE_REGION);
        // Create tables again
        onCreate(db);
    }

    public String[] getRegions(){
        HashMap<String,String> user = new HashMap<String,String>();
        String selectQuery = "SELECT  * FROM " + TABLE_REGION;

        SQLiteDatabase db = this.getReadableDatabase();
        Cursor cursor = db.rawQuery(selectQuery, null);
        // Move to first row
        cursor.moveToFirst();
        if(cursor.getCount() > 0){
            user.put("name", cursor.getString(1));
        }
        cursor.close();
        db.close();
        String [] regions;
        regions=new String[user.values().size()];
        for (Entry<String, String> entry : user.entrySet()) {
            int i=0;
            regions[i] = entry.getValue();      
            i++;
        }
        // return user
        return regions;
    }

    public int getRegionID(String name){
        HashMap<String,String> user = new HashMap<String,String>();
        String selectQuery = "SELECT  * FROM " + TABLE_REGION+" WHERE name="+name;

        SQLiteDatabase db = this.getReadableDatabase();
        Cursor cursor = db.rawQuery(selectQuery, null);
        // Move to first row
        cursor.moveToFirst();
        if(cursor.getCount() > 0){
            user.put("id", cursor.getString(0));
        }
        cursor.close();
        db.close();
        // return user
        return Integer.valueOf(user.get("id"));
    }

    public String[] getCities(int region_id){
        HashMap<String,String> user = new HashMap<String,String>();
        String selectQuery = "SELECT  * FROM " + TABLE_CITY+" WHERE region_id="+String.valueOf(region_id);

        SQLiteDatabase db = this.getReadableDatabase();
        Cursor cursor = db.rawQuery(selectQuery, null);
        // Move to first row
        cursor.moveToFirst();
        if(cursor.getCount() > 0){
            user.put("name", cursor.getString(1));
        }
        cursor.close();
        db.close();
        String [] cities;
        cities=new String[user.values().size()];
        for (Entry<String, String> entry : user.entrySet()) {
            int i=0;
            cities[i] = entry.getValue();       
            i++;
        }
        // return user
        return cities;
    }

}

感谢您的帮助

它不起作用 - 这意味着每次它都是空的。插入语句未得到满足。

2 个答案:

答案 0 :(得分:3)

我仍然会使用Android提供的insert()。您的代码似乎没有正确地将参数传递给VALUES SQLite命令。有关INSERT INTO的解释,请参阅here

答案 1 :(得分:2)

我总是在beginTransaction和EndTransaction之间使用execSQL,你试过吗?

以下是代码的摘录:

String cmd = "QUERY FOR EXECUTE";
SQLiteDatabase db = dbHelper.getWritableDatabase();
db.beginTransaction();

if (cmd.trim().length() > 0) {
    db.execSQL(cmd);
}

db.setTransactionSuccessful();
db.endTransaction();
db.close();

确保您也有写权限。