Android execSQL不使用insert

Android execSQL不使用insert,android,sqlite,Android,Sqlite,我知道文档中说在这种情况下使用insert而不是execSQL更好,但我有一个非常大的sql文件,它包含6000条记录,使用execSQL更容易,但它不起作用 public class CitiesHandler extends SQLiteOpenHelper { // All Static variables // Database Version private static final int DATABASE_VERSION = 1; // Data

我知道文档中说在这种情况下使用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;
    }

}
public类CitiesHandler扩展SQLiteOpenHelper{
//所有静态变量
//数据库版本
私有静态最终int数据库_VERSION=1;
//数据库名称
私有静态最终字符串数据库\u NAME=“cities”;
//登录表名
私有静态最终字符串表_REGION=“REGION”;
私有静态最终字符串表\u CITY=“CITY”;
//登录表列名称
私有静态最终字符串密钥\u ID=“ID”;
私有静态最终字符串键\u NAME=“NAME”;
私有静态最终字符串密钥\u REGION\u ID=“REGION\u ID”;
私有静态最终字符串键\u PHONE=“PHONE\u code”;
公共城市管理员(上下文){
super(上下文、数据库名称、null、数据库版本);
}
//创建表
@凌驾
public void onCreate(SQLiteDatabase db){
String stregion=“创建表区域(id整数主键,名称文本)”;
数据库execSQL(stregion);
String insertRegion=“插入区域值(1,'Аааааааааааааааааааааааааааааааааааааааааа107 , (8, 'Запорожская область') , (9, 'Ивано-Франковская область') , (10, 'Киевская область') , (11, 'Кировоградская область') , (12, 'Луганская область') , (13, 'Львовская область') , (14, 'Николаевская область') , (15, 'Одесская область') , (16, 'Полтавская область') , (17, 'Ровенская область') , (18, 'Сумская область') , (19, 'Тернопольская область') , (20, 'Харьковская область') , (21, 'Херсонская область') , (22, 'Хмельницкая область') , (23, 'Черкасская область') , (24, 'Черниговская область') , (25, 'Черновицкая область')";
execSQL(insertRegion);
}
//升级数据库
@凌驾
public void onUpgrade(SQLiteDatabase db,int-oldVersion,int-newVersion){
//删除旧表(如果存在)
db.execSQL(“如果存在删除表”+表_CITY);
db.execSQL(“如果存在删除表”+表区域);
//再次创建表
onCreate(db);
}
公共字符串[]getRegions(){
HashMap用户=新建HashMap();
String selectQuery=“SELECT*FROM”+表格\区域;
SQLiteDatabase db=this.getReadableDatabase();
Cursor Cursor=db.rawQuery(selectQuery,null);
//移到第一排
cursor.moveToFirst();
if(cursor.getCount()>0){
user.put(“name”,cursor.getString(1));
}
cursor.close();
db.close();
字符串[]区域;
regions=新字符串[user.values().size()];
for(条目:user.entrySet()){
int i=0;
regions[i]=entry.getValue();
i++;
}
//返回用户
返回区;
}
public int getRegionID(字符串名称){
HashMap用户=新建HashMap();
String selectQuery=“SELECT*FROM”+表\区域+”其中name=“+名称;
SQLiteDatabase db=this.getReadableDatabase();
Cursor Cursor=db.rawQuery(selectQuery,null);
//移到第一排
cursor.moveToFirst();
if(cursor.getCount()>0){
user.put(“id”,cursor.getString(0));
}
cursor.close();
db.close();
//返回用户
返回Integer.valueOf(user.get(“id”);
}
公共字符串[]getCities(内部区域\u id){
HashMap用户=新建HashMap();
String selectQuery=“SELECT*FROM”+表格城市+”其中区域id=“+String.valueOf(区域id);
SQLiteDatabase db=this.getReadableDatabase();
Cursor Cursor=db.rawQuery(selectQuery,null);
//移到第一排
cursor.moveToFirst();
if(cursor.getCount()>0){
user.put(“name”,cursor.getString(1));
}
cursor.close();
db.close();
串[]个城市;
cities=新字符串[user.values().size()];
for(条目:user.entrySet()){
int i=0;
cities[i]=entry.getValue();
i++;
}
//返回用户
回归城市;
}
}
谢谢你的帮助


它不工作-这意味着每次它都是空的。insert语句没有实现。

我仍然会使用Android提供的
insert()
。从您的代码来看,您似乎没有正确地将参数传递给
值SQLite
命令。有关
插入到
中的解释,请参阅。

我总是在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();

确保您也有写权限。

您遇到了什么错误?请随时解释“它不工作”的原因意思是。为什么不使用SQliteDatabase基本查询方法…而不是使用rawQuery,因为您没有执行非常复杂的查询…Agree可能重复。这里有一个我会这样做,但我有一个大sql语句,不想解析它。这不是一个那么长的语句。我不知道解析是什么意思,但使用
insert()
仍然是一个更好的选择。
onCreate()
已经在一个事务中。这个正在工作,谢谢