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

好看的网站源码网站开发gif图太多耗资源吗

好看的网站源码,网站开发gif图太多耗资源吗,做网站公司人员,加油站网站建设目录 前言 MyBatis的具体使用 一些小工具:MyBatisX 常见问题: 1.表中字段名和实体属性名不一致 2.按条件查询(单条件)时的,查询条件怎么编写 3.按条件查询(多条件) 4.多条件查询时&…

目录

前言

MyBatis的具体使用

一些小工具:MyBatisX

常见问题:

1.表中字段名和实体属性名不一致

2.按条件查询(单条件)时的,查询条件怎么编写

3.按条件查询(多条件)

4.多条件查询时,用户不把所有条件填完

5.单条件查询时,不知道用户到底选了哪一个

6.添加用户怎么写接口和mapper.xml

7.添加信息时,如果要主键增长呢

8.修改信息

9.删除一行数据

10.批量删除☆☆☆

MyBatis注解



前言

为什么要有MyBatis呢?

当然是因为JDBC代码太繁琐啦~

上图标1的代码有很多字符串,而这些是连接数据库的四个基本信息,以后如果要将Mysql数据库换成其他的关系型数据库的话,这四个地方都需要修改,如果放在此处就意味着要修改我们的源代码。

上图标2的代码。如果表结构发生变化,SQL语句就要进行更改。这也不方便后期的维护。

操作很繁琐

使用MyBatis就可以解决这些问题

MyBatis的具体使用

1.创建一个表。

2.导入依赖坐标

3.在项目的resources 目录下创建mybatis的配置文件 mybatis-config.xml 

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><!--  配置别名  --><!-- 这样的话,就在UserMapper中可以不用设置成这样了   --><!--    <select id="selectAll" resultType="org.example.pojo.User">--><!--    因为在mybatis中配置了别名,所以可以不用谢前面的包名了    -->
<!--    <select id="selectAll" resultType="User">--><typeAliases><package name="org.example.pojo"/></typeAliases><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><!--   这一段代码是连接信息             --><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql:///mybatis?useSSL=false"/><property name="username" value="root"/><property name="password" value="1234"/></dataSource></environment></environments><!-- 指定sql映射的路径   -->
<!--  因为在resource目录上有和src目录下的下相同目录,所以直接可以使用package包的方式  --><mappers>
<!--        <mapper resource="org/example/mapper/UserMapper.xml"/>--><package name="org.example.mapper"/></mappers>
</configuration>

4.创建实体类User

public class User {private int id;private String username;private String password;private String gender;private String addr;//省略了 setter 和 getter
}

5.在模块的 resources 目录下创建映射配置文件 UserMapper.xml

SQL语句就是在**Mapper.xml文件中编写的

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="test"><select id="selectAll" resultType="com.itheima.pojo.User">select * from tb_user;</select>
</mapper>

需要满足这样的目录层级

6.定义UserMapper接口代码

public interface UserMapper {List<User> selectAll();
}

注意层级和名称一致问题

7.定义一个测试类进行测试

/*** Mybatis 代理开发*/
public class MyBatisDemo2 {public static void main(String[] args) throws IOException {//1. 加载mybatis的核心配置文件,获取 SqlSessionFactoryString resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);//2. 获取SqlSession对象,用它来执行sqlSqlSession sqlSession = sqlSessionFactory.openSession();//3. 执行sql//3.1 获取UserMapper接口的代理对象UserMapper userMapper = sqlSession.getMapper(UserMapper.class);List<User> users = userMapper.selectAll();System.out.println(users);//4. 释放资源sqlSession.close();}
}

一些小工具:MyBatisX

MyBatisX 插件

  • XML映射配置文件 和 接口方法 间相互跳转

  • 根据接口方法生成 statement

如下图操作就可以完成,生成Mapper.xml文件中的statement

常见问题:

1.表中字段名和实体属性名不一致

使用Mybatis时,可能会出现数据库表的字段名称和实体类的属性名称不一样的问题,这样的话就不能自动封装数据了。

可以resultMap

具体来说:就是在 **Mapper.xml中添加下图红框框住的<resultMap></resultMap>部分,对字段进行映射,下图中前面的字段是数据库中的命名,后面是实体类的属性名。

然后将resultType换成resultMap

2.按条件查询(单条件)时的,查询条件怎么编写

在 **Mapper中这样写,如下图查询条件是id  就这样写#{id}

对于有参数的Mapper接口方法

3.按条件查询(多条件)

可以使用以下三种方法

mapper.xml的编写

在测试类中的调用

4.多条件查询时,用户不把所有条件填完

这个时候就要使用到动态SQL

使用<where></where>标签 和 <if></if>标签

5.单条件查询时,不知道用户到底选了哪一个

这种需求需要使用到 choose(when,otherwise)标签 实现, 而 choose 标签类似于Java 中的switch语句。

6.添加用户怎么写接口和mapper.xml

定义接口

写mapper,使用的是<insert></insert>

封装对象,执行方法

7.添加信息时,如果要主键增长呢

添加 

useGeneratedKeys, keyProperty 关键字

8.修改信息

定义接口

编写mapper.xml

执行方法

9.删除一行数据

10.批量删除☆☆☆

编写SQL时需要遍历数组来拼接SQL语句。Mybatis 提供了 foreach 标签供我们使用

MyBatis注解

注解是用来替换映射配置文件方式配置的,所以使用了注解,就不需要再映射配置文件中书写对应的 statement。

使用注解开发会比配置文件开发更加方便。如下就是使用注解进行开发。

但是对于复杂的SQL语句还是建议使用配置文件的方法。

public interface UserMapper {@Insert("INSERT INTO users(username, age) VALUES(#{username}, #{age})")int insertUser(User user);
}

public interface UserMapper {@Delete("DELETE FROM users WHERE id = #{id}")int deleteUserById(@Param("id") int id);
}

public interface UserMapper {@Update("UPDATE users SET username = #{username}, age = #{age} WHERE id = #{id}")int updateUser(User user);
}

public interface UserMapper {@Select("SELECT * FROM users WHERE id = #{id}")User selectUserById(@Param("id") int id);// 查询所有用户@Select("SELECT * FROM users")List<User> selectAllUsers();
}

http://www.yayakq.cn/news/791139/

相关文章:

  • 珠海建设网站公司哪家好长沙市停课最新消息
  • 建设壁纸网站的目的广西住房和城乡建设部网站
  • 简洁的网站设计益阳网站开发公司
  • 建设部职称评审的网站北控京奥建设有限公司网站
  • 西安设计网站公司注册资金100万的公司要多少钱
  • 互联网门户网站有哪些南京最新情况最新消息今天
  • 门业东莞网站建设技术支持wordpress修改管理员
  • 笔记本做系统哪个网站好兴仁企业建站公司
  • 电子书新手学做网站iis下安装wordpress
  • 如何建设公司网站知乎企业管理咨询公司前景
  • 免费自助设计网站怎么加快登录网站速度
  • 网站维护推广怎么做电子商务网站推广策划方案
  • 网站建设网络推广最低价格计算机网站开发方向
  • 成都门户网站有哪些网页设计入门首先要学什么
  • 陕西建设官方网站企业网站备案那么麻烦吗
  • 想做机械加工和橡胶生意怎么做网站小程序怎样制作
  • 网页设计与网站建设在线第二章建筑招聘平台
  • 创意设计网站京网站制作公司
  • 上海嘉定区网站建设汕头百度关键词搜索
  • 大连建设项目关键词优化价格
  • 视频投票网站怎么做上海知名网站建
  • 网站开发部职责公司网站程序
  • 农村做网站赚钱百度app下载安装官方免费下载
  • 广东微信网站建设价格科技公司网站设计方案
  • 找网站建设公司重庆永川网站建设价格
  • 外国人的做视频网站吗网站建设与维护可行性报告
  • 网站备案哪个部门网站显示系统建设中
  • wdcp怎么上传做好的网站软件app下载免费
  • 网站快速刷排名工具长春网站建设技术外包
  • 做网站应该考虑哪些问题做展示类网站