ormlite android,如何使用ormLite在android中的现有实体中添加新字段?

OLENT ENTITY:我有一个实体,我忘了在某些字段上添加@DatabaseField注释

@DatabaseTable

public class Card {

@DatabaseField(generatedId = true)

private int id;

@DatabaseField(unique = true)

private String cardNumber;

@DatabaseField

private String nameOnCard;

private String ccv;

private String validFrom;

private String validTill;

private String pin;

//Required by ormLite

public Card() {

}

//skipped the getter setters below

}

我有一个写配置的类,这里是代码.

package net.udevs.db;

import com.j256.ormlite.android.apptools.OrmLiteConfigUtil;

import net.udevs.entity.Card;

public class OrmLiteSqlLiteConfigGenerator extends OrmLiteConfigUtil {

private final static Class>[] entityClasses=new Class[]{EmailAccount.class, Card.class};

public static void main(String... args) throws Exception{

writeConfigFile("ormlite_config.txt",entityClasses);

}

}

生成的配置文件低于&通过查看它我知道数据库中的字段没有更新.

#

# generated on 2016/01/14 01:13:56

#

# --table-start--

dataClass=net.udevs.entity.Card

tableName=card

# --table-fields-start--

# --field-start--

fieldName=id

generatedId=true

# --field-end--

# --field-start--

fieldName=cardNumber

unique=true

# --field-end--

# --field-start--

fieldName=nameOnCard

# --field-end--

# --table-fields-end--

# --table-end--

#################################

NEW ENTITY:现在我添加了缺少的@DatabaseField注释.

public class Card {

@DatabaseField(generatedId = true)

private int id;

@DatabaseField(unique = true)

private String cardNumber;

@DatabaseField

private String nameOnCard;

@DatabaseField

private String ccv;

@DatabaseField

private String validFrom;

@DatabaseField

private String validTill;

@DatabaseField

private String pin;

public Card() {

}

public Card(int id, String cardNumber, String nameOnCard, String ccv, String validFrom, String validTill, String pin) {

this.id = id;

this.cardNumber = cardNumber;

this.nameOnCard = nameOnCard;

this.ccv = ccv;

this.validFrom = validFrom;

this.validTill = validTill;

this.pin = pin;

}

//skipped the getter setters below

}

&安培;然后我再次运行OrmLiteConfigUtil类,但配置文件没有改变.

解决方法:

您可以将@DatabaseField注释添加到缺少的字段并增加数据库版本,然后在onUpgrade方法中执行此操作

@Override

public void onUpgrade(SQLiteDatabase db, ConnectionSource connectionSource, int oldVersion, int newVersion) {

if(oldVersion == 1) {

try {

Dao dao = getCardDao();

dao.executeRaw("ALTER TABLE `Card` ADD COLUMN ccv STRING;");

dao.executeRaw("ALTER TABLE `Card` ADD COLUMN validFrom STRING;");

} catch (SQLException e) {

Log.e(DatabaseHelper.class.getName(), "Error ", e);

}

}

}

最后运行OrmLiteConfigUtil,配置文本文件将更改.

通过这种方式,您不必擦除数据库并丢失数据.

标签:android,ormlite

来源: https://codeday.me/bug/20190829/1760853.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值