当前位置: 首页 > news >正文

成都优秀网站建设英语培训机构

成都优秀网站建设,英语培训机构,wordpress4.9漏洞,做网站如何使用特殊字体Mybatis-Plus实现CRUD 1 Insert增加2 ID生成策略3 Delete删除4 逻辑删除5 Update修改6 Select查询 Mybatis-Plus实现CRUD 通用 CRUD 封装**BaseMapper (opens new window)**接口,为 Mybatis-Plus 启动时自动解析实体表关系映射转换为 Mybatis 内部对象注入容器参数 …

Mybatis-Plus实现CRUD

    • 1 Insert增加
    • 2 ID生成策略
    • 3 Delete删除
    • 4 逻辑删除
    • 5 Update修改
    • 6 Select查询

Mybatis-Plus实现CRUD

  • 通用 CRUD 封装**BaseMapper (opens new window)**接口,为 Mybatis-Plus 启动时自动解析实体表关系映射转换为 Mybatis 内部对象注入容器
  • 参数 Serializable为任意类型主键 Mybatis-Plus不推荐使用复合主键约定每一张表都有自己的唯一id 主键
  • 对象 Wrapper为 条件构造器

1 Insert增加

插入一条记录

  • int insert(T entity);
//测试增加
@Test
public void testInsert(){User user = new User(null,"jack",30,"jack@qq.com");userMapper.insert(user);
}

此时,代码会出现异常。因为User类并没有设置ID,那么MP会使用ID生成策略自动生成一个ID。

这个ID是由雪花算法得到的,类型为Long类型,而实体类在中ID为Integer类型

2 ID生成策略

通过**@TableId(type = IdType.AUTO)** 注解进行指定

主键类型参数说明
AUTO(0)数据库ID自增(数据库使用自增)
NONE(1)该类型为未设置主键类型(将跟随全局)
INPUT(2)用户手动输入ID
ID_WORKER(3)全局唯一ID (idWorker )
UUID(4)全局唯一ID (UUID)
ID_WORKER_STR(5)符串全局唯一ID (idWorker 的字符串表示)

3 Delete删除

根据 ID 删除

  • int deleteById(Serializable id)

删除(根据ID 批量删除)

  • int deleteBatchIds(@Param(Constants.COLLECTION) Collection<? extends Serializable> idList)
//测试删除
@Test
public void testdeleteById(){userMapper.deleteById(6);
}
//测试批量删除
@Test
public void testdeleteBatchIds(){Integer[] ids = {1,2,3,4};userMapper.deleteBatchIds(Arrays.asList(ids));
}

4 逻辑删除

在开发中有些数据不能直接从数据库中进行删除。用户删除数据有时候管理员还需要查看!!!

那么在实际的开发中可以实现逻辑删除

实现:

  1. 在数据库中添加deleted字段(0表示未删除、1表示删除)
  2. 在实体上添加@TableLogic注解
@TableLogic
private Integer deleted;
//测试逻辑删除
@Test
public void testLogicDeleteById(){userMapper.deleteById(1);
}
# 执行sql语句为:
UPDATE user SET deleted=1 WHERE id=? AND deleted=0

添加逻辑删除属性后,查询中都会自动带上条件where deleted = 0

5 Update修改

根据 ID 修改(参数为实体类对象)

  • int updateById(@Param(Constants.ENTITY) T entity);
//测试修改
@Test
public void testUpdateById(){User user = new User(5,"rose",30,"rose@qq.com");userMapper.updateById(user);
}

6 Select查询

根据 ID 查询

  • T selectById(Serializable id);

查询(根据ID 批量查询)

  • List<T> selectBatchIds(@Param(Constants.COLLECTION) Collection<? extends Serializable> idList);

根据 entity 条件,查询全部记录

  • List<T> selectList(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper);

根据 Wrapper 条件,查询总记录数

  • Integer selectCount(@Param(Constants.WRAPPER) Wrapper<T> queryWrapper);
//测试根据id查询
@Test
public void testselectById(){User user = userMapper.selectById(1);System.out.println(user);
}
//查询(根据ID 批量查询)
@Test
public void testselectBatchIds(){List<User> userList = userMapper.selectBatchIds(Arrays.asList(1, 2, 3, 4));userList.forEach(System.out::println);
}
//根据 entity 条件,查询全部记录
@Test
public void testselectList(){List<User> userList = userMapper.selectList(null);userList.forEach(System.out::println);
}
//根据 Wrapper 条件,查询总记录数
@Test
public void testselectCount(){Integer count = userMapper.selectCount(null);System.out.println(count);
}
http://www.wangmingla.cn/news/5603.html

相关文章:

  • 动态网站开发实训报告1百度seo流量
  • 局域网内做网站温州网站建设开发
  • 做视频网站如何赚钱seo顾问张智伟
  • 手机做公司网站站长平台
  • 邯郸去哪做网站改版杭州搜索引擎排名
  • 中企动力网站开发汕头seo建站
  • 做网站什么是解析什么是跳转游戏代理免费加盟
  • 目前主流的网站开发语言百度客服转人工
  • wordpress英文企业主题爱站网seo培训
  • 公司网站定位建议高端营销型网站建设
  • 呼和浩特做网站电商运营工资一般多少钱一个月
  • 崇州企业网站建设app搜索优化
  • 网上建立网站百度信息流广告位置
  • 专做韩国代购的网站seo网站排名的软件
  • wordpress 变成垃圾邮件seo超级外链工具
  • 2003建立虚拟网站南京今日新闻头条
  • 个人网站建设软件宁德市
  • 中国广告设计网seo收录查询
  • 南宁网站建设设计制作永久免费制作网页
  • 网站制作软件都是什么网站运营及推广方案
  • 公司网站建设的方案市场推广方案怎么做
  • 如何电话推销客户做网站江门网站优化公司
  • 莫邻在线客服系统网店seo排名优化
  • DW做网站下拉列表怎么做网站策划方案书
  • 北京做网站的公司排行郑州网络seo
  • 做网站设计怎么进企业济南网站制作
  • 没有有知道钓鱼网站在哪儿做网站网页的优化方法
  • 网站推广网络推广金华网站推广
  • 表述网站建设流程正规赚佣金的平台
  • 免费自动建站nba最新排行