Android orm mysql_[Android]Android端ORM框架——RapidORM(v1.0)

以下内容为原创,欢迎转载,转载请注明

Android上主流的ORM框架有很多,常用的有ORMLite、GreenDao等。

ORMLite:

-优点:API很友好,使用比较方便简单稳定,相关功能比较完整。

-缺点:内部使用反射实现,性能并不是很好。

GreenDao:

-优点:性能很不错,

-缺点:API却不太友好,而且不支持复合主键,主键必须要有并且必须是long或者Long。持久类可以用它提供的模版生成,但是一旦使用了它的模版,持久类、DAO就不能随意去修改,扩展性不是很好。如果不使用它的模版,代码写起来就很繁琐。

特点:

1. 支持使用反射和非反射(模版生成)两种方式实现执行SQL。

2. 支持复合主键

3. 支持任何主键类型

4. 兼容android原生的 android.database.sqlite.SQLiteDatabase 和SqlCipher的 net.sqlcipher.database.SQLiteDatabase。

缺点:

1. 不支持链表查询。

快速指南:

一、新建持久类Person:

1 /**

2 * Author: wangjie3 * Email: tiantian.china.2@gmail.com4 * Date: 6/25/15.5 */

6 @Table(propertyClazz = PersonProperty.class)7 public class Person implementsSerializable{8

9 @Column(primaryKey = true)10 privateInteger id;11

12 @Column(primaryKey = true)13 privateInteger typeId;14

15 @Column16 privateString name;17

18 @Column19 privateInteger age;20

21 @Column22 privateString address;23

24 @Column25 privateLong birth;26

27 @Column28 privateBoolean student;29

30 //getter/setter...

31

32 }

1. Table注解用于标记这个类需要映射到数据表,RapidORM会创建这个表。

-name属性:表示对应表的名称,默认为类的simpleName。

-propertyClazz属性:表示如果不使用反射执行sql时,需要的ModelProperty类的Class,RapidORM会自动在这个ModelProperty中去绑定需要执行SQL的数据。不填写则表示使用默认的反射的方式执行SQL。具体后面会讲到。

2. Column注解用语标记这个字段映射到的数据表的列(如果)。

-name属性:表示对应列的名称。默认为字段的名称。

-primaryKey属性:表示改列是否是主键,默认是false。(可以在多个字段都适用这个属性,表示为复合主键)。

-autoincrement属性:表示主键是否是自增长,只有该字段是主键并且只有一个主键并且是Integer或int类型才会生效。

-defaultValue属性:表示该列默认值。

-notNull属性:表示该列不能为空。

-unique属性:表示该列唯一约束。

-uniqueCombo属性:暂未实现。

-index属性:暂未实现。

二、注册持久类,并指定SQLiteOpenHelper:

新建类DatabaseFactory,继承RapidORMConnection:

1 /**

2 * Author: wangjie3 * Email: tiantian.china.2@gmail.com4 * Date: 6/25/15.5 */

6 public class DatabaseFactory extends RapidORMConnection{7 private static final int VERSION = 1;8

9 private staticDatabaseFactory instance;10

11 public synchronized staticDatabaseFactory getInstance() {12 if (null ==instance) {13 instance = newDatabaseFactory();14 }15 returninstance;16 }17

18 privateDatabaseFactory() {19 super();20 }21

22 @Override23 protectedRapidORMDefaultSQLiteOpenHelperDelegate getRapidORMDatabaseOpenHelper(@NonNull String databaseName) {24 return new RapidORMDefaultSQLiteOpenHelperDelegate(newMyDatabaseOpenHelper(MyApplication.getInstance(), databaseName, VERSION));25 }26

27 @Override28 protected List>registerAllTableClass() {29 List> allTableClass = new ArrayList<>();30 allTableClass.add(Person.class);31 //all table class

32 returnallTableClass;33 }34 }

DatabaseFactory推荐使用单例,实现RapidORMConnection的getRapidORMDatabaseOpenHelper()方法,该方法需要返回一个RapidORMDatabaseOpenHelperDelegate或者它的子类对象,RapidORMDatabaseOpenHelperDelegate是SQLiteOpenHelper的委托,因为需要兼容android原生的 android.database.sqlite.SQLiteDatabase 和SqlCipher的 net.sqlcipher.database.SQLiteDatabase 两种方式。

如果使用 android.database.sqlite.SQLiteDatabase ,则可以使用RapidORMDefaultSQLiteOpenHelperDelegate,然后构造方法中传入真正的android.database.sqlite.SQLiteDatabase (也就是这里的MyDatabaseOpenHelper)即可,使用SqlCipher的方式后面再讲。

还需要实现registerAllTableClass()方法,这里返回一个所有需要映射表的持久类Class集合。

三、在需要的地方进行初始化RapidORM(比如在登录完成之后):

DatabaseFactory.getInstance().resetDatabase("hello_rapid_orm.db");

如上,调用resetDatabase()方法即可初始化数据库。

四、编写Dao:

新建PersonDaoImpl继承BaseDaoImpl(这里简略了PersonDao接口):

1 /**

2 * Author: wangjie3 * Email: tiantian.china.2@gmail.com4 * Date: 6/26/15.5 */

6 public class PersonDaoImpl extends BaseDaoImpl{7 publicPersonDaoImpl() {8 super(Person.class);9 }10

11 }

BaseDaoImpl中默认实现了下面的基本方法(T为范型,指具体的持久类):

-void insert(T model) throws Exception;  // 插入一条数据。

-void update(T model) throws Exception;  // 更新一条数据。

-void delete(T model) throws Exception;  // 删除一条数据。

-void deleteAll() throws Exception;      // 删除表中所有的数据

-void insertOrReplace(T model) throws Exception;    // 删除或者替换(暂不支持)

-List queryAll() throws Exception;      // 查询表中所有数据

-List rawQuery(String sql, String[] selectionArgs) throws Exception;      // 使用原生sql查询表中所有的数据

-void rawExecute(String sql, Object[] bindArgs) throws Exception;        // 使用原生sql执行一条sql语句

-void insertInTx(T... models) throws Exception;          // 插入多条数据(在一个事务中)

-void insertInTx(Iterable models) throws Exception;      // 同上

-void updateInTx(T... models) throws Exception;          // 更新多条数据(在一个事务中)

-void updateInTx(Iterable models) throws Exception;      // 同上

-void deleteInTx(T... models) throws Exception;            // 删除多条数据(在一个事务中)

-void deleteInTx(Iterable models) throws Exception;        // 同上

-void executeInTx(RapidORMSQLiteDatabaseDelegate db, RapidOrmFunc1 func1) throws Exception; // 执行一个方法(可多个sql),在一个事务中

-void executeInTx(RapidOrmFunc1 func1) throws Exception;    // 同上

面向对象的方式使用Where和Builder来构建sql语句:

1. Where:

Where表示一系列的条件语句,含义与SQL中的where关键字一致。

支持的where操作:

-eq(String column, Object value)    // 相等条件判断

-ne(String column, Object value)    // 不相等条件判断

-gt(String column, Object value)     // 大于条件判断

-lt(String column, Object value)     // 小于条件判断

-ge(String column, Object value)     // 大于等于条件

-le(String column, Object value)     // 小于等于条件

-in(String column, Object... values)    // 包含条件

-ni(String column, Object... values)    // 不包含条件

-isNull(String column)          // null条件判断

-notNull(String column)         // 不为null条件判断

-between(String column, Object value1, Object value2)  // BETWEEN ... AND ..." condition

-like(String column, Object value)      // 模糊匹配条件

-Where raw(String rawWhere, Object... values)  // 原生sql条件

-and(Where... wheres)          // 多个Where与

-or(Where... wheres)          // 多个Where或

Where举例:

1 Where.and(2 Where.like(PersonProperty.name.column, "%wangjie%"),3 Where.lt(PersonProperty.id.column, 200),4 Where.or(5 Where.between(PersonProperty.age.column, 19, 39),6 Where.isNull(PersonProperty.address.column)7 ),8 Where.eq(PersonProperty.typeId.column, 1)9 )

如上,

Line2条件:name模糊匹配wangjie

Line3条件:id小于200

Line5条件:age在19到39之间

Line6条件:address不是null

Line8条件:typeId等于1

Line4条件:Line5条件和Line6条件是or关系;

Line1条件:Line2、Line3、Line4、Line8条件是and关系。

2. QueryBuilder:

QueryBuilder用于构建查询语句。

-setWhere(Where where)    // 设置Where条件;

-setLimit(Integer limit)      // 设置limit

-addSelectColumn(String... selectColumn)    // 设置查询的数据列名(可以调用多遍来设置多个,默认是查询所有数据)

-addOrder(String column, boolean isAsc)     // 设置查询结果的排序(可以调用多遍来设置多个)

QueryBuilder举例:

1 public List findPersonsByWhere() throwsException {2 returnqueryBuilder()3 .addSelectColumn(PersonProperty.id.column, PersonProperty.typeId.column, PersonProperty.name.column,4 PersonProperty.age.column, PersonProperty.birth.column, PersonProperty.address.column)5 .setWhere(Where.and(6 Where.like(PersonProperty.name.column, "%wangjie%"),7 Where.lt(PersonProperty.id.column, 200),8 Where.or(9 Where.between(PersonProperty.age.column, 19, 39),10 Where.isNull(PersonProperty.address.column)11 ),12 Where.eq(PersonProperty.typeId.column, 1)13 ))14 .addOrder(PersonProperty.id.column, false)15 .addOrder(PersonProperty.name.column, true)16 .setLimit(10)17 .query(this);18 }

如上,通过queryBuilder()方法构建一个QueryBuilder,并设置查询的列名、Where、排序、limit等参数,最后调用query()执行查询。

3. UpdateBuilder:

UpdateBuilder用于构建更新语句。

-setWhere(Where where)    // 设置Where条件;

-addUpdateColumn(String column, Object value)    // 添加需要更新的字段;

UpdateBuilder举例:

1 public void updatePerson() throwsException {2 long now =System.currentTimeMillis();3 updateBuilder()4 .setWhere(Where.and(5 Where.like(PersonProperty.name.column, "%wangjie%"),6 Where.lt(PersonProperty.id.column, 200),7 Where.or(8 Where.between(PersonProperty.age.column, 19, 39),9 Where.isNull(PersonProperty.address.column)10 ),11 Where.eq(PersonProperty.typeId.column, 1)12 ))13 .addUpdateColumn(PersonProperty.birth.column, now)14 .addUpdateColumn(PersonProperty.address.column, "address_" + now).update(this);15 }

如上,通过updateBuilder()方法构建一个UpdateBuilder,并设置要更新的字段,最后调用update()执行查询。

4. DeleteBuilder:

DeleteBuilder用于构建删除语句。

-setWhere(Where where)    // 设置Where条件;

DeleteBuilder举例:

1 public void deletePerson() throwsException {2 deleteBuilder()3 .setWhere(Where.and(4 Where.like(PersonProperty.name.column, "%wangjie%"),5 Where.lt(PersonProperty.id.column, 200),6 Where.or(7 Where.between(PersonProperty.age.column, 19, 39),8 Where.isNull(PersonProperty.address.column)9 ),10 Where.eq(PersonProperty.typeId.column, 1)11 ))12 .delete(this);13 }

如上,通过deleteBuilder()方法构建一个DeleteBuilder,并设置Where条件,最后调用delete()执行查询。

使用模版生成ModelProperty:

如果你打算使用非反射的方式执行sql,则可以使用ModelPropertyGenerator模版来生成

1. 新建一个类,在main方法中执行:

/*** Author: wangjie

* Email: tiantian.china.2@gmail.com

* Date: 7/2/15.*/

public classMyGenerator {public static void main(String[] args) throwsException {

Class tableClazz= Person.class;newModelPropertyGenerator().generate(tableClazz,"example/src/main/java",

tableClazz.getPackage().getName()+ ".config");

}

}

如上,generate()方法参数如下:

generate(Class tableClazz, String outerDir, String packageName)

参数一:要生成的Property持久类的Class

参数二:生成的ModelProperty类文件存放目录

参数三:生成的ModelProperty类文件的包名

执行完毕后,就会在com.wangjie.rapidorm.example.database.model.config包下生成如下的ModelProperty:

1 //THIS CODE IS GENERATED BY RapidORM, DO NOT EDIT.

2 /**

3 * Property of Person4 */

5 public class PersonProperty implements IModelProperty{6

7 public static final ModelFieldMapper id = new ModelFieldMapper(0, "id", "id");8 public static final ModelFieldMapper typeId = new ModelFieldMapper(1, "typeId", "typeId");9 public static final ModelFieldMapper name = new ModelFieldMapper(2, "name", "name");10 public static final ModelFieldMapper age = new ModelFieldMapper(3, "age", "age");11 public static final ModelFieldMapper address = new ModelFieldMapper(4, "address", "address");12 public static final ModelFieldMapper birth = new ModelFieldMapper(5, "birth", "birth");13 public static final ModelFieldMapper student = new ModelFieldMapper(6, "student", "student");14

15 publicPersonProperty() {16 }17

18

19 @Override20 public void bindInsertArgs(Person model, ListinsertArgs) {21 Integer id =model.getId();22 insertArgs.add(null == id ? null: id);23

24 Integer typeId =model.getTypeId();25 insertArgs.add(null == typeId ? null: typeId);26

27 String name =model.getName();28 insertArgs.add(null == name ? null: name);29

30 Integer age =model.getAge();31 insertArgs.add(null == age ? null: age);32

33 String address =model.getAddress();34 insertArgs.add(null == address ? null: address);35

36 Long birth =model.getBirth();37 insertArgs.add(null == birth ? null: birth);38

39 Boolean student =model.isStudent();40 insertArgs.add(null == student ? null : student ? 1 : 0);41

42 }43

44 @Override45 public void bindUpdateArgs(Person model, ListupdateArgs) {46 String name =model.getName();47 updateArgs.add(null == name ? null: name);48

49 Integer age =model.getAge();50 updateArgs.add(null == age ? null: age);51

52 String address =model.getAddress();53 updateArgs.add(null == address ? null: address);54

55 Long birth =model.getBirth();56 updateArgs.add(null == birth ? null: birth);57

58 Boolean student =model.isStudent();59 updateArgs.add(null == student ? null : student ? 1 : 0);60

61 }62

63 @Override64 public void bindPkArgs(Person model, ListpkArgs) {65 Integer id =model.getId();66 pkArgs.add(null == id ? null: id);67

68 Integer typeId =model.getTypeId();69 pkArgs.add(null == typeId ? null: typeId);70

71 }72

73 @Override74 publicPerson parseFromCursor(Cursor cursor) {75 Person model = newPerson();76 intindex;77 index = cursor.getColumnIndex("id");78 if(-1 !=index){79 model.setId(cursor.isNull(index) ? null: (cursor.getInt(index)));80 }81

82 index = cursor.getColumnIndex("typeId");83 if(-1 !=index){84 model.setTypeId(cursor.isNull(index) ? null: (cursor.getInt(index)));85 }86

87 index = cursor.getColumnIndex("name");88 if(-1 !=index){89 model.setName(cursor.isNull(index) ? null: (cursor.getString(index)));90 }91

92 index = cursor.getColumnIndex("age");93 if(-1 !=index){94 model.setAge(cursor.isNull(index) ? null: (cursor.getInt(index)));95 }96

97 index = cursor.getColumnIndex("address");98 if(-1 !=index){99 model.setAddress(cursor.isNull(index) ? null: (cursor.getString(index)));100 }101

102 index = cursor.getColumnIndex("birth");103 if(-1 !=index){104 model.setBirth(cursor.isNull(index) ? null: (cursor.getLong(index)));105 }106

107 index = cursor.getColumnIndex("student");108 if(-1 !=index){109 model.setStudent(cursor.isNull(index) ? null : (cursor.getInt(index) == 1));110 }111

112 returnmodel;113 }114

115 }

注意:此Property类一旦生成,则不能修改;如果该持久类相关的注解属性改变,则需要重新生成这个Property类。

2. 在相应的持久类的@Table注解中设置propertyClazz:

1 @Table(propertyClazz = PersonProperty.class)2 public class Person implements Serializable{

如何兼容SqlCipher

1. 新建MySQLCipherOpenHelper,继承net.sqlcipher.database.SQLiteOpenHelper:

1 importandroid.content.Context;2 importcom.wangjie.rapidorm.core.dao.DatabaseProcessor;3 importcom.wangjie.rapidorm.core.delegate.database.RapidORMSQLiteDatabaseDelegate;4 importnet.sqlcipher.database.SQLiteDatabase;5 importnet.sqlcipher.database.SQLiteDatabaseHook;6 importnet.sqlcipher.database.SQLiteOpenHelper;7

8 /**

9 * Author: wangjie10 * Email: tiantian.china.2@gmail.com11 * Date: 8/17/15.12 */

13 public class MySQLCipherOpenHelper extendsSQLiteOpenHelper {14

15 privateRapidORMSQLiteDatabaseDelegate rapidORMSQLiteDatabaseDelegate;16

17 public MySQLCipherOpenHelper(Context context, String name, intversion) {18 super(context, name, null, version);19 }20

21 public MySQLCipherOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, intversion) {22 super(context, name, factory, version);23 }24

25 public MySQLCipherOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, intversion, SQLiteDatabaseHook hook) {26 super(context, name, factory, version, hook);27 }28

29 @Override30 public voidonCreate(SQLiteDatabase db) {31 //super.onCreate(db);

32 rapidORMSQLiteDatabaseDelegate = newMySQLCipherDatabaseDelegate(db);33 DatabaseProcessor databaseProcessor =DatabaseProcessor.getInstance();34 for (Class>tableClazz : databaseProcessor.getAllTableClass()) {35 databaseProcessor.createTable(rapidORMSQLiteDatabaseDelegate, tableClazz, true);36 }37 }38

39 @Override40 public void onUpgrade(SQLiteDatabase db, int oldVersion, intnewVersion) {41 //super.onUpgrade(db, oldVersion, newVersion);

42 rapidORMSQLiteDatabaseDelegate = newMySQLCipherDatabaseDelegate(db);43 DatabaseProcessor databaseProcessor =DatabaseProcessor.getInstance();44 //todo: dev only!!!!!

45 databaseProcessor.dropAllTable(rapidORMSQLiteDatabaseDelegate);46

47 }48 }

2. 新建MySQLCipherDatabaseDelegate继承RapidORMSQLiteDatabaseDelegate,并实现以下的方法:

1 importandroid.database.Cursor;2 importandroid.database.SQLException;3 importcom.wangjie.rapidorm.core.delegate.database.RapidORMSQLiteDatabaseDelegate;4 importnet.sqlcipher.database.SQLiteDatabase;5

6 /**

7 * Author: wangjie8 * Email: tiantian.china.2@gmail.com9 * Date: 8/17/15.10 */

11 public class MySQLCipherDatabaseDelegate extends RapidORMSQLiteDatabaseDelegate{12 publicMySQLCipherDatabaseDelegate(SQLiteDatabase db) {13 super(db);14 }15

16 @Override17 public void execSQL(String sql) throwsSQLException {18 db.execSQL(sql);19 }20

21 @Override22 public booleanisDbLockedByCurrentThread() {23 returndb.isDbLockedByCurrentThread();24 }25

26 @Override27 public void execSQL(String sql, Object[] bindArgs) throwsException {28 db.execSQL(sql, bindArgs);29 }30

31 @Override32 publicCursor rawQuery(String sql, String[] selectionArgs) {33 returndb.rawQuery(sql, selectionArgs);34 }35

36 @Override37 public voidbeginTransaction() {38 db.beginTransaction();39 }40

41 @Override42 public voidsetTransactionSuccessful() {43 db.setTransactionSuccessful();44 }45

46 @Override47 public voidendTransaction() {48 db.endTransaction();49 }50

51 @Override52 public voidclose() {53 db.close();54 }55 }

注意这里的import,这里的SQLiteDatabase需要导入 net.sqlcipher.database.SQLiteDatabase 。

3. 新建MySQLCipherOpenHelperDelegate继承RapidORMDatabaseOpenHelperDelegate,实现如下方法:

1 importcom.wangjie.rapidorm.core.delegate.openhelper.RapidORMDatabaseOpenHelperDelegate;2 3

4 /**

5 * Author: wangjie6 * Email: tiantian.china.2@gmail.com7 * Date: 6/18/15.8 */

9 public class MySQLCipherOpenHelperDelegate extends RapidORMDatabaseOpenHelperDelegate{10 publicMySQLCipherOpenHelperDelegate(MySQLCipherOpenHelper sqLiteOpenHelper) {11 super(sqLiteOpenHelper);12 }13

14 public static final String SECRET_KEY = "1234567890abcdef";15

16 @Override17 publicMySQLCipherOpenHelperDelegate getReadableDatabase() {18 return newMySQLCipherDatabaseDelegate(openHelper.getReadableDatabase(SECRET_KEY));19 }20

21 @Override22 publicMySQLCipherOpenHelperDelegate getWritableDatabase() {23 return newMySQLCipherDatabaseDelegate(openHelper.getWritableDatabase(SECRET_KEY));24 }25

26 }

4. 在DatabaseFactory中使用SqlCipher版本:

1 /**

2 * Author: wangjie3 * Email: tiantian.china.2@gmail.com4 * Date: 6/25/15.5 */

6 public class DatabaseFactory extends RapidORMConnection{7 private static final int VERSION = 1;8

9 private staticDatabaseFactory instance;10

11 public synchronized staticDatabaseFactory getInstance() {12 if (null ==instance) {13 instance = newDatabaseFactory();14 }15 returninstance;16 }17

18 privateDatabaseFactory() {19 super();20 }21

22 @Override23 protectedMySQLCipherOpenHelperDelegate getRapidORMDatabaseOpenHelper(@NonNull String databaseName) {24 return new MySQLCipherOpenHelperDelegate(newMySQLCipherOpenHelper(applicationContext, databaseName, VERSION));25 }26

27 @Override28 protected List>registerAllTableClass() {29 List> allTableClass = new ArrayList<>();30 allTableClass.add(Person.class);31 //register all table class here...

32 returnallTableClass;33 }34 }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MiniOrm-for-Android是什么? MiniOrm-for-android  是一款简单,只能,灵活的android ORM框架,完全基于对象进行操作。主要帮助android程序员的快速开发。通过反射将查询的数据智能的转换成 Entity 。省去开发人员手动解析的时间。 功能特点: 小巧,类库大小27k 快速,10000条数据,时长3.6秒 使用简单,支持实体类注解方式,除了实体类之外只需创建一个DAO就可以进行操作。 支持原声的sql语句操作 耦合性低 结构模型: 类关系图: 纯java结构设计,通过接口的设计,将上层业务和实际操作数据库的部分进行分离,开发者可以在此基础上自行实现mysql等数据的支持。下面是java部分核心设计 接入类库: 在项目的程序目录build.gradle中加入 dependencies {      compile 'com.ml.miniorm:miniorm:1.1.8'  } 基本方法: 创建表: StuDao stuDao=new StuDao(); stuDao.createTable();  新增: Student student=new Student();  student.setAge(2);  student.setStuName("王小明"); new StuDao().save(student);  删除:    //1. 根据主键删除student.setId(2);new StudentDao().delete(student); //2.根据其他属性删除 student.setStuName("kkkk");     student.setAge(2); stuDao.delete(student); //3.删除全部 stuDao.deleteAll(); 更新:  // (注意,需指定ID) student.setId(2); student.setStuName("kkkk"); stuDao.update(student); 查询: //全部 List<Student> list=stuDao.queryAll(); //query  by id stuDao.queryById(1)||stuDao.queryById(“1” 精确条件查询 可以写sql语句 然后直接调用方法 teacherDao.executeQuery("select * from usertable",teacherDao.getQueryEntity(),teacherDao.getReflexEntity() ); 调用QueryBuilder //查询 全部 性别为 女 List listaaa=teacherDao.getQueryBuilder().callQuery().queryAll().where(Where.handle().eq("sex","女")).executeQueryList(); List<Teacher> listaaa=teacherDao.getQueryBuilder().callQuery().queryAll().where(Where.handle().and("sex","=","女")).executeQueryList(); //模糊查询 List<CustomerBean> list = customerBeanDao.getQueryBuilder().callQuery().queryAll().where(Where.handle().and("userName", " like ", "%" tiaojian "%").or().and("company", " like ", "%" tiaojian "%").or().and("nickname", " like ", "%" tiaojian "%")).executeQueryList(); //对应的 sql select * from CustomerBean where userName like '%你曾%' or company like '%你曾%' or nickname like '%你曾%' ; //根据主键分页 int lastid = teacherDao.queryLastInsertId(); String table = teacherDao.getReflexEntity().getTableEntity().getTableName(); String column = teacherDao.getReflexEntity().getTableIdEntity().getColumnName(); List list1 = teacherDao.getQueryBuilder().callQuery().queryAll().where(Where.handle().and(column, "<=", lastid).and(column, ">", lastid - 标签:MiniOrm
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值