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

上海信息公司做网站中企动力z云邮箱

上海信息公司做网站,中企动力z云邮箱,长沙微网站开发,免费加速器看国外网站目录 MyBatis第一章:框架的概述1. MyBatis框架的概述 第二章:MyBatis的入门程序1. 创建数据库和表结构2. MyBatis的入门步骤 MyBatis 第一章:框架的概述 1. MyBatis框架的概述 MyBatis是一个优秀的基于Java的持久层框架,内部对…

目录

  • MyBatis
    • 第一章:框架的概述
      • 1. MyBatis框架的概述
    • 第二章:MyBatis的入门程序
      • 1. 创建数据库和表结构
      • 2. MyBatis的入门步骤

MyBatis

第一章:框架的概述

1. MyBatis框架的概述

  1. MyBatis是一个优秀的基于Java的持久层框架,内部对JDBC做了封装,使开发者只需要关注SQL语句,而不用关注JDBC的代码,使开发变得更加的简单。
  2. MyBatis通过XML或者注解的方式将要执行的各种Statement对象配置起来,通过Java对象和statement中SQL的动态参数进行映射,并最终执行SQL语句。执行SQL后,最终将结果已Java对象返回。
  3. 采用了ORM的思想。

第二章:MyBatis的入门程序

1. 创建数据库和表结构

create database mybatis_db;
use mybatis_db;CREATE TABLE `user` (`id` int(11) NOT NULL auto_increment,`username` varchar(32) NOT NULL COMMENT '用户名称',`birthday` datetime default NULL COMMENT '生日',`sex` char(1) default NULL COMMENT '性别',`address` varchar(256) default NULL COMMENT '地址',PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;insert  into `user`(`id`,`username`,`birthday`,`sex`,`address`) values (1,'老王','2018-02-27 17:47:08','男','北京'),(2,'熊大','2018-03-02 15:09:37','女','上海'),(3,'熊二','2018-03-04 11:34:34','女','深圳'),(4,'光头强','2018-03-04 12:04:06','男','广州');

2. MyBatis的入门步骤

  1. 创建maven的项目,创建Java工程即可。

  2. 引入坐标

    1. 引入MyBatis的3.4.5的版本的坐标

    2. 引入MySQL驱动的jar包,5.1.6版本

    3. 引入Junit单元测试的jar包

    4. 引入log4j的jar包,1.2.12版本(需要引入log4j.properties的配置文件)

          <dependencies><!--mybatis核心包--><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.5</version></dependency><!--mysql驱动包--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.6</version></dependency><!-- 单元测试 --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.10</version><scope>test</scope></dependency><!-- 日志 --><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency></dependencies>
      
  3. 编写User的实现类,属性尽量使用包装类型,具体的代码如下

    package cn.tx.domain;import java.io.Serializable;
    import java.util.Date;/***** */
    public class User implements Serializable{private static final long serialVersionUID = 525400707336671154L;private Integer id;private String username;private Date birthday;private String sex;private String address;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public Date getBirthday() {return birthday;}public void setBirthday(Date birthday) {this.birthday = birthday;}public String getSex() {return sex;}public void setSex(String sex) {this.sex = sex;}public String getAddress() {return address;}public void setAddress(String address) {this.address = address;}@Overridepublic String toString() {return "User{" +"id=" + id +", username='" + username + '\'' +", birthday=" + birthday +", sex='" + sex + '\'' +", address='" + address + '\'' +'}';}
    }
    
  4. 编写UserMapper的接口和方法(就是咱们以前的UserDao接口)

    package cn.tx.mapper;import java.util.List;
    import cn.tx.domain.User;public interface UserMapper {/*** 查询所有的用户* @return*/public List<User> findAll();}
    
  5. 在resources目录下,创建mapper文件夹。编写UserMapper.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="com.qcbyjy.mapper.UserMapper"><select id="findAll" resultType="com.qcbyjy.domain.User">select * from user;</select>
    </mapper>
    
    1. mapper namespace=“com.qcbyjy.mapper.UserMapper”,叫名称空间,表明以后查找UserMapper接口中的findAll的方法。
    2. select id="findAll"中的id属性编写的UserMapper接口中的方法的名称,固定的。
    3. resultType="com.qcbyjy.domain.User"表明的是findAll方法的返回值类型。
  6. 编写主配置文件,在resources目录下创建SqlMapConfig.xml的配置文件(其实名称可以任意),导入对应的约束,编写主配置文件。

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE configuration  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"  "http://mybatis.org/dtd/mybatis-3-config.dtd">
    <configuration><!-- 配置环境们 --><environments default="mysql"><!-- 配置具体的环境 --><environment id="mysql"><!-- 配置事务管理类型 --><transactionManager type="JDBC"/><!-- 配置是否需要使用连接池,POOLED使用,UNPOOLED不使用 --><dataSource type="POOLED"><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql:///mybatis_db"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><!-- 加载映射的配置文件 --><mappers><mapper resource="mappers/UserMapper.xml"/></mappers>
    </configuration>
    

    1.配置环境(environments)

    default=“mysql”:指定默认使用的数据库环境。

    子标签 定义了名为 mysql 的环境。

    transactionManager type=“JDBC”:声明使用 JDBC 事务管理方式。

    配置数据源,类型为连接池(POOLED)。

    包括数据库驱动类、连接 URL、用户名和密码。

    2.加载映射文件(mappers)

    :加载位于 resources/mappers/ 目录下的 UserMapper.xml 文件,定义 SQL 语句和接口映射关系

  7. 编写入门程序

    1.加载配置文件

    使用 MyBatis 提供的 Resources 工具类加载 SqlMapConfig.xml。

    2.构建 SqlSessionFactory

    通过 SqlSessionFactoryBuilder 构建 SqlSessionFactory 工厂,用于创建 SqlSession。

    3.获取 SqlSession

    调用 openSession() 方法创建 SqlSession,用于执行 SQL 语句。

    4.调用 Mapper 接口

    使用 getMapper(UserMapper.class) 获取 UserMapper 接口的动态代理对象。

    调用 findAll() 方法执行 SQL 查询。

    5.输出结果

    遍历查询结果,打印用户信息。

    6.释放资源

    关闭 SqlSession 和 InputStream,避免资源泄漏。

    package cn.tx.test;import java.io.InputStream;
    import java.util.List;import org.apache.ibatis.io.Resources;
    import org.apache.ibatis.session.SqlSession;
    import org.apache.ibatis.session.SqlSessionFactory;
    import org.apache.ibatis.session.SqlSessionFactoryBuilder;
    import org.junit.Test;import cn.tx.domain.User;
    import cn.tx.mapper.UserMapper;public class UserTest {/*** 测试查询所有的方法* @throws Exception */@Testpublic void testFindAll() throws Exception {// 加载主配置文件,目的是构建SqlSessionFactory的对象InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");// 创建SqlSessionFactory对象SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in);// 使用SqlSessionFactory工厂对象创建SqlSession对象SqlSession session = factory.openSession();// 通过session创建UserMapper接口的代理对象UserMapper mapper = session.getMapper(UserMapper.class);// 调用查询所有的方法List<User> list = mapper.findAll();// 遍历集合for (User user : list) {System.out.println(user);}// 释放资源session.close();in.close();}@Testpublic void run2() throws Exception {// 加载配置文件InputStream inputStream = Resources.getResourceAsStream("SqlMapConfig.xml");// 构建SqlSessionFactory对象SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(inputStream);// 获取到session对象SqlSession session = factory.openSession();// 查询所有的数据List<User> list = session.selectList("com.qcbyjy.mapper.UserMapper.findAll");// 变量集合for (User user : list) {System.out.println(user);}// 关闭资源session.close();inputStream.close();} 
    }
    
http://www.yayakq.cn/news/177862/

相关文章:

  • 大气的企业网站设计软文营销的宗旨是什么
  • 郑州哪里有做网站滨城网站开发
  • wordpress登录可见代码建站优化一条龙
  • 网站建设网页设计网站模板高端文化网站
  • 网站 制作 工具文化馆网站数字化建设介绍
  • 做房地产要自己开网站微信生活门户网站源码
  • 杭州网站建设长春公司河南郑州特产
  • 深圳定制建站公司电话专业网站建设行业现状
  • ftp怎么上传网站水利网站建设
  • 大连模板网站制作推荐wordpress安装流程图
  • 找人做网站需要什么软件wordpress+魅族
  • 众创空间网站建设湖南华图企业展厅设计公司
  • vue.js做个人网站建设一个官方网站多少钱
  • 网站的规划与建设课程设计域名网址区别
  • 网站建设所属行业wordpress musik
  • 营销型企业网站建设建站公司还行吗
  • 滕州市住房城乡建设局网站网站写作赚钱
  • 青岛网页建站工具wordpress文章内容加信息
  • 网站模板绑定域名小程序制作好以后
  • wordpress 点评类网站什么平台可以推销自己的产品
  • 网站建设的相应技术seo01网站
  • 做企业网站和邮箱wordpress登录页面模板
  • 一般做网站费用网页设计代码水平对齐属性align
  • 学做网站论坛vip账号破解山东诚信工程建设监理有限公司网站
  • 淘宝客 网站建设不完整wordpress 做表格
  • 网站建设有哪种方式做app怎么做
  • 05网英语书优化课程设置
  • 如何提升网站点击量黑龙江中国建设监理协会网站
  • 门户网站建设 报告西安的网络优化公司
  • 集团公司做网站哪家的云服务器便宜