程序使用mybatis的步骤:

1.配置mybatis

涉及到的配置文件有conf.xml和与实体类对应的映射配置文件

(1) conf.xml:配置数据库信息和需要加载的映射文件

<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<!-- 配置数据库信息 -->
<property name="driver" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/jobinfokd?serverTimezone=GMT%2B8"/>
<property name="username" value="root"/>
<property name="password" value="000000"/>
</dataSource>
</environment>
</environments>
<mappers>
<!-- 加载映射文件 -->
<mapper resource="org/alex/entity/usersMapper.xml"/>
</mappers>
</configuration>

这里我使用的是MySQL,在设置url时,第一次没有写?serverTimezone=GMT%2B8,会报一个关于时区什么的错误,看视频学习的时候里面用的Oracle,并没有报这个错误,总之加上如图所示的代码就好了。<mappers></mappers>标签内的映射文件即为下文的与实体类相关的映射文件。

还有一个小细节,将MySQL的驱动添加到lib目录后,这里写driver的时候,刚开始按照网上的写的是com.mysql.jdbc.Driver,结果报了错,错误信息提示要改成com.mysql.cj.jdbc.Driver

(2) 映射文件xxMapper.xml:写增删改查标签,即对数据库表的操作

例:usersMapper.xml文件

 <mapper namespace="org.alex.entity.usersMapper">
<select id="queryUsersById" resultType="org.alex.entity.Users" parameterType="String">
select * from logins where loginid = #{loginid}
</select>
</mapper>

这里实现了一个查询的操作,namespace表示该xml文件所在的包名+xml文件名(注:这里映射文件与实体类在同一个包下),resultType表示sql语句返回的结果类型,这里设置为返回一个Users实体类(要写实体类的全类名),parameterType表示输入类型,因为我的查询语句的where条件后的loginid设计为varchar类型,所以这里对应的要写String。

2.写测试类 TestMyBatis

 public class TestMyBatis {
public static void main(String args[]) throws IOException {
//加载Mybatis配置文件(为了访问数据库)
Reader reader = Resources.getResourceAsReader("conf.xml");
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(reader);
//相当于connection
SqlSession session = sessionFactory.openSession();
String statement = "org.alex.entity.usersMapper.queryUsersById";
Users users = session.selectOne(statement,"root");
System.out.println(users);
session.close();
} }

上文代码中session相当于传统方法中的connection,第4,5,7句代码都是固定的,第8行代码根据映射文件中查询语句设置的id以包名+映射文件名+id找到sql语句,第9行代码中“root”为where条件中的loginid,最后打印出结果,关闭连接。

<mapper namespace="org.alex.entity.usersMapper"> <select id="queryUsersById" resultType="org.alex.entity.Users" parameterType="String"> select * from logins where loginid = #{loginid}  </select></mapper>

第一次使用mybatis的更多相关文章

  1. 初识Mybatis框架,实现增删改查等操作(动态拼接和动态修改)

    此第一次接触Mybatis框架确实是有点不适应,特别是刚从Hibernate框架转转型过来,那么为什么要使用Mybatis框架,Mybatis框架和Hibernate框架又有什么异同呢? 这个问题在我 ...

  2. 使用Mybatis Generator 生产 AS400中的数据表对象

    第一次使用Mybatis,由于公司核心服务器是AS400,参考了网络各个大大的教程后,发现无法使用Mybatis Generator自动生成AS400中的表对象 参考URL: http://www.c ...

  3. 初识Mybatis框架,实现增删改查等操作

    此第一次接触Mybatis框架确实是有点不适应,特别是刚从Hibernate框架转转型过来,那么为什么要使用Mybatis框架,Mybatis框架和Hibernate框架又有什么异同呢? 这个问题在我 ...

  4. Mybatis.net与MVC入门配置及联合查询动态SQL拼接和简单事务

    第一次学习Mybatis.net,在博客园也找到好多资料,但是在配置成功之后也遇到了一些问题,尤其是在动态SQl拼接时候,这里把遇到的问题还有自己写的一个Demo贴出来,希望能帮到新手,有不适合的地方 ...

  5. MyBatis源码解析【5】工厂的构建

    前言 这个分类比较连续,如果这里看不懂,或者第一次看,请回顾之前的博客 http://www.cnblogs.com/linkstar/category/1027239.html 终于算是把装备弄齐全 ...

  6. MyBatis与MySQL交互

    MyBatis是我接触到的第一个框架,下面谈一谈我第一次使用MyBatis时的感悟. 首先是一些准备工作 下载相关的jar包.到GitHub上就行,上面有全面和完整的jar文件 在eclipse上安装 ...

  7. MyBatis简单使用和入门理解

    本文记录第一次使用Mybatis时碰到的一些错误和简单理解,采用的示例是Eclipse中的JAVA工程,采用XML文件定义数据库连接. 可以使用Java JDBC API直接操作数据库,但使用框架会更 ...

  8. 实习小结(四)--- MyBatis Generator使用

    第一次听闻MyBatis Generator插件很是惊讶,已经有这么便捷方式的工具通过数据库表来自动生成实体类,映射文件,接口以及帮助类,而且可以通过自己写方法来增加中文注释,遂来学习一波.首先先建一 ...

  9. 为何Spring MVC可获取到方法参数名,而MyBatis却不行?【享学Spring MVC】

    每篇一句 胡适:多谈些问题,少聊些主义 前言 Spring MVC和MyBatis作为当下最为流行的两个框架,大家平时开发中都在用.如果你往深了一步去思考,你应该会有这样的疑问: 在使用Spring ...

随机推荐

  1. Dangerous well

    Firsttime to develop games throuth Unity3d, such a great platform! You can build your games more qui ...

  2. oracle 根据一个表更新另一个表内容

    declarecursor c_col is select * from xtgl_jgmcbm where substr(v_jgbm,0,2)in('41');--v_sjbm in( selec ...

  3. 提示Unused default export错误,如何解决

    问题描述如下: 这个错误提示其实是webstorm的变量语法检查提示,修改一下它的配置就好了. 1.点击Webstorm右下角的小人,点击Configure inspections 2.在搜索框中输入 ...

  4. TCP学习总结(二)

    前面一节咱们介绍完了TCP协议,这部分,将要介绍,TCP是如何实现可靠传输的. TCP的可靠传输 1.滑动窗口 上一节我们介绍TCP报文段头部的时候说得到,"窗口"这个部分,&qu ...

  5. python pycharm pyqt 安装

    1.python3 windows:www.python.org/download/windows/ 我的是WIN7  64位所以选的是    Download Windows x86-64 exec ...

  6. vue+element-ui实现表格编辑(增加或删除行,删除单行或删除多行)

    <template> <div class="app-container"> <div class="filter-container&qu ...

  7. [JsonSchema] 关于接口测试 Json 格式比对核心算法实现 (Java 版)

    引言 为什么要自己重新造轮子,而不是采用第三方的JsonSchema方法进行实现存在以下痛点:1.我之前在网上找了很久,没有找到java版直接进行jsonschema生成的方法或直接比较的方法2.ht ...

  8. Delphi7连接MySql数据库-DBGrid控件显示数据

    一个简单的Delphi7小程序,使用MySql数据库做简单查询,用DBGrid控件显示结果,实现过程如下: (1)在MySql中新建demouser表,插入记录用于测试. (2)在Delphi7中新建 ...

  9. checkbox默认选中

    http://www.ggfenxiang8.com/?page_id=1108 需要最新前端视频教程vu.js1.0/2.0等的可以叫我QQ1139721002

  10. iOS CATransition 动画的简单使用

    下面是实现的代码 //选择动画 - (IBAction)selectAnimationTypeButton:(id)sender { UIButton *button = sender; animat ...