Mybatis应用入门
mybatis简介
Mybatis是在jdbc的基础之上封装而成的持久层框架。
Mybatis是一个ORM框架。ORM(object relational mapping):对象关系型映射
搭建mybatis环境
<!-- 设置项目属性 -->
<properties>
<argLine>-Dfile.encoding=UTF-8</argLine>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<!-- 依赖管理 -->
<dependencies>
<!-- mysql驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
<!-- mybatis框架 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.5</version>
</dependency>
</dependencies>
mybatis配置文件(配置连接数据库信息)
在src/main/resources下创建mybatisConfig.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="mysqlDB">
<!-- 配置一个数据库连接环境 -->
<environment id="mysqlDB">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<!-- url -->
<property name="url" value="jdbc:mysql://127.0.0.1:3306/mybatis"></property>
<!-- name -->
<property name="username" value="root"></property>
<!-- password -->
<property name="password" value="root"></property>
<!-- driver class -->
<property name="driver" value="com.mysql.jdbc.Driver"></property>
</dataSource>
</environment>
</environments>
<!-- mybatis映射文件 -->
<mappers>
<mapper resource="mapper/UserEntityMapper.xml"></mapper>
</mappers>
</configuration> 主题结构:
<!ELEMENT configuration (properties?, settings?, typeAliases?, typeHandlers?, objectFactory?, objectWrapperFactory?, reflectorFactory?, plugins?, environments?, databaseIdProvider?, mappers?)>
<!ELEMENT mapper (cache-ref | cache | resultMap* | parameterMap* | sql* | insert* | update* | delete* | select* )+>
mybatis映射文件
<?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.offcn.mybatis.entity">
<!-- insert -->
<insert id="insertUser">
insert into tbl_user values(2,'scott','tiger',25)
</insert>
</mapper>
常用API
public class TestMybatis {
public static void main(String[] args) throws IOException {
// 加载配置文件
Reader reader = Resources.getResourceAsReader("mybatisConfig.xml");
// 创建构造器对象
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
// 创建工厂
SqlSessionFactory sqlSessionFactory = builder.build(reader);
//创建执行对象
SqlSession session = sqlSessionFactory.openSession();
// 执行sql语句
session.insert("insertUser");
// 提交事务
session.commit();
session.close();
}
}
向SQL语句传参数方式
(1)传对象 <update id="updateUser" parameterType="UserEntity">
update tbl_user set
uname=#{uname},upass=#{upass},uage=#{uage} where
uid=#{uid}
</update>
public void updateUser() {
UserEntity user = new UserEntity(8, "紫衫龙王", "qkdny", 41);
// 创建执行对象
SqlSession session = sqlSessionFactory.openSession();
// 执行sql语句
session.insert("updateUser", user);
// 提交事务
session.commit();
session.close();
}
(2)传map对象
public void queryMap() {
// 构造条件
Map<String, Object> map = new HashMap<String, Object>();
map.put("name", "scott");
map.put("password", "tiger");
// 创建执行对象
SqlSession session = sqlSessionFactory.openSession();
// 执行sql语句
List<UserEntity> list = session.selectList("queryMap", map);
for (UserEntity user : list) {
System.out.println(user);
}
session.close();
}
<!-- 根据用户名和密码查询 -->
<select id="queryMap" resultType="UserEntity" parameterType="java.util.Map">
SELECT uid,uname,upass,uage from tbl_user where uname=#{name} and upass=#{password}
</select>
(3)直接传变量
public void queryById() {
// 创建执行对象
SqlSession session = sqlSessionFactory.openSession();
// 执行sql语句
UserEntity user = (UserEntity) session.selectOne("queryById", 5);
System.out.println(user);
session.close();
}
<select id="queryById" parameterType="int" resultType="UserEntity">
SELECT uid,uname,upass,uage from tbl_user where uid=#{uid}
</select>
使用实体类别名
<typeAliases>
<!-- 设置实体类别名 --> 要根据属性顺序设置该属性,不然配置文件报错
<typeAlias type="com.offcn.mybatis.entity.UserEntity" alias="UserEntity"></typeAlias>
</typeAliases> <insert id="insertUserWithParam" parameterType="UserEntity">//此处就可以使用别名了
insert into tbl_user(uid,uname,upass,uage) values(#{uid},#{uname},#{upass},#{uage})
</insert>
获取sql结果的方式
获取对象
<!-- query id resultType:设定返回值-->
<select id="queryById" parameterType="int" resultType="UserEntity">
SELECT uid,uname,upass,uage from tbl_user where uid=#{uid}
</select> @Test
public void queryById() {
// 创建执行对象
SqlSession session = sqlSessionFactory.openSession();
// 执行sql语句,获取对象
UserEntity user =(UserEntity)session.selectOne("queryById", 5);
System.out.println(user);
session.close();
} 获取集合
<!-- query All -->
<select id="queryAll" resultType="UserEntity">
SELECT uid,uname,upass,uage from tbl_user
</select>
@Test
public void queryAll() {
// 创建执行对象
SqlSession session = sqlSessionFactory.openSession();
// 执行sql语句,获取list集合
List<UserEntity> list=session.selectList("queryAll");
for(UserEntity user:list) {
System.out.println(user);
}
session.close();
}
简单日志使用
导入log4j依赖
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.15</version>
</dependency> resources下创建日志文件log4j.properties
### set log levels ###
log4j.rootLogger = debug,stdout,log
#, log, index, D, I, W, E ### print log to console ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = %d %p [%c] - <%m>%n ### create log to file ###
log4j.appender.log = org.apache.log4j.DailyRollingFileAppender
log4j.appender.log.File = /logs/log.log
log4j.appender.log.Append = true
log4j.appender.log.layout = org.apache.log4j.PatternLayout
log4j.appender.log.layout.ConversionPattern= %d %p [%c] - <%m>%n # Control logging for other open source packages
log4j.logger.net.sf.navigator=ERROR
log4j.logger.net.sf.acegisecurity=WARN
log4j.logger.net.sf.acegisecurity.intercept.event.LoggerListener=WARN
log4j.logger.org.apache.commons=ERROR
log4j.logger.org.apache.struts=WARN
log4j.logger.org.displaytag=ERROR
log4j.logger.org.springframework=WARN
log4j.logger.org.apache.velocity=WARN # SqlMap logging configuration...
log4j.logger.com.ibatis=debug
log4j.logger.com.ibatis.db=debug
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=debug
log4j.logger.com.ibatis.sqlmap.engine.cache.CacheModel=debug
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientImpl=debug
log4j.logger.com.ibatis.sqlmap.engine.builder.xml.SqlMapParser=debug
log4j.logger.com.ibatis.common.util.StopWatch=debug log4j.logger.java.sql.Connection=debug
log4j.logger.java.sql.Statement=error
log4j.logger.java.sql.PreparedStatement=debug
log4j.logger.java.sql.ResultSet=error 日志级别
A:off 最高等级,用于关闭所有日志记录。
B:fatal 指出每个严重的错误事件将会导致应用程序的退出。
C:error 指出虽然发生错误事件,但仍然不影响系统的继续运行。
D:warn 表明会出现潜在的错误情形。
E:info 一般和在粗粒度级别上,强调应用程序的运行全程。
F:debug 一般用于细粒度级别上,对调试应用程序非常有帮助。
G:all 最低等级,用于打开所有日志记录。
Mybatis应用入门的更多相关文章
- MyBatis学习总结(一)——MyBatis快速入门
一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...
- MyBatis快速入门
一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...
- MyBatis学习总结(一)——MyBatis快速入门(转载)
本文转载自http://www.cnblogs.com/jpf-java/p/6013537.html MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了 ...
- MyBatis入门学习教程-MyBatis快速入门
一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...
- MyBatis学习总结(一)——MyBatis快速入门
一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...
- 【转】MyBatis学习总结(一)——MyBatis快速入门
[转]MyBatis学习总结(一)——MyBatis快速入门 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC ...
- mybatis快速入门(六)
前面mybatis的入门程序基本上都写完了,就看大家的灵活运用了,今天来吧前面的整合一下封装一个公共的BaseDao 只需要把前面的改造下然后创建一个BaseDao的接口,其它的继承BaseDao接口 ...
- MyBatis学习总结-MyBatis快速入门的系列教程
MyBatis学习总结-MyBatis快速入门的系列教程 [MyBatis]MyBatis 使用教程 [MyBatis]MyBatis XML配置 [MyBatis]MyBatis XML映射文件 [ ...
- MyBatis基础入门《二十》动态SQL(foreach)
MyBatis基础入门<二十>动态SQL(foreach) 1. 迭代一个集合,通常用于in条件 2. 属性 > item > index > collection : ...
- MyBatis基础入门《十九》动态SQL(set,trim)
MyBatis基础入门<十九>动态SQL(set,trim) 描述: 1. 问题 : 更新用户表数据时,若某个参数为null时,会导致更新错误 2. 分析: 正确结果: 若某个参数为nul ...
随机推荐
- OpenFOAM制作动画
原视频下载地址:https://yunpan.cn/cMpfh9cCjKnZI(提取码:823b)
- linux 命令scp
scp命令网络传输文件 上传文件 scp 文件名 usename@10.233.23.100:Data/ 上传文件夹到服务器 scp -r 文件夹(不带/)usename@10.233.23.100: ...
- 修改layui的表单手机、邮箱验证可以为空怎么实现?
修改layui的表单手机.邮箱验证可以为空 解决办法: 修改源码: 把表单验证源代码(form.js)的正则表达式改一下,例如手机的正则为:/^1d{10}$/,可以改成/^$|^1d{10} ...
- Error-JavaScript:SCRIPT1007: 缺少 ']'
ylbtech-Error-JavaScript:SCRIPT1007: 缺少 ']' SCRIPT1007: 缺少 ']' 1.返回顶部 · if (flag) { return eval(&quo ...
- flutter FloatingActionButton组件
import 'package:flutter/material.dart'; class FloatingActionButtonDemo extends StatelessWidget { @ov ...
- 003——angular 组件 以及组件里面的模板
创建组件: ng g component components/news 一.创建 angualr 组件................................................ ...
- nginx通过robots.txt禁止所有蜘蛛访问(禁止搜索引擎收录)
在server {} 块中添加下面的配置 location =/robots.txt { default_type text/html; add_header Content-Type "t ...
- 【Linux】反向代理
Nginx server { root /data/wwwroot/; server_name www.test.com; location / { proxy_http_version 1.1; p ...
- 果卿居士-《四种清净明诲》之不淫欲 -------------------------------------------------------------------------------- (转自学佛网:http://www.xuefo.net/nr/article19/186541.html)
“如不断淫”, “阿难,如不断淫,修禅定者,如蒸砂石.欲其成饭.经百千劫.只名热砂.何以故.此非饭本.砂石成故.” 阿难啊,如果这个修行的人,最后不能断除淫欲,包括夫妻之间的淫欲,如果你不能断除这个欲 ...
- django中同通过getlist() 接收页面form的post数组
前端中的一些东西: <form action="people?action=edit" method="post"> <input type= ...