//数据库创建
```java
package soexample.umeng.com.day_04_greendao.app;
import android.app.Application;
import soexample.umeng.com.day_04_greendao.dao.DaoMaster;
import soexample.umeng.com.day_04_greendao.dao.DaoSession;
public class MyApp extends Application {
private static DaoSession mDaoSession;
@Override
public void onCreate() {
super.onCreate();
initDatabase();
}
private void initDatabase() {
//创建数据库
DaoMaster.DevOpenHelper openHelper = new DaoMaster.DevOpenHelper(this, "xxlv.db");
//用greenDao的Daomaster来包装这个数据库
DaoMaster daoMaster = new DaoMaster(openHelper.getWritableDatabase());
mDaoSession = daoMaster.newSession();
}
public static DaoSession getDaoSession() {
return mDaoSession;
}
}
* GreenDao数据库
* 怎么使用:
* 1:导入依赖
* 1:Project下classpath classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2'
* 2:model下的build.gradle 第一行 apply plugin: 'org.greenrobot.greendao'
* 导入两个依赖
* implementation 'org.greenrobot:greendao:3.2.2'
* implementation 'org.greenrobot:greendao-generator:3.2.2'
* 3:在Android代码中加入
* greendao {
* //指定数据库schema版本号,迁移等操作会用到
* schemaVersion 1
* //DaoSession、DaoMaster以及所有实体类的dao生成的目录,默认为你的entity所在的包名
* //daoPackage 包名
* daoPackage 'soexample.umeng.com.day_04_greendao.dao'
* //这就是我们上面说到的自定义生成数据库文件的目录了,可以将生成的文件放到我们的java目录中,而不是build中,这样就不用额外的设置资源目录了
* //工程路径
* targetGenDir 'src/main/java'
* }
* <p>
* 以上配置OK就可以使用greendao
* 写一个实体类然后在外部加上一个注解
*
* @Id注解选择 long / Long 属性作为实体ID。在数据库术语中,它是主键。参数自动增量,是使ID值不断增加(不会选用旧值)的标志。
* @Property让你定义一个非默认的列名,其属性映射到。如果不存在,greenDAO将在SQL杂交方式使用字段名(大写,下划线,而不是骆驼情况下,例如 customName将成为 CUSTOM_NAME)。注意:您目前只能使用内联常量来指定列名。
* @NotNull makes the property a “NOT NULL” column on the database side。通常是有意义的纪念原始类型(long, int, short, byte)与@NotNull,同时具有包装类(Long, Integer, Short, Byte)空的值。
* @Transient表明这个字段不会被写入数据库,只是作为一个普通的java类字段,用来临时存储数据的,不会被持久化
* @Entity 定义实体
* @nameInDb 在数据库中的名字,如不写则为实体中类名
* @indexes 索引
* @createInDb 是否创建表,默认为true,false时不创建
* @schema 指定架构名称为实体
* @active 无论是更新生成都刷新
* @Id
* @NotNull 不为null
* @Unique 唯一约束
* @ToMany 一对多
* @OrderBy 排序
* @ToOne 一对一
* @Transient 不存储在数据库中
* @generated 由greendao产生的构造函数或方法
* <p>
* 写完字段过后 需要make project锤子锤一下即可
* <p>
* DaoMaster 创建数据库
* DaoSession 管理绑定表
* XXXDao
* <p>
* 我们抽取代码在Application操作
* private void initDatabase() {
* //创建数据库
* DaoMaster.DevOpenHelper openHelper = new DaoMaster.DevOpenHelper(this, "xxlv.db");
* //用greenDao的Daomaster来包装这个数据库
* DaoMaster daoMaster = new DaoMaster(openHelper.getWritableDatabase());
* mDaoSession = daoMaster.newSession();
* }
* <p>
* 扩展知识 数据库升级 一般只要数据库定下来 字段就不能随便改了
* 序列化和反序列化 高频面试问题
* 一个Android Parcelable 一个是java Serializable
* 如果你这个实体类用序列化必须要加安全的UID
* private static final long serialVersionUID = -4211449776975163975L;```
//二级列表适配器
```java
package soexample.umeng.com.day07_shopping_car_demo.adapter;
import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseExpandableListAdapter;
import android.widget.CheckBox;
import android.widget.ImageView;
import android.widget.TextView;
import com.bumptech.glide.Glide;
import java.util.List;
import soexample.umeng.com.day07_shopping_car_demo.R;
import soexample.umeng.com.day07_shopping_car_demo.bean.MyData;
import soexample.umeng.com.day07_shopping_car_demo.weight.MyAddOrRemoveView;
public class MyExpanAdapter extends BaseExpandableListAdapter {
private List<MyData.ResultBean> mList;
private Context mContext;
public MyExpanAdapter(List<MyData.ResultBean> mList, Context mContext) {
this.mList = mList;
this.mContext = mContext;
}
@Override
public int getGroupCount() {
return mList.size();
}
@Override
public int getChildrenCount(int groupPosition) {
return mList.get(groupPosition).getShoppingCartList().size();
}
@Override
public Object getGroup(int groupPosition) {
return null;
}
@Override
public Object getChild(int groupPosition, int childPosition) {
return null;
}
@Override
public long getGroupId(int groupPosition) {
return 0;
}
@Override
public long getChildId(int groupPosition, int childPosition) {
return 0;
}
@Override
public boolean hasStableIds() {
return false;
}
@Override
public View getGroupView(final int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) {
GroupHolder holder = null;
if (convertView == null) {
holder = new GroupHolder();
convertView = View.inflate(mContext, R.layout.recy_big, null);
holder.mBigCheck = convertView.findViewById(R.id.Big_CheckBox);
holder.mBigTv = convertView.findViewById(R.id.Big_Text);
convertView.setTag(holder);
} else {
holder = (GroupHolder) convertView.getTag();
}
holder.mBigTv.setText(mList.get(groupPosition).getCategoryName() + "");
holder.mBigCheck.set