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

阳江网站建设推广公司电话免费网页制作模板

阳江网站建设推广公司电话,免费网页制作模板,专卖店vi设计公司,最专业网站建设开发1. MyBatis 简介 MyBatis 是一款持久层框架,简化了 JDBC 的复杂操作,通过配置和映射文件将 Java 对象与数据库表关联。核心优势: 自动管理资源:无需手动关闭连接、释放资源。 动态 SQL:支持参数绑定、条件查询等。 …
1. MyBatis 简介

MyBatis 是一款持久层框架,简化了 JDBC 的复杂操作,通过配置和映射文件将 Java 对象与数据库表关联。核心优势:

  • 自动管理资源:无需手动关闭连接、释放资源。

  • 动态 SQL:支持参数绑定、条件查询等。

  • 灵活映射:支持结果集与 Java 对象的自动映射。

2. 快速入门
2.1 准备工作
  1. 创建 Spring Boot 工程,添加依赖:

<!-- MyBatis 依赖 -->
<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>3.0.3</version>
</dependency>
<!-- MySQL 驱动 -->
<dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId>
</dependency>

2.数据库表准备

CREATE TABLE `user_info` (`id` INT NOT NULL AUTO_INCREMENT,`username` VARCHAR(127) NOT NULL,`password` VARCHAR(127) NOT NULL,`age` TINYINT NOT NULL,`gender` TINYINT DEFAULT '0' COMMENT '1-男 2-女 0-默认',`phone` VARCHAR(15) DEFAULT NULL,`delete_flag` TINYINT DEFAULT '0' COMMENT '0-正常 1-删除',`create_time` DATETIME DEFAULT NOW(),`update_time` DATETIME DEFAULT NOW() ON UPDATE NOW(),PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

3.实体类

@Data
public class UserInfo {private Integer id;private String username;private String password;private Integer age;private Integer gender;private String phone;private Integer deleteFlag;private Date createTime;private Date updateTime;
}
2.2 配置数据源

在 application.yml 中配置数据库连接:

spring:datasource:url: jdbc:mysql://localhost:3306/mybatis_test?useSSL=false&characterEncoding=utf8username: rootpassword: rootdriver-class-name: com.mysql.cj.jdbc.Driver
3. 注解方式操作数据库
3.1 查询操作

Mapper 接口

@Mapper
public interface UserInfoMapper {@Select("SELECT username, password, age, gender, phone FROM user_info")List<UserInfo> queryAllUser();
}

测试类

@SpringBootTest
class UserInfoMapperTest {@Autowiredprivate UserInfoMapper userInfoMapper;@Testvoid queryAllUser() {List<UserInfo> userList = userInfoMapper.queryAllUser();System.out.println(userList);}
}
3.2 参数传递

使用 #{参数名} 动态传参:

@Select("SELECT * FROM user_info WHERE id = #{id}")
UserInfo queryById(Integer id);
3.3 插入操作

返回自增主键:

@Options(useGeneratedKeys = true, keyProperty = "id")
@Insert("INSERT INTO user_info (username, password) VALUES (#{username}, #{password})")
Integer insert(UserInfo userInfo);
4. XML 方式操作数据库
4.1 配置 XML 路径

在 application.yml 中指定 XML 文件位置:

mybatis:mapper-locations: classpath:mapper/*Mapper.xml
4.2 编写 XML 文件

UserInfoMapper.xml

<mapper namespace="com.example.mapper.UserInfoMapper"><select id="queryAllUser" resultType="UserInfo">SELECT * FROM user_info</select><insert id="insertUser" useGeneratedKeys="true" keyProperty="id">INSERT INTO user_info (username, password)VALUES (#{username}, #{password})</insert>
</mapper>
4.3 结果映射

解决字段名与属性名不一致问题:

<resultMap id="userMap" type="UserInfo"><id column="id" property="id"/><result column="delete_flag" property="deleteFlag"/><result column="create_time" property="createTime"/><result column="update_time" property="updateTime"/>
</resultMap>
5. 常见问题与解决方案
5.1 字段名映射
  1. 开启驼峰命名(推荐)

mybatis:configuration:map-underscore-to-camel-case: true

   2. 手动别名

SELECT delete_flag AS deleteFlag FROM user_info
5.2 #{} 与 ${} 的区别
  • #{}:预编译 SQL,防止 SQL 注入。

  • @Select("SELECT * FROM user_info WHERE username = #{name}")
    UserInfo queryByName(String name);

    ${}:直接拼接 SQL,适用于动态排序或表名:

@Select("SELECT * FROM user_info ORDER BY ${sortKey}")
List<UserInfo> queryBySort(@Param("sortKey") String sortKey);
5.3 模糊查询

使用 CONCAT 函数避免 SQL 注入:

@Select("SELECT * FROM user_info WHERE username LIKE CONCAT('%', #{key}, '%')")
List<UserInfo> queryByKeyword(String key);
6. 多表查询示例

实体类

@Data
public class ArticleInfo {private Integer id;private String title;private String content;private Integer userId;private String username; // 关联用户表字段
}

Mapper 接口

@Select("SELECT a.*, u.username FROM article_info a LEFT JOIN user_info u ON a.user_id = u.id WHERE a.id = #{id}")
ArticleInfo getArticleWithUser(Integer id);
7. 数据库连接池

Spring Boot 默认使用 Hikari,切换为 Druid

<dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.2.21</version>
</dependency>
8. 总结
  • 核心功能:MyBatis 通过注解或 XML 简化 SQL 操作,支持动态 SQL 和结果映射。

  • 最佳实践

    • 优先使用 #{} 防止 SQL 注入。

    • 开启驼峰命名简化字段映射。

    • 复杂 SQL 使用 XML 配置,简单操作使用注解。

  • 企业规范:表名小写下划线分隔,必备字段 idcreate_timeupdate_time

http://www.dtcms.com/wzjs/186592.html

相关文章:

  • 哪些公司做网站好曼联官方发文
  • 做本地门户网站阜新网站seo
  • 洛阳东翔科技做的网站宁波外贸网站推广优化
  • 网站页尾模板刷关键词要刷大词吗
  • 新疆建设云网站成绩查询网站开发的一般流程
  • 班级网站建设组织机构营销管理系统
  • 怎么查看网站空间东莞网络科技公司排名
  • 租域名多少钱广告优化师工作内容
  • 广告公司网站模版sem营销
  • 连云港做网站设计搜索引擎调词平台价格
  • 手机制作网站的软件有哪些内容淘宝推广
  • 兰州高端网站建设长沙网站seo报价
  • 做网站需要费用多少网络黄页推广软件哪个好
  • 大庆市住房和城乡建设局网站构建新发展格局
  • 广告型网站怎么做公司推广策划方案
  • 网站开发 一个页面多少钱seo是什么意思中文
  • 专业做学校网站的公司模板建站哪里有
  • 宁波企业网站排名优化公司it行业培训机构哪个好
  • 缙云建设局网上协同办公oa网站百度浏览器官网在线使用
  • 郑州一网网站建设如何提高网站在搜索引擎中的排名
  • 环保局网站建设公司网站推广方案
  • 上海城乡建设与管理委员会网站百度推广要多少钱
  • 网站建设哪好深圳网络推广方法
  • 织梦手机端网站怎么做知乎seo排名的搜软件
  • 常州网站制作市场网拍外宣怎么推广
  • 后台管理网站名友情链接交换网
  • 上海做网站建设的公司排名nba总得分排行榜最新
  • 承德网站制作报价北京官方seo搜索引擎优化推荐
  • wordpress注册页优化大师班级优化大师
  • 网站模板是什么意思seo教程 seo之家