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

石家庄网络公司招聘信息广州谷歌seo

石家庄网络公司招聘信息,广州谷歌seo,如何建立一个企业的网站,博客营销是一种新兴的网络营销方式MyBatis与MyBatis-Plus深度分析 一、MyBatis原理与基础 1. MyBatis核心原理 MyBatis是一个半自动ORM框架,主要原理包括: SQL与代码分离:通过XML或注解配置SQL语句动态SQL:提供if、choose、foreach等标签实现动态SQL结果集映射…

MyBatis与MyBatis-Plus深度分析

一、MyBatis原理与基础

1. MyBatis核心原理

MyBatis是一个半自动ORM框架,主要原理包括:

  • SQL与代码分离:通过XML或注解配置SQL语句
  • 动态SQL:提供if、choose、foreach等标签实现动态SQL
  • 结果集映射:将数据库结果集自动映射到Java对象
  • 一级/二级缓存:提供缓存机制提高性能

2. MyBatis基础知识点

核心组件

  • SqlSessionFactory:创建SqlSession的工厂
  • SqlSession:执行SQL的核心接口
  • Mapper接口:定义数据库操作方法
  • Mapper XML:编写SQL语句的配置文件

关键特性

  • 参数映射(#{}, ${})
  • 结果映射(resultMap)
  • 动态SQL标签
  • 插件机制

3. MyBatis简单案例

// Mapper接口
public interface UserMapper {@Select("SELECT * FROM users WHERE id = #{id}")User getUserById(int id);@Insert("INSERT INTO users(name, email) VALUES(#{name}, #{email})")@Options(useGeneratedKeys = true, keyProperty = "id")void insertUser(User user);
}// 实体类
public class User {private Integer id;private String name;private String email;// getters/setters
}// 使用示例
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
try (SqlSession session = sqlSessionFactory.openSession()) {UserMapper mapper = session.getMapper(UserMapper.class);User user = mapper.getUserById(1);System.out.println(user.getName());
}

二、MyBatis-Plus原理与增强

1. MyBatis-Plus核心原理

MyBatis-Plus在MyBatis基础上增强:

  • 自动CRUD:内置通用Mapper,减少基础SQL编写
  • 条件构造器:通过Lambda表达式构建查询条件
  • 代码生成器:自动生成Entity、Mapper等代码
  • 分页插件:简化分页操作
  • 性能分析插件:输出SQL执行性能

2. MyBatis-Plus基础知识点

核心特性

  • 通用CRUD操作
  • Lambda表达式查询
  • 主键策略支持
  • 全局配置
  • 乐观锁支持
  • SQL注入器

与MyBatis主要区别

特性MyBatisMyBatis-Plus
CRUD操作需手动编写内置通用方法
条件构造需写SQLLambda表达式
代码生成需第三方工具内置生成器
分页需插件内置分页插件
性能分析需配置内置插件

3. MyBatis-Plus简单案例

// 实体类
@Data
@TableName("users")
public class User {@TableId(type = IdType.AUTO)private Long id;private String name;private String email;
}// Mapper接口
public interface UserMapper extends BaseMapper<User> {// 已继承基本CRUD方法
}// 服务层
@Service
public class UserService {@Autowiredprivate UserMapper userMapper;public List<User> getUsersByName(String name) {QueryWrapper<User> queryWrapper = new QueryWrapper<>();queryWrapper.lambda().eq(User::getName, name);return userMapper.selectList(queryWrapper);}
}// 使用Lambda查询
List<User> users = userMapper.selectList(Wrappers.<User>lambdaQuery().like(User::getName, "张").gt(User::getAge, 18)
);

三、综合对比与选择建议

1. 适用场景

  • MyBatis适用场景
    • 需要精细控制SQL
    • 复杂查询和存储过程调用
    • 已有MyBatis项目维护
  • MyBatis-Plus适用场景
    • 快速开发CRUD功能
    • 需要减少样板代码
    • 新项目开发

2. 性能考虑

  • MyBatis-Plus在简单CRUD上效率更高(减少代码量)
  • 复杂SQL场景两者性能相当(最终都转为MyBatis执行)
  • MyBatis-Plus的Lambda查询会转换为MyBatis的SQL,无额外性能损耗

3. 综合案例展示

复杂查询+分页案例

// MyBatis实现
@Select("SELECT * FROM users WHERE name LIKE #{name} AND age > #{age} LIMIT #{offset}, #{size}")
List<User> findUsers(@Param("name") String name, @Param("age") int age,@Param("offset") int offset,@Param("size") int size);// MyBatis-Plus实现
Page<User> page = new Page<>(1, 10); // 第1页,每页10条
LambdaQueryWrapper<User> wrapper = Wrappers.lambdaQuery();
wrapper.like(User::getName, "张").gt(User::getAge, 18);
IPage<User> userPage = userMapper.selectPage(page, wrapper);

动态更新案例

// MyBatis实现
@Update("<script>" +"UPDATE users " +"<set>" +"  <if test='name != null'>name=#{name},</if>" +"  <if test='email != null'>email=#{email},</if>" +"</set>" +"WHERE id=#{id}" +"</script>")
void updateUserSelective(User user);// MyBatis-Plus实现
userMapper.update(null, Wrappers.lambdaUpdate(User.class).set(User::getName, "新名字").eq(User::getId, 1));

四、总结

  1. MyBatis提供更精细的SQL控制,适合复杂场景
  2. MyBatis-Plus大幅简化CRUD操作,提高开发效率
  3. 两者可以结合使用,MyBatis-Plus处理简单操作,复杂SQL仍可用原生MyBatis方式
  4. 新项目推荐使用MyBatis-Plus,可显著减少样板代码

根据项目需求和团队熟悉程度选择合适的框架,大型项目中也可以两者混合使用,兼顾开发效率和灵活性

http://www.cadmedia.cn/news/3321.html

相关文章:

  • 铆焊加工平台焦作seo公司
  • 东莞高端网站建设西安发布最新通知
  • wordpress电商方案搜狗排名优化工具
  • 陕西东盟建设工程有限公司网站深圳网络推广公司有哪些
  • 做网站需要备案百度山西授权代理
  • 便宜网站制作公司我想在百度发布信息
  • 云南人参果上海seo优化公司
  • 镇江个人网站制作学营销app哪个更好
  • 乌鲁木齐网站建设如何优化推广中的关键词
  • 网站下载app免费安全谷歌搜索广告
  • 门户网站兴化建设局百度百度推广
  • 网站页面设计的特色百度指数在线查询工具
  • 工商营业执照年检百度快速优化排名软件
  • logo在线制作免费生成在线看seo网站
  • 智能广告投放平台seo排名影响因素主要有
  • 招标网站建设申请百度推广入口
  • 南宁vi设计公司重庆做seo外包的
  • 谷歌seo网站建设百度经验
  • 智能建站系统下载seo优化公司信
  • 专业网站建设联系重庆今天刚刚发生的重大新闻
  • 画册设计报价明细表成都网站优化seo
  • 成都做网站建设公司网站关键词优化排名外包
  • 网站建设那好aso优化排名
  • 朝阳区公安局网站备案专业营销推广团队
  • 湖北省住房与城乡建设部网站软件开发平台
  • 软件开发培训计划搜索引擎优化包括
  • 建设工程网教育网官网关键词优化 搜索引擎
  • 怎么自己公司名下的网站seo优化工具
  • 南宁在哪里推广网站制作网站的全过程
  • ui设计是什么专业学科seo引擎搜索网站