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

兰州道路建设情况网站福建论坛

兰州道路建设情况网站,福建论坛,智能科技网站模板下载,android移动网站开发详解操作步骤 创建数据库 建立user表 放入数据 1、创建javaweb工程并添加Jar包 用到的jar包 junit 用于测试 mybatis框架&#xff1a;mybatis-3.5.9.jar mysql数据库&#xff1a;mysql-connector-java-8.0.28.jar 2、添加MyBatis核心配置文件 <?xml version"1.0"…

操作步骤

创建数据库

建立user表

放入数据

1、创建javaweb工程并添加Jar包

用到的jar包

junit 用于测试

mybatis框架:mybatis-3.5.9.jar

mysql数据库:mysql-connector-java-8.0.28.jar 

2、添加MyBatis核心配置文件

<?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><!-- 配置内容在这里 --></configuration>

driver=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis
username=root
password=root

 编写”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><properties resource="database.properties"></properties><typeAliases><package name="entity"/></typeAliases><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><property name="driver" value="${driver}"/><property name="url" value="${url}?useUnicode=true&amp;characterEncoding=UTF-8&amp;serverTimezone=UTC&amp;useSSL=false"/><property name="username" value="${username}"/><property name="password" value="${password}"/></dataSource></environment></environments><mappers><mapper resource="mapper/UserMapper.xml"></mapper></mappers>
</configuration>

 ”mybatis-config.xml”的配置节点说明

1、configuration:

        配置文件的根元素节点

2、environments:

        表示配置MyBaits的多套运行环境,该元素节点下可以配置多个environment子元素节点

3、environment:

        配置Mybaits的一套运行环境,需指定运行环境ID、事务管理(transactionManager)和数据源(dataSource)配置等相关信息

4、mappers:

        其下可以配置多个mapper节点来具体指定SQL映射文件的路径,resource属性的值表述了类资源路径下的SQL映射文件的路径

3、创建实体类

package entity;public class User {private String username;private String password;private Integer age;private String sex;private String birthDate;public User() {}public User(String username, String password, Integer age, String sex, String birthDate) {this.username = username;this.password = password;this.age = age;this.sex = sex;this.birthDate = birthDate;}public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public Integer getAge() {return age;}public void setAge(Integer age) {this.age = age;}public String getSex() {return sex;}public void setSex(String sex) {this.sex = sex;}public String getBirthDate() {return birthDate;}public void setBirthDate(String birthDate) {this.birthDate = birthDate;}@Overridepublic String toString() {return "User{" +"username='" + username + '\'' +", password='" + password + '\'' +", age=" + age +", sex='" + sex + '\'' +", birthDate=" + birthDate +'}';}
}

注: 1、类的名称不一定和表名相同

2、属性名称和数据库字段名称相同,才能自动映射

3、属性类型需要和数据库字段类型对应

4、每一个属性都要生成get/set方法 

4、创建SQL映射文件

<?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="/"><!-- SQL映射写在这里 -->
</mapper>

 编辑”UserMapper.xml”SQL映射内容

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="/"><select id="findAll" resultType="user">
select * from user</select><select id="findAll2" resultType="map">
select * from user</select><select id="myCount" resultType="int" parameterType="map">select count(*) from smbms_bill join smbms_provider on smbms_bill.providerId=smbms_provider.id where smbms_provider.proName like concat('%',#{proName},'%') and isPayment=#{isPayment}</select>
</mapper><!--建立映射关系-->

配置节点说明 

select:表示查询语句

id属性:表示该SQL语句的唯一标识符

resultType属性:表示SQL语句返回值类型,此处通过SQL语句查询数据,将数据直接映射到User实体类上 

5、代码测试,输出结果

import entity.User;
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 java.io.IOException;
import java.io.InputStream;
import java.util.HashMap;
import java.util.List;
import java.util.Map;public class UserMapperTest {@Testpublic void Test01() throws IOException {System.out.println(" = ");InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();SqlSessionFactory build = sqlSessionFactoryBuilder.build(inputStream);SqlSession sqlSession = build.openSession();List<User> findAll = sqlSession.selectList("findAll");for (User user: findAll) {System.out.println("user = " + user);}sqlSession.close();}@Testpublic void Test02() throws IOException {InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();SqlSessionFactory build = sqlSessionFactoryBuilder.build(inputStream);SqlSession sqlSession = build.openSession();List<Map<String,Object>> findAll = sqlSession.selectList("findAll2");for (Map<String, Object> stringObjectMap : findAll) {System.out.println("stringObjectMap = " + stringObjectMap);}sqlSession.close();}}

 结果为list集合对象

结果为map集合对象 

6、扩展 

configuration 根节点

        properties    可以配置在Java 属性配置文件中

        settings    修改 MyBatis 在运行时的行为方式

        typeAliases   为 Java 类型命名一个别名(简称)

        typeHandlers   类型处理器

        objectFactory   对象工厂

        plugins   插件

        environments   环境

                environment   环境变量

                        transactionManager  事务管理器

                        dataSource   数据源

        mappers    映射器

注意顺序不然会爆红

typeAliases元素的作用是配置类型别名

二选一推荐第二个

这个可以指定名称

作用是简化代码

默认是类首字母小写的名称

通过package的name属性直接指定包名,Mybatis会自动扫描指定包下的JavaBean,并设置一个别名,默认名称为非限定类名

原本要这样写

 现在

属性文件: 文件后缀为.properties 这种文件以key=value格式存储内容 

指定类资源路径下的属性文件 

使用${}占位符和属性文件中的键名来实现动态配置

 mapper

namespace属性的作用: namespace和子元素的id联合保证全局唯一,区别不同的映射文件 绑定DAO接口,即面向接口编程

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

相关文章:

  • 搭建网站吧专门做网站网站犯法吗
  • 响应式网站有什么弊端软装设计一般怎么收费
  • 河南南阳油田网站建设物流网信息平台
  • 网站备案完才能建站吗百度域名是什么?
  • dw做aspx网站大连工程信息招标网
  • 东莞网站设计知名 乐云践新蜂聘网360建筑网
  • 淘宝联盟登记新网站net域名网站
  • wordpress站点名称的影响seo优化网站教程百度
  • 学做包子馒头的网站ip网域名查询
  • 做网站编辑要会什么中国造价网官网
  • 网站制作软件 aws怎么制作自己的网页
  • 临沂seo建站江阴服装外贸现状
  • 网站部分乱码html5做网站导航
  • 成品网站货源入口浙江最新通知今天
  • 兰州网站搜索引擎优化健身器材网站源码
  • 网站托管目的是什么动漫制作专业就业方向和前景
  • 免费行情软件app网站大全下载有图片教做美食的网站
  • 淘宝客网站里面catid=16网络推广技巧培训
  • 站外推广免费网站东莞家居网站建设
  • 济南品质网站建设费用篮网目前排名
  • 安全教育网站建设背景微信开发者工具官方文档
  • 保定网站建设方案托管平台开发的基本流程
  • 抓取网站后台齐齐哈尔市建设网站
  • 防制网站怎么做网站 三合一
  • 网站备案抽查英文外贸网站设计
  • 网站建设总体设计德尔普的网站建设的价格
  • c2c网站开发毕业设计code snippet wordpress
  • 做侵权网站用哪里的服务器稳wordpress 怎么切换主题
  • 长春企业网站如何建设电商商城系统免费版下载
  • 电脑网站拦截怎么解除影楼网站模版