以下代码用于在数据库中插入数据。
启动应用程序时,将执行以下代码。
执行RecentDBManager
后,当我从模拟器内存中PULL
数据库时,它在FavoriteScrip
表中没有显示任何记录。
当我在InsertStmt
方法中记录setData
时,它运行正常。
它显示
insert into FavoriteScrip(sym,cmp,chg) values ('value1','value2','value3')
但未插入表格中
在主要班级
rdbM = new RecentDBManager(CompanyView.this);
try {
if (!rdbM.checkDataBase()) {
rdbM.createDataBase();
}
rdbM.openDB();
rdbM.setData("value1");
rdbM.closeDB();
} catch (Exception e) {
throw new Error("ERROR in DB Access"+ e.toString());
}
RecentDBManager类
public class RecentDBManager {
private DatabaseHelper dataHelper;
private SQLiteDatabase mDb;
private Context ctx;
private String DATABASE_PATH = "/data/data/com.mypackage/databases/";
private static String DATABASE_NAME = "ScripMasterDB";
private static String TABLE_NAME = "FavoriteScrip";
private String InsertStmt;
private static final int DATABASE_VERSION = 1;
private Cursor cur;
RecentDBManager(Context ctx) {
this.ctx = ctx;
dataHelper = new DatabaseHelper(ctx);
}
private static class DatabaseHelper extends SQLiteOpenHelper {
Context myContext = null;
public DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
this.myContext = context;
}
@Override
public void onCreate(SQLiteDatabase db) {
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
Log.w("DBHelper", "Upgrading database from version " + oldVersion
+ " to " + newVersion + ", which will destroy all old data");
onCreate(db);
}
}
public boolean checkDataBase() {
String myPath = DATABASE_PATH + DATABASE_NAME;
File f = new File(myPath);
return f.exists();
}
public void createDataBase() {
openDB();
try {
OutputStream myOutput = new FileOutputStream(DATABASE_PATH+ DATABASE_NAME);
if (mDb.isOpen())
mDb.close();
myOutput.flush();
myOutput.close();
} catch (Exception e) {
throw new Error("RecentDbManager Exception - " + e.getMessage());
}
}
public RecentDBManager openDB() throws SQLException {
mDb = dataHelper.getWritableDatabase();
return this;
}
public void setData(String value1, String value2, String value3) {
ContentValues cv = new ContentValues();
cv.put("sym", value1);
cv.put("dt_tm", "datetime()");
mDb.insert(TABLE_NAME, null, cv);
} catch (SQLiteException e) {
throw new Error("RecentDbManager Exception in inserting data"
+ e.getMessage());
}
}
public void closeDB() {
try {
mDb.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
我有一列包含当前日期时间。
因此查询的格式为"insert into " + TABLE_NAME+ " (sym,dt_tm) values ('" + value1 + "',datetime())"
我试过
ContentValues cv = new ContentValues();
cv.put("sym", value1);
cv.put("dt_tm", "datetime()");
mDb.insert(TABLE_NAME, null, cv);
value1
列已插入表格但未插入日期时间。可能是什么问题?
完成......我使用了以下内容:
Calendar date1 = Calendar.getInstance();
SimpleDateFormat dateformatter = new SimpleDateFormat(
"dd/MM/yyyy HH:mm:ss");
String currentdate = dateformatter.format(date1
.getTime());
并将currentdate
作为第二个参数传递。
THNX ALL !!!!
任何帮助都将有益于生命!
答案 0 :(得分:3)
试
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(Create table Memo (ID INTEGER PRIMARY KEY AUTOINCREMENT, sym TEXT, cmp TEXT, cng TEXT);
}
public void setData(String value1, String value2, String value3) {
ContentValues cv = new ContentValues();
cv.put("sym", value1);
cv.put("cmp", value2);
cv.put("cng", value3);
mDb.insert(TABLE_NAME, null, cv);
}
答案 1 :(得分:1)
尝试在insert语句的tablename后面留一个空格:
insert into FavoriteScrip (sym,cmp,chg) values ('value1','value2','value3')
InsertStmt="insert into " + TABLE_NAME + " (sym,cmp,chg) values ('" + value1 + "','" + value2 + "','" + value3 + "')";
答案 2 :(得分:0)
尝试使用insert代替原始查询