分表jdbctemplate mybatis

sharding分表应用笔记(四)——踩坑记录

sharding分表应用笔记(四)——踩坑记录(更新中) 目录sharding分表应用笔记(四)——踩坑记录(更新中)1 sql语句使用时不带分表关键字段2 在事务中触发数据源路由 1 sql语句使用时不带分表关键字段 如果不带分表关键字段,会默认进行全节点域遍历。如果没有预先创建所有的表节点,会报 ......
分表 sharding 笔记

mybatis plus order by 不支持convert函数

最近业务上有个需求,要按照企业名称中文进行排序显示。项目使用的是mybatisplus + mysql 从网上看到的排序解决方法是使用mysql 的 convert函数: select * from 客户表 where *** order by convert(`企业名称` using GBK); ......
函数 mybatis convert order plus

jdbc和Mybatis的区别?Mybatis的如何返回结果,底层原理是什么?

jdbc和Mybatis的区别? JDBC(Java Database Connectivity)和 MyBatis(也称为 iBatis)都是用于在 Java 应用程序中访问数据库的工具,但它们有一些重要的区别。 抽象程度: 1.JDBC: 是 Java 标准库的一部分,提供了一组用于执行 SQL ......
Mybatis 底层 原理 结果 jdbc

MyBatis基础知识梳理

一、MyBatis简介 1.1 简介 ​ MyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO ......
基础知识 MyBatis 基础 知识

Mybatis-Plus集成Sharding-JDBC与Flyway实现多租户分库分表

背景 公司产品部收到了一些重要客户的需求,他们希望能够依赖独立的数据库存储来支持他们的业务数据。与此同时,仍有许多中小客户,可以继续使用公共库以满足其需求。技术实现方面,此前持久层框架使用的Mybatis-plus,部分业务场景使用到了Sharding-JDBC用于分表,另外,我们的数据库版本控制工 ......

Spring5学习随笔-整合MyBatis(持久层)、连接池、Mapper文件

主要涵盖了Spring与持久层技术的整合,以及Spring与MyBatis的整合。第一章介绍了为什么需要将Spring与持久层技术整合,以及Spring可以与哪些持久层技术进行整合。第二章详细介绍了Spring与MyBatis的整合思路、开发步骤和编码实例,并解决了MyBatis开发过程中存在的问题... ......
随笔 Spring5 MyBatis 文件 Spring

分表

shardingsphere: datasource: name: test test: type: com.alibaba.druid.pool.DruidDataSource url: jdbc:mysql://192.168.124.12:3306/zjjs?serverTimezone=UT ......
分表

mybatis自动分表和JdbcTemplate自动建表

需求背景:由于业务的增长,原有的表存放的太多的数据,每次去查询的数据耗时很久,严重影响了查询效率,所以才有了今天的博客文章,在处理问题的过程中,有考虑mysql的分区方案,我的分区是按照月份的,但是对于定时任务来说,时间存在重复的,所以mysql分区方案被剔除,因为项目xxl-job的方案,主要针对 ......
分表 JdbcTemplate mybatis

sharding分表应用笔记(三)——多数据源路由

sharding分表应用笔记(三)——多数据源路由 目录sharding分表应用笔记(三)——多数据源路由1 背景2 配置2.1 命名空间配置2.2 spring-jdbc路由配置3 指定路由3.1 自定义注解3.2 功能实现3.3 用例 1 背景 应用背景:物理数据源只有一个;对于部分数据量大的表 ......
分表 数据源 路由 sharding 笔记

mybatis判断多个条件

以下是通过仓库+物资来进行查询 @Select("<script>" + "SELECT v.id,v.kfcode,v.kfname,v.kc, p.wzname,p.dw,v.wzgg" + " FROM (select * from y_kc" + " where softdel=0" + " ......
多个 条件 mybatis

MyBatis-Plus

MyBatis-Plus官网:https://baomidou.com/ 一、简介 1. 概述 MyBatis-Plus(简称 MP,是由baomidou(苞米豆)组织开源的)是一个基于 MyBatis 的增强工具,它对 Mybatis 的基础功能进行了增强,但未做任何改变。 使得我们可以在 Myb ......
MyBatis-Plus MyBatis Plus

No libraries found for 'tk.mybatis.mapper.common.Mapper'

1,无法导入tk.mybatis.mapper.common.Mapper 2.Mapper报错No libraries found for 'tk.mybatis.mapper.common.Mapper' 解决方法如下(添加通用mybatis这个依赖) 1.在pom.xml中添加tk.mybat ......
libraries mybatis Mapper common mapper

Mybatis注意事项

一、事务问题 1、事务的特征 事务应该具有4个属性:原子性、一致性、隔离性、持久性。这四个属性通常称为ACID特性。 1、原子性(atomicity)。一个事务是一个不可分割的工作单位,事务中的诸多操作要么都做,要么都不做。 2、一致性(consistency)。事务必须是使数据库从一个一致性状态变 ......
注意事项 事项 Mybatis

mybatis拦截器:实现拦截update语句插入列值

修改sql的时机 在预编译SQL(prepare方法)前加入修改的逻辑,可以对sql处理也可以对映射类做处理。 准备的xml文件 mybatis-config.xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PU ......
语句 mybatis update

MyBatis踩坑之单字符条件比较

背景 Mybatis中可以使用 <choose><when>...</when></choose> 语句来实现条件选择,<when> 标签含有 test 属性用于设置比较条件,但是在某些特定情况下,字符串的比较会存在一个坑,那就是单字符字符串会被降级为字符类型(char),从而导致比较条件不会生效。 ......
单字 条件 MyBatis

Dapper NetCore 分表实战

在项目开发过程中很多时候需要持久化大数据,其中的一项选择就是数据库分库分表,本篇从实战角度介绍在NetCore中如何通过Dapper实现分表,废话不多说,开搞! 模拟业务场景:公司中有很多员工,分为不同的角色:老板(Boss), 虾兵(Shrimp Soldier),蟹将(CrabGeneral), ......
分表 实战 NetCore Dapper

Mybatis配置

Mybatis配置 常用依赖(pom.xml) <!--添加log4j依赖--> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency> ......
Mybatis

MyBatis

1.什么是MyBatis? MyBatis 是一款优秀的持久层框架 MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的过程 MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 实体类 【Plain Old Java Objects, ......
MyBatis

Mybatis和其他主流框架的整合使用

Mybatis简介 MyBatis历史 MyBatis最初是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Software Foundation迁移到了Google Code。随着开发团队转投Google Code旗下,iBatis3.x正式更名为MyBatis。代 ......
框架 主流 Mybatis

【随手记】mybatis动态sql foreach遍历List<Map>问题

使用mybatis时经常需要在xml里写动态sql,发现foreach标签使用的问题 foreach标签使用 当Mapper传参是List<Map<String, Object>集合的形式时,不能直接使用参数名,会找不到对应的参数。 list类型的参数会特殊处理封装在map中,map的key就叫li ......
手记 mybatis foreach 动态 问题

mybatis模糊查询

模糊查询在我们开发中是一项必不可缺少的重要内容。对于我们mybatis实现模糊查询有三种方式,以下具体的实现步聚: 1. 添加模糊查询的接口方法getStudentBySname List<Student> getStudentBySname1(String sname); List<Student ......
mybatis

mybatis返回自增主键值

对于自增主键在某些业务中保存一个对象后,需要使用到这个主键完成后续的业务逻辑,就需要获取该主键值。 1、在接口中定义新增方法 int addStudent(Student student); 2、在mapper中配置新增配置 方式一: <insert id="addStudent" paramete ......
mybatis

2.Spring、SpringMVC、MyBatis、Git入门

Spring核心思想 数据管理:事务、整合数据库 web 集成:邮件、定时任务、消息队列、安全控制 管理bean:给bean,给配置(知道关系) 1.启动tomcat 2.自动创建Spring容器,自动扫描某些包下的某些bean,让bean装配到容器中 @SpringBootConfiguratio ......
SpringMVC MyBatis Spring Git

java项目实战-mybatis-基本用法02接口绑定实现类-day23

目录1. 复习 什么是接口 什么是类?2. mybatis接口绑定实现类 来实现查询3. 参数的传递4 插入数据 1. 复习 什么是接口 什么是类? public interface Speak { void say(); } Speak这个接口里面定义了say方法 所有实现了Speak的类 都必须 ......
实战 接口 mybatis 项目 java

Mybatis-Plus 使用隐患,太坑了!

作者:糊涂码 链接:https://juejin.cn/post/7156428078061895710 前言 MP 从出现就一直有争议 感觉一直 都存在两种声音 like: 很方便啊 通过函数自动拼接Sql 不需要去XML 再去使用标签 之前一分钟写好的Sql 现在一秒钟就能写好 简直不要太方便 ......
Mybatis-Plus 隐患 Mybatis Plus

使用Springboot结合mybatis搭建最简单的操作mysql教程

废话不说,上代码 pom文件,如果是jdk1.8,请使用如下的SpringBoot版本号 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http ......
Springboot mybatis 教程 mysql

mybatis-plus 根据当前时间,判断检索

<if test="timeStatus != null and timeStatus.trim() != ''"> <if test="timeStatus == 1"> <![CDATA[ AND DATE_FORMAT(now(), '%Y-%m-%d %H:%i:%S') < DATE_FO ......
mybatis-plus mybatis 时间 plus

Mybatis 查询数据库正常返回,但是部分数据丢失,显示null

今天遇到了这个Mybatis 查询数据库正常返回,但是部分数据丢失,显示null。原来是对象名和表的字段名有问题!!! 搜了一下,看见了这个https://blog.csdn.net/adminoy/article/details/131505328 但是我的对象名和表的字段名是一样的。例如:res ......
数据 Mybatis 部分 数据库 null

mybatis

5.解决属性名和字段名不一致的问题 解决方法: 起别名 ResultMap 6.日志 6.1日志工厂 如果一个数据库出现了异常,我们经常需要排错,日志是最好的助手。 曾经:sout,debug 现在:日志 需要掌握的:LOG4J STDOUT_LOGGING 至于具体使用哪一个,在MyBatis中设 ......
mybatis

sharding分表应用笔记(二)——按时间分表策略配置

sharding分表应用笔记(二)——按时间分表策略配置 目录sharding分表应用笔记(二)——按时间分表策略配置1 背景2 配置2.1 命名空间配置2.2 策略接口实现2.2.1 时间精确分片策略2.2.2 时间范围分片策略3 外部链接 1 背景 应用背景:物理数据源只有一个;对于部分数据量大 ......
分表 sharding 策略 时间 笔记