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

深圳市专业的做网站站长统计app进入网址新版小猪

深圳市专业的做网站,站长统计app进入网址新版小猪,廊坊百度网站推广,seo网站建设哪家专业上一篇我们介绍了在pom文件中引入mybatis依赖,配置了mybatis配置文件,通过读取配置文件创建了会话工厂,使用会话工厂创建会话获取连接对象读取到了数据库的基本信息。 如果您需要对上面的内容进行了解,可以参考Mybatis引入与使用…

上一篇我们介绍了在pom文件中引入mybatis依赖,配置了mybatis配置文件,通过读取配置文件创建了会话工厂,使用会话工厂创建会话获取连接对象读取到了数据库的基本信息。

如果您需要对上面的内容进行了解,可以参考Mybatis引入与使用https://blog.csdn.net/m1729339749/article/details/132457971

 本篇我们在上一篇的基础上了解如果使用mybatis查询数据:

一、准备数据

这里我们直接使用脚本初始化数据库中的数据

-- 如果数据库不存在则创建数据库
CREATE DATABASE IF NOT EXISTS demo DEFAULT CHARSET utf8;
-- 切换数据库
USE demo;
-- 创建用户表
CREATE TABLE IF NOT EXISTS T_USER(ID INT PRIMARY KEY,USERNAME VARCHAR(32) NOT NULL,AGE INT NOT NULL 
);
-- 插入用户数据
INSERT INTO T_USER(ID, USERNAME, AGE)
VALUES(1, '张三', 20),(2, '李四', 22),(3, '王五', 24);

创建了一个名称为demo的数据库;并在库里创建了名称为T_USER的用户表并向表中插入了数据

二、创建用户实体类

在cn.horse.demo2包下创建UserInfo实体类,为了方便打印用户的信息这里重写了ToString()方法

package cn.horse.demo2;public class UserInfo {private int id;private String username;private int age;@Overridepublic String toString() {StringBuilder result = new StringBuilder();result.append('[');result.append("id: " + this.id);result.append(", ");result.append("username: " + this.username);result.append(", ");result.append("age: " + this.age);result.append(']');return result.toString();}
}

三、配置Mapper文件

这里我在resources下创建了一个demo2的目录,并在目录下创建了一个UserInfoMapper.xml的配置文件。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="UserInfoMapper"><select id="findById" resultType="cn.horse.demo2.UserInfo">SELECT *FROM T_USERWHERE ID = #{id}</select><select id="findAll" resultType="cn.horse.demo2.UserInfo">SELECT *FROM T_USER</select>
</mapper>

namespace代表的是名称空间;如果有多个Mapper配置文件,名称空间不允许重复

select查询标签;

        id代表的是编号,同一个名称空间下编号不允许重复;

       resultType代表的是结果类型,指将数据库查询出来的数据转换成结果类型对象,转换的前提是结果类型需要提供无参数的构造方法(用于创建结果类型对象),数据库中的列需要与结果类型中的字段一一对应(使用反射的方式进行对象中字段的赋值),否则无法创建结果类型对象或者无法将数据绑定到结果类型对象的字段上。

        标签内容是SQL语句,代表使用ID查询用户信息,其中#{id}是参数;在执行当前查询语句时需要携带此参数。

四、引入Mapper配置

Mapper配置完成后,并没有生效;需要在mybatis-config.xml文件中配置完成后才能生效;

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><property name="driver" value="${driver}"/><property name="url" value="jdbc:mysql://${ip}:${port}/${database}?useUnicode=true&amp;useSSL=false&amp;characterEncoding=utf8"/><property name="username" value="${username}"/><property name="password" value="${password}"/></dataSource></environment></environments><mappers><mapper resource="demo2/UserInfoMapper.xml" /></mappers>
</configuration>

其中mapper标签是我们引入的配置,resource用于指向Mapper配置文件的位置。

五、查询一条数据

// 读取mybatis配置文件
InputStream inputStream = ClassLoader.getSystemClassLoader().getResourceAsStream("mybatis-config.xml");
// 根据配置创建SqlSession工厂
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);SqlSession sqlSession = null;
try {// 创建SqlSessionsqlSession = sqlSessionFactory.openSession();// 根据用户编号查询一条用户信息UserInfo userInfo = sqlSession.selectOne("UserInfoMapper.findById", 2);System.out.println(userInfo);
} finally {// 关闭会话if(Objects.nonNull(sqlSession)) {sqlSession.close();}
}

代码中我们使用selectOne查询一条数据:

第一个参数代表的是语句,其实就是【名称空间.编号】,根据名称空间和编号可以找到我们在Mapper配置文件中配置的SQL语句

第二个参数代表的是参数值,用于解析SQL语句中的参数

测试:

执行上面代码的结果如下:

 查询的结果与我们库中的数据一致。

六、查询数据列表

// 读取mybatis配置文件
InputStream inputStream = ClassLoader.getSystemClassLoader().getResourceAsStream("mybatis-config.xml");
// 根据配置创建SqlSession工厂
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);SqlSession sqlSession = null;
try {// 创建SqlSessionsqlSession = sqlSessionFactory.openSession();// 查询数据列表List<UserInfo> userInfoList = sqlSession.selectList("UserInfoMapper.findAll");for (UserInfo userInfo: userInfoList) {System.out.println(userInfo);}
} finally {// 关闭会话if(Objects.nonNull(sqlSession)) {sqlSession.close();}
}

代码中我们使用selectList查询数据列表,由于没有使用到参数,所以没有传递任何参数

测试:

执行上面代码的结果如下:

查询的结果与我们库中的数据一致。

 

http://www.yidumall.com/news/22540.html

相关文章:

  • 怎么建设网站卖东西什么是百度竞价排名
  • 河北邯郸手机网站建设链接买卖
  • 目前国内家教做的好的网站专业软文平台
  • 如何建设网站视频百度平台交易
  • 上海外贸企业网站优化技巧
  • wordpress如何修改登录地址青岛的seo服务公司
  • 网站链接设计网络推广优化方案
  • 网站做微信支付对接成都百度seo优化公司
  • 用微软雅黑做网站可以吗2345网址导航官网官方电脑版
  • 免费网站建设系统深圳网络推广软件
  • 家装效果图设计网站网站建设的基本流程
  • 烟台网站开发制作中文搜索引擎大全
  • 不正规网站制作谷歌优化怎么做
  • 做海报兼职网站seo岗位
  • 上海高端做网站网络销售哪个平台最好
  • 百度小程序可以根据网站的要求做吗sem技术培训
  • 橙子建站客服电话googleplay商店
  • 网站栏目划分怎么做汕头seo优化
  • 网站开发业务无锡百度推广平台
  • 南昌网站建设公司网站建设公司网站查询信息
  • 做外贸网站有哪些考研培训
  • 学校要建个网站应该怎么做百度网站收录
  • 武汉生活网seo云优化如何
  • 犀牛云做网站怎么样推广信息发布平台
  • 博客网站 做淘宝客太原seo代理商
  • 游戏抽奖网站用java怎么做新闻最近新闻10条
  • wordpress 优秀网站nba最新排名
  • 广西临桂建设局网站seo站长
  • 如何做旅游休闲网站免费引流推广方法
  • 郑州网站制作的公司网络营销大赛策划书