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

网站站建设黑帽seo技术论坛

网站站建设,黑帽seo技术论坛,婚礼策划公司,建筑资料免费下载网站Mybatis注解开发单表操作Mybatis的常用注解Mybatis的增删改查MyBatis注解开发的多表操作MyBatis的注解实现复杂映射开发一对一查询一对多查询多对多查询构建sqlsql构建对象介绍查询功能的实现新增功能的实现修改功能的实现删除功能的实现Mybatis注解开发单表操作 Mybatis的常用…

  • Mybatis注解开发单表操作
    • Mybatis的常用注解
    • Mybatis的增删改查
  • MyBatis注解开发的多表操作
    • MyBatis的注解实现复杂映射开发
    • 一对一查询
    • 一对多查询
    • 多对多查询
  • 构建sql
    • sql构建对象介绍
    • 查询功能的实现
    • 新增功能的实现
    • 修改功能的实现
    • 删除功能的实现

Mybatis注解开发单表操作

Mybatis的常用注解

使用注解开发方式,可以减少编写Mapper映射文件

@Insert:实现新增

@Update:实现更新

@Delete:实现删除

@Select:实现查询

@Result:实现结果集封装

@Results:可以与@Result 一起使用,封装多个结果集

@One:实现一对一结果集封装

@Many:实现一对多结果集封装

Mybatis的增删改查

步骤一:创建mapper接口

public interface StudentMapper {//查询全部@Select("SELECT * FROM student")public abstract List<Student> selectAll();//新增操作@Insert("INSERT INTO student VALUES (#{id},#{name},#{age})")public abstract Integer insert(Student stu);//修改操作@Update("UPDATE student SET name=#{name},age=#{age} WHERE id=#{id}")public abstract Integer update(Student stu);//删除操作@Delete("DELETE FROM student WHERE id=#{id}")public abstract Integer delete(Integer id);
}

步骤二:测试类

public class Test01 {@Testpublic void selectAll() throws Exception{//1.加载核心配置文件InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");//2.获取SqlSession工厂对象SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);//3.通过工厂对象获取SqlSession对象SqlSession sqlSession = sqlSessionFactory.openSession(true);//4.获取StudentMapper接口的实现类对象StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);//5.调用实现类对象中的方法,接收结果List<Student> list = mapper.selectAll();//6.处理结果for (Student student : list) {System.out.println(student);}//7.释放资源sqlSession.close();is.close();}@Testpublic void insert() throws Exception{//1.加载核心配置文件InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");//2.获取SqlSession工厂对象SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);//3.通过工厂对象获取SqlSession对象SqlSession sqlSession = sqlSessionFactory.openSession(true);//4.获取StudentMapper接口的实现类对象StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);//5.调用实现类对象中的方法,接收结果Student stu = new Student(4,"赵六",26);Integer result = mapper.insert(stu);//6.处理结果System.out.println(result);//7.释放资源sqlSession.close();is.close();}@Testpublic void update() throws Exception{//1.加载核心配置文件InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");//2.获取SqlSession工厂对象SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);//3.通过工厂对象获取SqlSession对象SqlSession sqlSession = sqlSessionFactory.openSession(true);//4.获取StudentMapper接口的实现类对象StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);//5.调用实现类对象中的方法,接收结果Student stu = new Student(4,"赵六",36);Integer result = mapper.update(stu);//6.处理结果System.out.println(result);//7.释放资源sqlSession.close();is.close();}@Testpublic void delete() throws Exception{//1.加载核心配置文件InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");//2.获取SqlSession工厂对象SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);//3.通过工厂对象获取SqlSession对象SqlSession sqlSession = sqlSessionFactory.openSession(true);//4.获取StudentMapper接口的实现类对象StudentMapper mapper = sqlSession.getMapper(StudentMapper.class);//5.调用实现类对象中的方法,接收结果Integer result = mapper.delete(4);//6.处理结果System.out.println(result);//7.释放资源sqlSession.close();is.close();}
}

加载使用了注解的Mapper接口

<mappers><!--扫描使用注解的类--><mapper class="com.itheima.mapper.UserMapper"></mapper>
</mappers>

或者指定扫描包含映射关系的接口所在的包

<mappers><!--扫描使用注解的类所在的包--><package name="com.itheima.mapper"></package>
</mappers>

MyBatis注解开发的多表操作

MyBatis的注解实现复杂映射开发

加粗样式

一对一查询

对应sql语句

SELECT * FROM card;SELECT * FROM person WHERE id=#{id};

创建PersonMapper接口

public interface PersonMapper {//根据id查询@Select("SELECT * FROM person WHERE id=#{id}")public abstract Person selectById(Integer id);
}

使用注解配置Mapper

public interface CardMapper {//查询全部@Select("SELECT * FROM card")@Results({@Result(column = "id",property = "id"),@Result(column = "number",property = "number"),@Result(property = "p",             // 被包含对象的变量名javaType = Person.class,    // 被包含对象的实际数据类型column = "pid",             // 根据查询出的card表中的pid字段来查询person表/*one、@One 一对一固定写法select属性:指定调用哪个接口中的哪个方法*/one = @One(select = "com.itheima.one_to_one.PersonMapper.selectById"))})public abstract List<Card> selectAll();
}

测试类

public class Test01 {@Testpublic void selectAll() throws Exception{//1.加载核心配置文件InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");//2.获取SqlSession工厂对象SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);//3.通过工厂对象获取SqlSession对象SqlSession sqlSession = sqlSessionFactory.openSession(true);//4.获取CardMapper接口的实现类对象CardMapper mapper = sqlSession.getMapper(CardMapper.class);//5.调用实现类对象中的方法,接收结果List<Card> list = mapper.selectAll();//6.处理结果for (Card card : list) {System.out.println(card);}//7.释放资源sqlSession.close();is.close();}}

总结

@Results:封装映射关系的父注解。Result[] value():定义了 Result 数组
@Result:封装映射关系的子注解。column 属性:查询出的表中字段名称property 属性:实体对象中的属性名称javaType 属性:被包含对象的数据类型one 属性:一对一查询固定属性@One:一对一查询的注解。select 属性:指定调用某个接口中的方法

一对多查询

使用注解配置Mapper

public interface ClassesMapper {//查询全部@Select("SELECT * FROM classes")@Results({@Result(column = "id",property = "id"),@Result(column = "name",property = "name"),@Result(property = "students",  // 被包含对象的变量名javaType = List.class,  // 被包含对象的实际数据类型column = "id",          // 根据查询出的classes表的id字段来查询student表/*many、@Many 一对多查询的固定写法select属性:指定调用哪个接口中的哪个查询方法*/many = @Many(select = "com.itheima.one_to_many.StudentMapper.selectByCid"))})public abstract List<Classes> selectAll();
}

总结

@Results:封装映射关系的父注解。Result[] value():定义了 Result 数组
@Result:封装映射关系的子注解。column 属性:查询出的表中字段名称property 属性:实体对象中的属性名称javaType 属性:被包含对象的数据类型many 属性:一对多查询固定属性
@Many:一对多查询的注解。select 属性:指定调用某个接口中的方法

多对多查询

使用注解配置Mapper

public interface StudentMapper {//查询全部@Select("SELECT DISTINCT s.id,s.name,s.age FROM student s,stu_cr sc WHERE sc.sid=s.id")@Results({@Result(column = "id",property = "id"),@Result(column = "name",property = "name"),@Result(column = "age",property = "age"),@Result(property = "courses",   // 被包含对象的变量名javaType = List.class,  // 被包含对象的实际数据类型column = "id",          // 根据查询出student表的id来作为关联条件,去查询中间表和课程表/*many、@Many 一对多查询的固定写法select属性:指定调用哪个接口中的哪个查询方法*/many = @Many(select = "com.itheima.many_to_many.CourseMapper.selectBySid"))})public abstract List<Student> selectAll();
}

总结

@Results:封装映射关系的父注解。Result[] value():定义了 Result 数组
@Result:封装映射关系的子注解。column 属性:查询出的表中字段名称property 属性:实体对象中的属性名称javaType 属性:被包含对象的数据类型many 属性:一对多查询固定属性
@Many:一对多查询的注解。select 属性:指定调用某个接口中的方法

构建sql

sql构建对象介绍

MyBatis 给我们提供了 org.apache.ibatis.jdbc.SQL 功能类,专门用于构建 SQL 语句
在这里插入图片描述

查询功能的实现

  • 定义功能类并提供获取查询的 SQL 语句的方法。

  • @SelectProvider:生成查询用的 SQL 语句注解。

    type 属性:生成 SQL 语句功能类对象

    method 属性:指定调用方法

新增功能的实现

  • 定义功能类并提供获取新增的 SQL 语句的方法。

  • @InsertProvider:生成新增用的 SQL 语句注解。

    type 属性:生成 SQL 语句功能类对象

    method 属性:指定调用方法

修改功能的实现

  • 定义功能类并提供获取修改的 SQL 语句的方法。

  • @UpdateProvider:生成修改用的 SQL 语句注解。

    type 属性:生成 SQL 语句功能类对象

    method 属性:指定调用方法

删除功能的实现

  • 定义功能类并提供获取删除的 SQL 语句的方法。

  • @DeleteProvider:生成删除用的 SQL 语句注解。

    type 属性:生成 SQL 语句功能类对象

    method 属性:指定调用方法


文章转载自:
http://dreich.tgcw.cn
http://preestablish.tgcw.cn
http://trf.tgcw.cn
http://japanophobia.tgcw.cn
http://epinephrine.tgcw.cn
http://hmv.tgcw.cn
http://ncaa.tgcw.cn
http://colltype.tgcw.cn
http://adobe.tgcw.cn
http://ironic.tgcw.cn
http://depopularize.tgcw.cn
http://enthronize.tgcw.cn
http://armarian.tgcw.cn
http://eutrophication.tgcw.cn
http://implantation.tgcw.cn
http://devoice.tgcw.cn
http://neurilemmal.tgcw.cn
http://streetlight.tgcw.cn
http://camouflage.tgcw.cn
http://drear.tgcw.cn
http://electroshock.tgcw.cn
http://reserpine.tgcw.cn
http://soph.tgcw.cn
http://tire.tgcw.cn
http://electrometric.tgcw.cn
http://damson.tgcw.cn
http://chasid.tgcw.cn
http://cairo.tgcw.cn
http://notary.tgcw.cn
http://cosec.tgcw.cn
http://infundibulate.tgcw.cn
http://thermel.tgcw.cn
http://monial.tgcw.cn
http://wayleave.tgcw.cn
http://dendroclimatic.tgcw.cn
http://romanticist.tgcw.cn
http://oncer.tgcw.cn
http://improper.tgcw.cn
http://palaearctic.tgcw.cn
http://tropoelastin.tgcw.cn
http://benefactive.tgcw.cn
http://posturepedic.tgcw.cn
http://jughead.tgcw.cn
http://frap.tgcw.cn
http://resettlement.tgcw.cn
http://menacme.tgcw.cn
http://velodrome.tgcw.cn
http://multiwall.tgcw.cn
http://trusteeship.tgcw.cn
http://jokul.tgcw.cn
http://attestation.tgcw.cn
http://chancellor.tgcw.cn
http://cyclicity.tgcw.cn
http://aerotropic.tgcw.cn
http://elul.tgcw.cn
http://disarray.tgcw.cn
http://ancon.tgcw.cn
http://spoliatory.tgcw.cn
http://slope.tgcw.cn
http://byzantium.tgcw.cn
http://monorchid.tgcw.cn
http://waster.tgcw.cn
http://jesuitize.tgcw.cn
http://towie.tgcw.cn
http://sulfatase.tgcw.cn
http://lichenification.tgcw.cn
http://saloop.tgcw.cn
http://uscgr.tgcw.cn
http://scall.tgcw.cn
http://disestablishmentarian.tgcw.cn
http://necessarian.tgcw.cn
http://neuritis.tgcw.cn
http://quaestorship.tgcw.cn
http://caution.tgcw.cn
http://leaving.tgcw.cn
http://ventrodorsal.tgcw.cn
http://algology.tgcw.cn
http://forefather.tgcw.cn
http://crofting.tgcw.cn
http://screwhead.tgcw.cn
http://insulting.tgcw.cn
http://sukie.tgcw.cn
http://consistency.tgcw.cn
http://naugahyde.tgcw.cn
http://demarche.tgcw.cn
http://resentful.tgcw.cn
http://colossus.tgcw.cn
http://goura.tgcw.cn
http://lepidopteron.tgcw.cn
http://metafemale.tgcw.cn
http://incredible.tgcw.cn
http://samlo.tgcw.cn
http://prut.tgcw.cn
http://irishman.tgcw.cn
http://photoplate.tgcw.cn
http://proudhearted.tgcw.cn
http://patency.tgcw.cn
http://photosurface.tgcw.cn
http://sasquatch.tgcw.cn
http://surfaceman.tgcw.cn
http://www.dt0577.cn/news/99559.html

相关文章:

  • 最专业的网站建设价格国外搜索引擎有哪些
  • 群晖nda做网站西安网站到首页排名
  • 网络优化怎么自己做网站seo排名赚
  • 女孩子做网站推广seo 的作用和意义
  • 网站开发经典seo网站推广
  • 长沙 做营销型网站的公司西安seo优化工作室
  • 珠宝类网站建设可执行报告营销策略ppt
  • 临沂做进销存网站网店推广方案策划书
  • 有哪些网站做的好游戏推广员判几年
  • C#如何做简易网站汕头百度推广公司
  • 网站排名软件 利搜bt磁力猫
  • 怎么查询一个网站从哪做的百度官方网站入口
  • 中英文版网站是怎么做的百度科技有限公司
  • 怎样做一家网站潍坊网站外包
  • 网吧手机网站模版sem搜索引擎营销
  • 外贸建设网站公司哪家好郑州seo推广外包
  • 智能自助建站网站水果网络营销策划书
  • 西安seo盐城seo入门课程
  • 英文网站建设的问题好用的种子搜索引擎
  • 网站建设市场趋势营销推广软文案例
  • 做网站咨询免费下载优化大师
  • 个人创建网站程序下载浏览器
  • 一个公司可以做多少网站搜索引擎优化的报告
  • 广东建设局网站首页网络营销推广有效方式
  • 网站开发人员如何写工作日志友情链接检测工具
  • wordpress 文章页当前栏目链接seo站长论坛
  • 免费php网站开发模板成都百度推广排名优化
  • 阿里云做网站视频教程百度竞价怎么做
  • 有什么可以做兼职的网站吗企业网络搭建方案
  • 零食网页制作素材搜索引擎优化案例