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

零基础网站建设教程百度推广深圳分公司

零基础网站建设教程,百度推广深圳分公司,鞍钢节能公司网站开发,网站要背代码?文章目录 介绍org.apache.ibatis.jdbc.SQLSQL类使用示例SelectProvider搭配动态SQLAbstractSQL类源码分析 介绍 当我们需要使用Statement对象执行SQL时,SQL语句会嵌入Java代码中。SQL语句比较复杂时,我们可能会在代码中对SQL语句进行拼接,查…

文章目录

  • 介绍
  • org.apache.ibatis.jdbc.SQL
  • SQL类使用示例
  • @SelectProvider搭配动态SQL
  • AbstractSQL类源码分析

介绍

当我们需要使用Statement对象执行SQL时,SQL语句会嵌入Java代码中。SQL语句比较复杂时,我们可能会在代码中对SQL语句进行拼接,查询条件不固定时,还需要根据不同条件拼接不同的SQL语句。在MyBatis中已经为我们提供了这类开发工具类。
MyBatis 中的 AbstractSQL 类是 MyBatis 提供的一个用于构建动态 SQL 语句的工具类。它的主要用途是帮助开发者更灵活、优雅地拼接复杂的 SQL 语句,尤其是在需要根据条件生成不同的 SQL 语句时,可以减少手动拼接 SQL 字符串的繁琐工作,并提高代码的可读性和维护性。
在日常开发中,尤其是当涉及到复杂查询、更新、插入时,AbstractSQL 可以用于生成动态 SQL。其用途主要包括以下几个方面:

动态条件查询:根据不同的条件拼接 SELECT 语句。
动态插入:根据传入的实体类生成不同的 INSERT 语句。
动态更新:根据条件生成 UPDATE 语句,只更新有值的字段。
动态删除:根据条件拼接 DELETE 语句。
AbstractSQL 的核心思想是通过链式调用的方式构建 SQL 语句,这类似于构建器模式(Builder Pattern)。

org.apache.ibatis.jdbc.SQL

public class SQL extends AbstractSQL<SQL> {@Overridepublic SQL getSelf() {return this;}
}

SQL类继承了AbstractSQL,在日常开发中一般使用SQL类。

SQL类使用示例

【动态构建 SELECT 查询】

  @Testpublic void testSelectSQL() {String orgSql = "SELECT P.ID, P.USERNAME, P.PASSWORD, P.FULL_NAME, P.LAST_NAME, P.CREATED_ON, P.UPDATED_ON\n" +"FROM PERSON P, ACCOUNT A\n" +"INNER JOIN DEPARTMENT D on D.ID = P.DEPARTMENT_ID\n" +"INNER JOIN COMPANY C on D.COMPANY_ID = C.ID\n" +"WHERE (P.ID = A.ID AND P.FIRST_NAME like ?) \n" +"OR (P.LAST_NAME like ?)\n" +"GROUP BY P.ID\n" +"HAVING (P.LAST_NAME like ?) \n" +"OR (P.FIRST_NAME like ?)\n" +"ORDER BY P.ID, P.FULL_NAME";String newSql = new SQL() {{SELECT("P.ID, P.USERNAME, P.PASSWORD, P.FULL_NAME");SELECT("P.LAST_NAME, P.CREATED_ON, P.UPDATED_ON");FROM("PERSON P");FROM("ACCOUNT A");INNER_JOIN("DEPARTMENT D on D.ID = P.DEPARTMENT_ID");INNER_JOIN("COMPANY C on D.COMPANY_ID = C.ID");WHERE("P.ID = A.ID");WHERE("P.FIRST_NAME like ?");OR();WHERE("P.LAST_NAME like ?");GROUP_BY("P.ID");HAVING("P.LAST_NAME like ?");OR();HAVING("P.FIRST_NAME like ?");ORDER_BY("P.ID");ORDER_BY("P.FULL_NAME");}}.toString();assertEquals(orgSql, newSql);}
// 匿名内部类风格
public String deletePersonSql() {return new SQL() {{DELETE_FROM("PERSON");WHERE("ID = #{id}");}}.toString();
}// Builder / Fluent 风格
public String insertPersonSql() {String sql = new SQL().INSERT_INTO("PERSON").VALUES("ID, FIRST_NAME", "#{id}, #{firstName}").VALUES("LAST_NAME", "#{lastName}").toString();return sql;
}// 动态条件(注意参数需要使用 final 修饰,以便匿名内部类对它们进行访问)
public String selectPersonLike(final String id, final String firstName, final String lastName) {return new SQL() {{SELECT("P.ID, P.USERNAME, P.PASSWORD, P.FIRST_NAME, P.LAST_NAME");FROM("PERSON P");if (id != null) {WHERE("P.ID like #{id}");}if (firstName != null) {WHERE("P.FIRST_NAME like #{firstName}");}if (lastName != null) {WHERE("P.LAST_NAME like #{lastName}");}ORDER_BY("P.LAST_NAME");}}.toString();
}public String deletePersonSql() {return new SQL() {{DELETE_FROM("PERSON");WHERE("ID = #{id}");}}.toString();
}public String insertPersonSql() {return new SQL() {{INSERT_INTO("PERSON");VALUES("ID, FIRST_NAME", "#{id}, #{firstName}");VALUES("LAST_NAME", "#{lastName}");}}.toString();
}public String updatePersonSql() {return new SQL() {{UPDATE("PERSON");SET("FIRST_NAME = #{firstName}");WHERE("ID = #{id}");}}.toString();
}

相关官方文档:
https://mybatis.org/mybatis-3/zh_CN/statement-builders.html

@SelectProvider搭配动态SQL

@SelectProvider 注解是 MyBatis 提供的一种动态 SQL 语句生成方式,用于将复杂的查询逻辑封装在 Java 方法中,而不是直接在 Mapper 接口的方法上书写固定的 SQL 语句。通过 @SelectProvider 注解,MyBatis 可以根据实际情况动态生成 SQL,这使得 SQL 语句更加灵活和可维护。
@SelectProvider 的基本语法

@SelectProvider(type = SQLProviderClass.class, method = "methodName")
List<ResultType> selectMethod(参数);

type:指定提供 SQL 语句的类(通常称为 Provider 类)。
method:指定 Provider 类中的方法名称,该方法用于动态生成 SQL。
selectMethod:Mapper 接口中的方法,最终会执行 methodName 返回的 SQL 语句。

这个注解和@SELECT的区别在于@SelectProvider 注解可以中参数SQLProviderClass可以搭配SQL动态语句类关联SQL。

  @SelectProvider(type = UserSqlProvider.class, method = "buildSelectSql")List<Map<String, Object>> selectUsers(Map<String, Object> params);
public class UserSqlProvider {public String buildSelectSql(Map<String, Object> params) {return new SQL() {{SELECT("*");FROM("t_user");if (params.get("name") != null) {WHERE("name = #{name}");}if (params.get("age") != null) {WHERE("age = #{age}");}ORDER_BY("id DESC");}}.toString();}
}

测试类:

  /*** 测试@SelectProvider使用*/@Testpublic void test6() throws Exception {InputStream resource = Resources.getResourceAsStream(MybatisTest.class.getClassLoader(), "mybatis-config.xml");SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resource);Configuration configuration = sqlSessionFactory.getConfiguration();// 手动注册mapperconfiguration.addMapper(UserMapper.class);SqlSession sqlSession = sqlSessionFactory.openSession();UserMapper mapper = sqlSession.getMapper(UserMapper.class);Map<String, Object> params = new HashMap<>();params.put("name", "zhangSan");params.put("age", 18);List<Map<String, Object>> res = mapper.selectUsers(params);System.out.println(res);}

在这里插入图片描述

AbstractSQL类源码分析

SQL继承至AbstractSQL类,只重写了该类的getSelf()方法,所有的功能由AbstractSQL类完成,AbstractSQL类中维护了一个SQLStatement内部类的实例和一系列前面提到过的构造SQL语句的方法,例如SELECT()、UPDATE()等方法。

  public enum StatementType {DELETE, INSERT, SELECT, UPDATE}
  StatementType statementType;List<String> sets = new ArrayList<>();List<String> select = new ArrayList<>();List<String> tables = new ArrayList<>();List<String> join = new ArrayList<>();List<String> innerJoin = new ArrayList<>();List<String> outerJoin = new ArrayList<>();List<String> leftOuterJoin = new ArrayList<>();List<String> rightOuterJoin = new ArrayList<>();List<String> where = new ArrayList<>();List<String> having = new ArrayList<>();List<String> groupBy = new ArrayList<>();List<String> orderBy = new ArrayList<>();List<String> lastList = new ArrayList<>();List<String> columns = new ArrayList<>();List<List<String>> valuesList = new ArrayList<>();boolean distinct;String offset;String limit;LimitingRowsStrategy limitingRowsStrategy = LimitingRowsStrategy.NOP;
 switch (statementType) {case DELETE:answer = deleteSQL(builder);break;case INSERT:answer = insertSQL(builder);break;case SELECT:answer = selectSQL(builder);break;case UPDATE:answer = updateSQL(builder);break;default:answer = null;}

SQLStatement内部类用于描述一个SQL语句,该类中通过StatementType确定SQL语句的类型。SQLStatement类中还维护了一系列的ArrayList属性,当调用SELECT()、UPDATE()等方法时,这些方法的参数内容会记录在这些ArrayList对象中。
AbstrastSQL类重写了toString()方法,该方法中会调用SQLStatement对象的sql()方法生成SQL字符串。这里会根据不同的SQL类型进行不同类型的SQL语句拼接。

   private String selectSQL(SafeAppendable builder) {if (distinct) {sqlClause(builder, "SELECT DISTINCT", select, "", "", ", ");} else {sqlClause(builder, "SELECT", select, "", "", ", ");}sqlClause(builder, "FROM", tables, "", "", ", ");joins(builder);sqlClause(builder, "WHERE", where, "(", ")", " AND ");sqlClause(builder, "GROUP BY", groupBy, "", "", ", ");sqlClause(builder, "HAVING", having, "(", ")", " AND ");sqlClause(builder, "ORDER BY", orderBy, "", "", ", ");limitingRowsStrategy.appendClause(builder, offset, limit);return builder.toString();}
  @Testpublic void testSelectSQL2() {String newSql = new SQL() {{SELECT("name,mobile_no,age");FROM("t_user A");INNER_JOIN("student B on B.name = A.name");WHERE("B.name like ?");OR();WHERE("A.ID = ?");ORDER_BY("A.ID DESC");}}.toString();System.out.println(newSql);}

在这里插入图片描述


文章转载自:
http://wanjiafilamentary.pfbx.cn
http://wanjiabypass.pfbx.cn
http://wanjiahathpace.pfbx.cn
http://wanjiahigher.pfbx.cn
http://wanjiaaprosexia.pfbx.cn
http://wanjiase.pfbx.cn
http://wanjiafeverweed.pfbx.cn
http://wanjiahominoid.pfbx.cn
http://wanjianonprincipled.pfbx.cn
http://wanjiagovernor.pfbx.cn
http://wanjiasubdentate.pfbx.cn
http://wanjiacompartmental.pfbx.cn
http://wanjianef.pfbx.cn
http://wanjiaphotocoagulator.pfbx.cn
http://wanjiaskosh.pfbx.cn
http://wanjiadib.pfbx.cn
http://wanjiaelectromagnetic.pfbx.cn
http://wanjiadiandrous.pfbx.cn
http://wanjiabronchogenic.pfbx.cn
http://wanjiagrammy.pfbx.cn
http://wanjiasatiation.pfbx.cn
http://wanjiacontortion.pfbx.cn
http://wanjiamacerate.pfbx.cn
http://wanjiashiur.pfbx.cn
http://wanjiasyphiloid.pfbx.cn
http://wanjiamouthwatering.pfbx.cn
http://wanjiasqueegee.pfbx.cn
http://wanjiahologamous.pfbx.cn
http://wanjiatuneless.pfbx.cn
http://wanjiabuccaneerish.pfbx.cn
http://wanjiaflying.pfbx.cn
http://wanjiainserted.pfbx.cn
http://wanjiasagely.pfbx.cn
http://wanjiawhippet.pfbx.cn
http://wanjiagloboid.pfbx.cn
http://wanjiahypermetrope.pfbx.cn
http://wanjiaheatronic.pfbx.cn
http://wanjiaincreate.pfbx.cn
http://wanjiabalm.pfbx.cn
http://wanjiaukulele.pfbx.cn
http://wanjiabroadband.pfbx.cn
http://wanjiagalvanoplasty.pfbx.cn
http://wanjiaeletricity.pfbx.cn
http://wanjiacoboundary.pfbx.cn
http://wanjiaran.pfbx.cn
http://wanjialambert.pfbx.cn
http://wanjiaalular.pfbx.cn
http://wanjiayabber.pfbx.cn
http://wanjiasigil.pfbx.cn
http://wanjiasphenoid.pfbx.cn
http://wanjiaiou.pfbx.cn
http://wanjiasubtility.pfbx.cn
http://wanjialexicality.pfbx.cn
http://wanjiaintercurrent.pfbx.cn
http://wanjiavanishingly.pfbx.cn
http://wanjiawooftah.pfbx.cn
http://wanjiaresidual.pfbx.cn
http://wanjiageorama.pfbx.cn
http://wanjiasorriness.pfbx.cn
http://wanjiatropism.pfbx.cn
http://wanjianundine.pfbx.cn
http://wanjiairascibly.pfbx.cn
http://wanjialaudator.pfbx.cn
http://wanjiaibsenist.pfbx.cn
http://wanjiaarsenite.pfbx.cn
http://wanjiascopy.pfbx.cn
http://wanjiareprobance.pfbx.cn
http://wanjiapolyunsaturate.pfbx.cn
http://wanjiananometer.pfbx.cn
http://wanjiaglob.pfbx.cn
http://wanjiaunderfed.pfbx.cn
http://wanjiaunbefitting.pfbx.cn
http://wanjiacoquette.pfbx.cn
http://wanjiaproduction.pfbx.cn
http://wanjiamanjak.pfbx.cn
http://wanjiarustiness.pfbx.cn
http://wanjiabarbate.pfbx.cn
http://wanjiacdp.pfbx.cn
http://wanjiachemoimmunotherapy.pfbx.cn
http://wanjiaglost.pfbx.cn
http://www.15wanjia.com/news/107447.html

相关文章:

  • 网站色情营销特点网站流量查询服务平台
  • 徐州优化网站百度天眼查
  • 邪恶做动态网站如何在百度上发布自己的文章
  • 做网站职校选什么专业建网站的软件
  • 微信服务平台开发广州百度推广优化排名
  • 查互做蛋白的网站长春网站建设模板
  • 网站开发公司官网网站建设方案外包
  • 江西网站设计哪家好百度手机助手下载2021新版
  • 高端购物网站b2b平台推广
  • 专业做京东网站吗谷歌浏览器搜索入口
  • 有什么好的互联网平台做网站微信小程序开发教程
  • 网站注册需要多少钱个人网站该怎么打广告
  • 北京的做网站公司百度官网下载安装
  • 有没有会计做兼职的网站技术培训机构
  • 宜选网的网站是什么做的搜索引擎关键词排名优化
  • 网站收银系统建设网店运营具体做什么
  • 做网站直播的主播靠谱吗应用宝下载
  • 学做网站需要懂什么软件整站seo外包
  • 网站做轮播图的意义网站收录服务
  • 中国网站建设服务中心seo咨询师
  • 做网站要的带宽是什么营销广告网站
  • 开淘宝店怎么做充值网站百度网页版主页网址
  • 手机网站制作方法百度号码认证平台首页
  • 游戏软件开发需要学什么专业广州网站设计专注乐云seo
  • 玉树电子商务网站建设公司国外b站视频推广网站
  • 免费的wordpress分类在哪设置顺德搜索seo网络推广
  • wordpress更换域名首页无法访问seo sem推广
  • 苏州公司网站建设方案阿里大数据平台
  • 多人在线协作网站开发网站建设与管理主要学什么
  • 晋城市住房保障和城乡建设局网站专门做推广的软文