Mybatis框架搭建与简单查询详解
java中,操作数据库有jdbc、hibernate、mybatis等技术,今天整理了下,来讲一讲下mybatis。也为自己整理下文档;
hibernate是一个完全的orm框架,是完全面向对象的。但是由于全部都是以对象的形式来操作数据库,sql代码都是由框架自动生成,可操作性和灵活性比较mybatis都要差一些。所以,mybatis慢慢的变成多数开发的标准配置;
一、mybatis框架建设
mybatis的整体框架结构如下图所示,按照下图的工程原样建立即可(其中jar包在文章末尾提供)
二、编写数据库表对应的实体类
首先,数据库表结构如下(mysql数据库):
1、实体类user.java中写入如下代码:
public class user { @override public string tostring() { return "user [id=" + id + ", username=" + username + ", sex=" + sex + ", address=" + address + ", birthday=" + birthday + "]"; } private int id; private string username; private string sex; private string address; private date birthday; public int getid() { return id; } public void setid(int id) { this.id = id; } public string getusername() { return username; } public void setusername(string username) { this.username = username; } 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; } public date getbirthday() { return birthday; } public void setbirthday(date birthday) { this.birthday = birthday; } }
2、向sqlmapconfig.xml中写入配置文件
<!doctype configuration public "-//mybatis.org//dtd config 3.0//en" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <!-- 和spring整合后 environments配置将废除--> <environments default="development"> <environment id="development"> <!-- 使用jdbc事务管理--> <transactionmanager type="jdbc" /> <!-- 数据库连接池--> <datasource type="pooled"> <property name="driver" value="com.mysql.jdbc.driver" /> <property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterencoding=utf-8" /> <property name="username" value="root" /> <property name="password" value="123456" /> </datasource> </environment> </environments> <mappers> <mapper resource="sqlmap/user.xml"></mapper> </mappers> </configuration>
注意:sqlmapconfig中的mysql账户与密码需要改成你自己的账号密码
三、在config包下建立log4j.properties(公用文件)
在文件中写入默认参数:
# global logging configuration,建议开发环境中要用debug log4j.rootlogger=debug, stdout # console output... log4j.appender.stdout=org.apache.log4j.consoleappender log4j.appender.stdout.layout=org.apache.log4j.patternlayout log4j.appender.stdout.layout.conversionpattern=%5p [%t] - %m%n
四、开始编写user.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"> <!-- namespace命名空间,为了对sql语句进行隔离,方便管理 ,mapper开发dao方式,使用namespace有特殊作用 --> <mapper namespace="test"> <!-- 在mapper.xml文件中配置很多的sql语句,执行每个sql语句时,封装为mappedstatement对象 mapper.xml以statement为单位管理sql语句 --> <!-- 根据id查询用户信息 --> <!-- id:唯一标识 一个statement #{}:表示 一个占位符,如果#{}中传入简单类型的参数,#{}中的名称随意 parametertype:输入 参数的类型,通过#{}接收parametertype输入 的参数 resulttype:输出结果 类型,不管返回是多条还是单条,指定单条记录映射的pojo类型 --> <select id="finduserbyid" parametertype="int" resulttype="cn.qkp.mybatis.po.user"> select * from user where id=#{id} </select> </mapper>
以上配置完成,整个mybatis基础框架就算是搭建完毕了。我们就可以使用代码来操作数据库了。我们先对数据库进行简单的查询操作;
=========================使用mybatis!===============================
一、在first包中建立测试类(mybatisfrist.java)
内容代码为:
private sqlsessionfactory sqlsessionfactory;//存储sqlsessionfactory 对象 @before public void star() throws exception{ //设置配置路径,mybitis是以sqlmapconfig.xml为主路径。因为sqlmapconfig中的mapper关联了user.xml //因为在config根目录下,所以可以直接引用而不用带config string resource = "sqlmapconfig.xml"; //sqlmapconfig.xml读给输入流,使用mybitis的resources类下的getresourceasstream实现 inputstream inputstream = resources.getresourceasstream(resource); //创建mybitis的sqlsessionfactory工厂类 sqlsessionfactory = new sqlsessionfactorybuilder().build(inputstream); } @test public void test(){ //通过工厂类打开数据接口 sqlsession sqlsession = sqlsessionfactory.opensession(); //设置接收对象 user user = null; try { //查询数据selectone为查询一条的方法第一个参数是user.xml中的namespace.id;第二个参数是user配置文件中的#{id} user = sqlsession.selectone("test.finduserbyid", 1); } catch (exception e) { // todo: handle exception }finally{ sqlsession.close();//读完要关闭sqlsession } system.out.println(user);//打印输出 }
运行上述代码,结果为:
以上便成功连通数据库,并获取到指定数据!
ps:以上是查询单一数值的查询方法,如果要查询一组数据使用sqlsession的selectlist方法,接收一个list;代码如下:
在user.xml中:
<select id="selectbyname" parametertype="string" resulttype="cn.qkp.po.user"> select * from user where username like '%${value}%' </select>
ps:在xml中,使用#{}占位符表示系统自动会进行java类型和jdbc类型自动转换;而${}表示原样输出,使用${}会造成sql注入漏洞攻击,慎用;
在mybatisrun代码中:
@test public void star2(){ sqlsession sqlsession = sqlsessionfactory.opensession(); list<user> user = sqlsession.selectlist("test.selectbyname", "小明"); sqlsession.close(); system.out.println(user.get(0)); }
结果为:
相关的jar包连接:http://pan.baidu.com/s/1i4tijd7
以上就是基本的框架搭建和简单的查询操作,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
推荐阅读
-
Mybatis框架搭建与简单查询详解
-
详解MyEclipse中搭建spring-boot+mybatis+freemarker框架
-
详解SpringMVC和MyBatis框架开发环境搭建和简单实用
-
详解SpringMVC和MyBatis框架开发环境搭建和简单实用
-
详解手把手Maven搭建SpringMVC+Spring+MyBatis框架(超级详细版)
-
详解利用SpringCloud搭建一个最简单的微服务框架
-
详解手把手Maven搭建SpringMVC+Spring+MyBatis框架(超级详细版)
-
Docker搭建简单的应用栈与容器Hello World访问详解
-
详解Spring与Mybatis的整合方法(基于Eclipse的搭建)
-
Java Fluent Mybatis 聚合查询与apply方法详解流程篇