java中,操作数据库有jdbc、hibernate、mybatis等技术,今天整理了下,来讲一讲下mybatis。也为自己整理下文档;
hibernate是一个完全的orm框架,是完全面向对象的。但是由于全部都是以对象的形式来操作数据库,sql代码都是由框架自动生成,可操作性和灵活性比较mybatis都要差一些。所以,mybatis慢慢的变成多数开发的标准配置;
一、mybatis框架建设
mybatis的整体框架结构如下图所示,按照下图的工程原样建立即可(其中jar包在文章末尾提供)
二、编写数据库表对应的实体类
首先,数据库表结构如下(mysql数据库):
1、实体类user.java中写入如下代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
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中写入配置文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
<!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(公用文件)
在文件中写入默认参数:
1
2
3
4
5
6
|
# 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
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<?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)
内容代码为:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
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中:
1
2
3
|
<select id= "selectbyname" parametertype= "string" resulttype= "cn.qkp.po.user" >
select * from user where username like '%${value}%'
</select>
|
ps:在xml中,使用#{}占位符表示系统自动会进行java类型和jdbc类型自动转换;而${}表示原样输出,使用${}会造成sql注入漏洞攻击,慎用;
在mybatisrun代码中:
1
2
3
4
5
6
7
|
@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
以上就是基本的框架搭建和简单的查询操作,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持服务器之家!
原文链接:http://www.cnblogs.com/mylydg/p/6419498.html