我正在创建一个应用程序,其中包含存储在SQLitedatabase中的数据。我使用long作为主键(生成购买java.util.UUID的重要位)。我使用扩展的SQLiteOpenHelper处理数据库连接。查询:
INSERT INTO Categorys VALUES('-7311183930966261019', 'Mat', 'Matkonto', '#FFFFFF', '#F23341', '0', '231451', '0', '0', '');
没有问题,但是当我在第一个值-7311183930966261019中检索到很多精度的值时,已经丢失了。查询
SELECT * FROM Categorys WHERE _id='-7311183930966261019';
返回null;
我在sqlite3和命令行中尝试了相同的查询而没有遇到同样的问题所以我得出的结论是问题与android或我的处理方式有关。
更新: 在纠正了我现在的查询后:
INSERT INTO Categorys VALUES(-6645129292311215613, 'Sparande', 'Pengar som sparas inför framtiden', '#FFFFFF', '#F23341', '0', '231451', '0', 0, '');
从数据库中我得到(来自我班级的toString()):
Category: name: Sparande; description: Pengar som sparas inför framtiden; colorLight: #FFFFFF; colorDark: #F23341 _id: -6645129292311215104
检索数据的代码:
public static List<Category> readCategorys(Context context){
TransactionSQLOH helper = new TransactionSQLOH(context, DATABASE_NAME);
SQLiteDatabase db = helper.getReadableDatabase();
Cursor cursor = db.query(CategorySQLOH.TABLE_NAME, CategorySQLOH.COLUMNS, null, null, null, null, null);
List<Category> result = CategorySQLOH.cursorToCategory(cursor);
helper.close();
return result;
}
public static List<Category> cursorToCategory(Cursor cursor){
List<Category> result = new Vector<Category>();
if (cursor == null || cursor.getCount() == 0){
return result;
}
cursor.moveToFirst();
Category c;
do{
long _id = cursor.getLong(cursor.getColumnIndex(CategorySQLOH.COLUMNS[0]));
String name = cursor.getString(cursor.getColumnIndex(CategorySQLOH.COLUMNS[1]));
String description= cursor.getString(cursor.getColumnIndex(CategorySQLOH.COLUMNS[2]));
String colorLight = cursor.getString(cursor.getColumnIndex(CategorySQLOH.COLUMNS[3]));
String colorDark = cursor.getString(cursor.getColumnIndex(CategorySQLOH.COLUMNS[4]));
int destribution = cursor.getInt(cursor.getColumnIndex(CategorySQLOH.COLUMNS[5]));
long categoryGroup = cursor.getLong(cursor.getColumnIndex(CategorySQLOH.COLUMNS[6]));
int intData = cursor.getInt(cursor.getColumnIndex(CategorySQLOH.COLUMNS[7]));
long longData = cursor.getLong(cursor.getColumnIndex(CategorySQLOH.COLUMNS[8]));
String strData = cursor.getString(cursor.getColumnIndex(CategorySQLOH.COLUMNS[9]));
c = new Category(_id, name, description, colorLight, colorDark, destribution, categoryGroup, intData, longData, strData);
result.add(c);
}while(cursor.moveToNext());
return result;
}
更新
SELECT * FROM Categorys的结果;在拉出的数据库上:
sqlite> SELECT * FROM Categorys;
-6.64512929231122e+18|Sparande|Pengar som sparas inf├Âr framtiden|#FFFFFF|#F2334
1|0|231451.0|0|0.0|
更新:
.schema对拉数据库的结果。
CREATE TABLE Categorys ( _id REAL PRIMARY KEY, name TEXT NOT NULL, description T
EXT , colorLight TEXT , colorDark TEXT , destribution INTEGER , categoryGroup RE
AL , intData INTEGER , longData REAL , strData TEXT );
CREATE TABLE android_metadata (locale TEXT);
答案 0 :(得分:1)
Android:long =&gt; SQLiteDatabase =&gt;长,精确丢失
我想,因为你将它定义为LONG
我认为你需要删除单引号,因为引号,SQLite将其解释为几个字符而不是数字。
INSERT INTO Categorys VALUES(-7311183930966261019, 'Mat', ...);
SELECT * FROM Categorys WHERE _id = -7311183930966261019;
我自己测试过,一切正常。