草庐IT

Android SQLite - 主键 - 插入表

coder 2023-07-20 原文

我正处于为我的 Android 应用程序创建数据库的最后阶段,但是,我似乎无法让我的主键递增。这是我设置它的代码,

public class DatabaseHandler extends SQLiteOpenHelper {

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

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

    // Contacts table name
    public static final String TABLE_JOURNEY = "journey";

    // Contacts Table Columns names
    private static final String KEY_P = "key";
    private static final String KEY_ID = "id";
    private static final String KEY_DIST = "distance";
    private static final String KEY_MPG = "mpg";
    private static final String KEY_COST = "cost";

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

    // Creating Tables
    @Override
    public void onCreate(SQLiteDatabase db) {
        String CREATE_JOURNEY_TABLE = "CREATE TABLE " + TABLE_JOURNEY + "("
                + KEY_P + " INTEGER PRIMARY KEY," + KEY_ID + " TEXT," + KEY_DIST + " TEXT,"
                + KEY_MPG + " TEXT," + KEY_COST + " TEXT )";
        db.execSQL(CREATE_JOURNEY_TABLE);
    }

    // Upgrading database
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // Drop older table if existed
        db.execSQL("DROP TABLE IF EXISTS " + TABLE_JOURNEY);

        // Create tables again
        onCreate(db);
    }

    /**
     * All CRUD(Create, Read, Update, Delete) Operations
     */

    // Adding new contact
    void addJourneyData(Journey journey) {
        SQLiteDatabase db = this.getWritableDatabase();

        ContentValues values = new ContentValues();
        values.put(KEY_P, journey.getpKey());
        values.put(KEY_ID, journey.getId());
        values.put(KEY_DIST, journey.getDistance()); // Contact Name
        values.put(KEY_MPG, journey.getMpg()); // Contact Phone
        values.put(KEY_COST, journey.getCost()); // Contact Phone

        // Inserting Row
        db.insert(TABLE_JOURNEY, null, values);
        db.close(); // Closing database connection
    }

    // Getting single contact
    Journey getJourney(int id) {
        SQLiteDatabase db = this.getReadableDatabase();

        Cursor cursor = db.query(TABLE_JOURNEY, new String[] { KEY_P + KEY_ID + 
                KEY_DIST, KEY_MPG, KEY_COST }, KEY_P + "=?",
                new String[] { String.valueOf(id) }, null, null, null, null);
        if (cursor != null)
            cursor.moveToFirst();

        Journey journey = new Journey();
        journey.setPkey(Integer.parseInt(cursor.getString(0)));
        journey.setId(String.valueOf(cursor.getString(1)));
        journey.setMpg(String.valueOf(cursor.getString(2)));
        journey.setDistance(String.valueOf(cursor.getString(3)));
        journey.setCost(String.valueOf(cursor.getString(4)));
        // return contact
        return journey;
    }

    // Getting All Contacts
    public List<Journey> getAllJourneys() {
        List<Journey> journeyList = new ArrayList<Journey>();
        // Select All Query
        String selectQuery = "SELECT  * FROM " + TABLE_JOURNEY;

        SQLiteDatabase db = this.getWritableDatabase();
        Cursor cursor = db.rawQuery(selectQuery, null);

        // looping through all rows and adding to list
        if (cursor.moveToFirst()) {
            do {
                Journey journey = new Journey();
                journey.setPkey(Integer.parseInt(cursor.getString(0)));
                journey.setId(String.valueOf(cursor.getString(1)));
                journey.setMpg(String.valueOf(cursor.getString(2)));
                journey.setDistance(String.valueOf(cursor.getString(3)));
                journey.setCost(String.valueOf(cursor.getString(4)));
                // Adding contact to list
                journeyList.add(journey);
            } while (cursor.moveToNext());
        }

        // return contact list
        return journeyList;
    } 
}

这是我通过另一个 Activity 的按钮将详细信息添加到数据库的地方,

db.addJourneyData(new Journey(1,timeStamp, distanceLabel, mpgAnswer, pplAnswer));

我到了要点,它将添加第一个,但从那时起它会说主键不是唯一的 - 因此它不会更新数据库。

此外,我希望数据按降序排列,为此,我使用 DESC,但我应该将其放置在何处?

如有任何帮助,我们将不胜感激

非常感谢,

最佳答案

要使数据库自动为您生成主键,只需不要自己指定即可。从插入代码中删除这一行:

values.put(KEY_P, journey.getpKey());

可以从insert()的返回值中获取生成的id .

Also, I want the data to be in descending order, to do this, I use DESC, but where shall I place this?

假设这适用于执行 rawQuery()getAllJourneys(),只需在 SQL 中直接添加 ORDER BY:

String selectQuery = "SELECT  * FROM " + TABLE_JOURNEY + " ORDER BY " + KEY_P + " DESC";

关于Android SQLite - 主键 - 插入表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21833134/

有关Android SQLite - 主键 - 插入表的更多相关文章

  1. ruby - 如何在 Ruby 字符串中插入项目符号字符? - 2

    我正在尝试创建一个带有项目符号字符的Ruby1.9.3字符串。str="•"+"helloworld"但是,当我输入它时,我收到有关非ASCII字符的语法错误。我该怎么做? 最佳答案 你可以把Unicode字符放在那里。str="\u2022"+"helloworld" 关于ruby-如何在Ruby字符串中插入项目符号字符?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1195

  2. ruby - 在 ruby​​ 中使用自动创建插入数组 - 2

    我想知道是否可以通过自动创建数组来插入数组,如果数组不存在的话,就像在PHP中一样:$toto[]='titi';如果尚未定义$toto,它将创建数组并将“titi”压入。如果已经存在,它只会推送。在Ruby中我必须这样做:toto||=[]toto.push('titi')可以一行完成吗?因为如果我有一个循环,它会测试“||=”,除了第一次:Person.all.eachdo|person|toto||=[]#with1billionofperson,thislineisuseless999999999times...toto.push(person.name)你有更好的解决方案吗?

  3. ruby-on-rails - 在方法调用中插入 Ruby? - 2

    在我的用户模型中,我有一堆属性,例如is_foos_admin和is_bars_admin,它们决定允许用户编辑哪些类型的记录。我想干掉我的编辑链接,目前看起来像这样:'edit'ifcurrent_user.is_foos_admin?%>...'edit'ifcurrent_user.is_bars_admin?%>我想做一个帮助程序,让我传入一个foo或bar并返回一个链接来编辑它,就像这样:助手可能看起来像这样(这不起作用):defedit_link_for(thing)ifcurrent_user.is_things_admin?link_to'Edit',edit_poly

  4. Ruby 将对象插入现有的已排序对象数组 - 2

    我有以下现有的Dog对象数组,它们按age属性排序:classDogattr_accessor:agedefinitialize(age)@age=ageendenddogs=[Dog.new(1),Dog.new(4),Dog.new(10)]我现在想插入一条新的狗记录,并将它放在数组中的正确位置。假设我想插入这个对象:another_dog=Dog.new(8)我想把它插入到数组中,让它成为数组中的第三项。这是一个人为的示例,旨在演示我特别想如何将一个项目插入到现有的有序数组中。我意识到我可以创建一个全新的数组并重新对所有对象进行排序,但这不是我的目标。谢谢!

  5. Ruby:如何将条件插入字符串连接 - 2

    在字符串连接中,是否可以直接在语句中包含条件?在下面的示例中,我希望仅当dear列表不为空时才连接"mydear"。dear=""string="hello"+"mydear"unlessdear.empty?+",goodmorning!"但是结果报错:undefinedmethod'+'fortrue我知道另一种方法是在这条语句之前定义一个额外的变量,但我想避免这种情况。 最佳答案 使用插值而不是连接更容易和更具可读性:dear=""string="hello#{'mydear'unlessdear.empty?},goodmo

  6. ruby - 如何在数组中间插入一个数组? - 2

    我有一个Ruby数组[1,4]。我想在中间插入另一个数组[2,3],这样它就变成了[1,2,3,4]。我可以使用[1,4].insert(1,[2,3]).flatten实现这一点,但是有更好的方法吗? 最佳答案 您可以通过以下方式进行。[1,4].insert(1,*[2,3])insert()方法处理多个参数。因此,您可以使用splat运算符*将数组转换为参数。 关于ruby-如何在数组中间插入一个数组?,我们在StackOverflow上找到一个类似的问题:

  7. ruby - 用 ruby​​ 将 2 个破折号插入这个字符串的最短方法是什么? - 2

    这是字符串:04046955104021109我需要这样格式化:040469551-0402-1109用ruby​​做到这一点的最短/最有效的方法是什么? 最佳答案 两个简单的插入就可以了:example_string.insert(-9,'-').insert(-5,'-')负数表示您从字符串末尾开始计数。如果您愿意,也可以从头数起:example_string.insert(9,'-').insert(14,'-') 关于ruby-用ruby​​将2个破折号插入这个字符串的最短方法是

  8. ruby-on-rails - 如何将变量值插入 ERB 模板中的 HTML 标签? - 2

    我有一个偏爱:如何将像o.office这样的值插入到属性中?value="#{o.office}"无效。 最佳答案 'type='text'/>或者你可以使用表单助手 关于ruby-on-rails-如何将变量值插入ERB模板中的HTML标签?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/6172174/

  9. ruby-on-rails - Ruby on Rails PostGIS - 将多边形记录插入数据库 - 2

    我将RoR与PostGIS结合使用来存储位置数据。我正在尝试使用圆(例如,带半径的中心点)来存储估计位置。我试过类似的东西,但它不起作用:@location=Location.new(:place_id=>place.id,:circle=>%{ST_Buffer(ST_MakePoint(#{latitude},#{longitude})::geography,#{accuracy})})我也尝试过使用RGeo,它是出厂设置,但不确定如何准确使用它。任何帮助将不胜感激。谢谢。编辑1:我取得了一些进步。factory=RGeo::Cartesian.factorycenter_poin

  10. ruby - 以编程方式将数据插入 InDesign 文档 - 2

    我必须使用Adob​​eInDesign来创建文档。我们基本上需要在整个文档中有几个变量(公司名称、项目名称等)需要填写。我想知道是否有一种方法可以采用现有模板,并使用我熟悉的语言(Ruby、Python等)以编程方式填充这些模板。我尝试使用文本编辑器打开Adob​​eInDesign文件-但是当我使用Notepad++进行修改然后在InDesign中打开文件时,它告诉我文件已损坏。如果您对以编程方式构建InDesign文档有任何见解或了解任何教程,我们将不胜感激。附言我尝试查看Adob​​e的ExtendScript,但没有找到太多适用于InDesign的文档。感谢您的帮助!

随机推荐