springboot集成mbatisplus+sharding-jdbc+垂直切分

创建一个新库叫做user_db

 

 

/**
* 用户实体表
*/
@Data
public class TUser {
private Long userId;
private String ustatus;
private String username;
}
@Repository
public interface UserMapper extends BaseMapper<TUser> {
}
目前遇到的问题,实体表写的User,连接的时候找不到user,明明数据源配置的没问题。

INTO user ( ustatus,
username ) VALUES ( ?,
? )

后来实体类就改了,其实在上面加@Table的注解用别名也行。

 

 

#垂直切分
spring.shardingsphere.datasource.u1.type=com.alibaba.druid.pool.DruidDataSource
spring.shardingsphere.datasource.u1.driver-class-name=com.mysql.cj.jdbc.Driver
spring.shardingsphere.datasource.u1.url=jdbc:mysql://192.168.31.200:3306/user_db?serverTimezone=GMT%2B8
spring.shardingsphere.datasource.u1.username=root
spring.shardingsphere.datasource.u1.password=player3.

#t_user 表策略  u1库的表
spring.shardingsphere.sharding.tables.t_user.actual-data-nodes=u$->{1}.t_user

#主键生成策略
# 指定t_user表 主键user_id 生成策略为 SNOWFLAKE
spring.shardingsphere.sharding.tables.t_user.key-generator.column=user_id
spring.shardingsphere.sharding.tables.t_user.key-generator.type=SNOWFLAKE


# 指定分片策略 约定user_id值是直接添加到t_user种
spring.shardingsphere.sharding.tables.t_user.table-strategy.inline.sharding-column=user_id
spring.shardingsphere.sharding.tables.t_user.table-strategy.inline.algorithm-expression=t_user












    /**
* 单条插入
*/
@Test
public void addUser() {
TUser TUser = new TUser();
TUser.setUsername("张三2");
TUser.setUstatus("111132");
userMapper.insert(TUser);
}

@Test
public void findUser() {
QueryWrapper<TUser> wrapper = new QueryWrapper<>();
wrapper.eq("user_id",691448769429897217l);
TUser tUser = userMapper.selectOne(wrapper);
System.out.println(tUser);
//TUser(userId=691448769429897217, ustatus=111132, username=张三2)

}
posted @   三号小玩家  阅读(47)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
历史上的今天:
2021-01-22 Google Guava的splitter用法
Title
三号小玩家的 Mail: 17612457115@163.com, 联系QQ: 1359720840 微信: QQ1359720840

喜欢请打赏

扫描二维码打赏

支付宝打赏

点击右上角即可分享
微信分享提示