说明:本文章的数据源不是在配置文件中配置两个或多个数据源,在业务方面对这些数据源来回切换,本文章中的数据源是可以动态添加,修改,切换的,废话不多说。
先看工程图:
1.pom.xml文件
4.0.0
com.example
demo
0.0.1-SNAPSHOT
jar
DemoOne
Demo project for Spring Boot
org.springframework.boot
spring-boot-starter-parent
2.2.2.RELEASE
UTF-8
UTF-8
1.2.0
5.1.39
1.8
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-validation
org.springframework.boot
spring-boot-starter-freemarker
org.springframework.boot
spring-boot-starter-test
test
mysql
mysql-connector-java
runtime
com.oracle
ojdbc6
11.2.0.3
org.postgresql
postgresql
42.2.2
com.baomidou
dynamic-datasource-spring-boot-starter
3.5.1
com.alibaba
druid-spring-boot-starter
1.2.9
com.baomidou
mybatis-plus-boot-starter
3.5.1
com.baomidou
mybatis-plus-generator
3.5.2
org.apache.commons
commons-dbcp2
2.8.0
com.github.pagehelper
pagehelper-spring-boot-starter
mybatis
org.mybatis
mybatis-spring
org.mybatis
1.2.10
com.h2database
h2
org.projectlombok
lombok
1.14.8
com.github.xiaoymin
knife4j-spring-boot-starter
2.0.9
cn.hutool
hutool-all
5.8.0.M3
commons-lang
commons-lang
2.6
com.google.guava
guava
21.0
com.alibaba
fastjson
1.2.28
org.springframework.boot
spring-boot-maven-plugin
2.application.yml
server:
port: 9000
spring:
datasource:
dynamic:
primary: master
datasource:
#默认数据库
master:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/my_demo_01?characterEncoding=utf8&useSSL=false&autoReconnect=true&allowPublicKeyRetrieval=true&serverTimezone=GMT%2B8
username: root
password: root
#my_demo_02:
# driver-class-name: com.mysql.cj.jdbc.Driver
# url: jdbc:mysql://127.0.0.1:3306/my_demo_02?characterEncoding=utf8&useSSL=false&autoReconnect=true&allowPublicKeyRetrieval=true&serverTimezone=GMT%2B8
# username: root
# password: root
jackson:
date-format: dd/MM/yyyy
time-zone: GMT+8
mvc:
date-format: dd/MM/yyyy HH:mm:ss
pathmatch:
matching-strategy: ant_path_matcher
logging:
level:
com.baomidou: debug
mybatis-plus:
mapper-locations: classpath:mappers/*.xml
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
3.fs_order.sql和sys_user.sql
/*
Navicat Premium Data Transfer
Source Server : 本机数据库mysql
Source Server Type : MySQL
Source Server Version : 80011 (8.0.11)
Source Host : localhost:3306
Source Schema : my_demo_01
Target Server Type : MySQL
Target Server Version : 80011 (8.0.11)
File Encoding : 65001
Date: 30/10/2023 11:24:09
*/
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for sys_user
-- ----------------------------
DROP TABLE IF EXISTS `sys_user`;
CREATE TABLE `sys_user` (
`id` varchar(38) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '主键',
`user_name` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '用户名',
`nick_name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '昵称',
`age` int(4) NULL DEFAULT NULL COMMENT '年龄',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '用户表' ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of sys_user
-- ----------------------------
INSERT INTO `sys_user` VALUES ('a', 'zhanglong', '张龙', 30);
INSERT INTO `sys_user` VALUES ('b', 'zhaohu', '赵虎', 31);
INSERT INTO `sys_user` VALUES ('c', 'wangchao', '王朝', 32);
INSERT INTO `sys_user` VALUES ('d', 'mahan', '马汉', 33);
SET FOREIGN_KEY_CHECKS = 1;
/*
Navicat Premium Data Transfer
Source Server : 本机数据库mysql
Source Server Type : MySQL
Source Server Version : 80011 (8.0.11)
Source Host : localhost:3306
Source Schema : my_demo_02
Target Server Type : MySQL
Target Server Version : 80011 (8.0.11)
File Encoding : 65001
Date: 30/10/2023 11:24:22
*/
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for fs_order
-- ----------------------------
DROP TABLE IF EXISTS `fs_order`;
CREATE TABLE `fs_order` (
`id` varchar(38) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
`order_num` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '订单号',
`address` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '订单地址',
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '订单表' ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of fs_order
-- ----------------------------
INSERT INTO `fs_order` VALUES ('111', '0456afa8-3c7b-40a6-a82c-544ea16ee082', '梁山八百里水泊');
INSERT INTO `fs_order` VALUES ('222', '625b2fa6-a3c5-49f9-bfc9-f8c84b5af6a0', '大运河桥');
SET FOREIGN_KEY_CHECKS = 1;
4.MySpringBootApplication.java
package com.example;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
//@MapperScan("com.example.mapper") //在数据层配置@Mapper一个功能
@SpringBootApplication
public class MySpringBootApplication {
public static void main(String[] args) {
SpringApplication.run(MySpringBootApplication.class, args);
}
}
5.SwaggerConfig.java
package com.example.config;
import com.github.xiaoymin.knife4j.spring.annotations.EnableKnife4j;
import org.springframework.boot.autoconfigure.condition.ConditionalOnWebApplication;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.ParameterBuilder;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.schema.ModelRef;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Parameter;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2WebMvc;
import java.util.ArrayList;
import java.util.List;
/**
* @author 李庆伟
* @date 2022/5/20 10:22
*/
@ConditionalOnWebApplication
@Configuration
@EnableSwagger2WebMvc
@EnableKnife4j
public class SwaggerConfig {
/**
* Swagger2的配置文件,这里可以配置Swagger2的一些基本的内容,比如扫描的包等等
* []
* @return {@link Docket}
* @throws
* @author 李庆伟
* @date 2021/12/13 16:28
*/
@Bean
public Docket createRestApi() {
//设置请求在父类方法中,如果在本类方法中设置请求头,则覆盖父类方法
List pars = makeHeader();
return new Docket(DocumentationType.SWAGGER_2)
.select()
.apis(RequestHandlerSelectors.basePackage(makeScan()))
//.apis(RequestHandlerSelectors.basePackage(App8300.class.getPackage().getName()))
.build()
.globalOperationParameters(pars)
.apiInfo(apiInfo());
}
/**
* swagger封装请求头
* [pars]
* @return {@link List< Parameter>}
* @throws
* @author 李庆伟
* @date 2022/5/20 11:26
*/
public List makeHeader(){
List pars = new ArrayList<>();
ParameterBuilder token = new ParameterBuilder();
token.name("Authorization").description("Authorization")
.modelRef(new ModelRef("string"))
.parameterType("header")
.required(false).build();
pars.add(token.build());
ParameterBuilder languageCode = new ParameterBuilder();
languageCode.name("languageCode").description("languageCode")
.modelRef(new ModelRef("string"))
.parameterType("header")
.required(false).build();
pars.add(languageCode.build());
return pars;
}
public String makeScan(){
return "com.example.controller";
}
/**
* 构建API文档的详细信息函数
* @return
*/
public ApiInfo apiInfo() {
return new ApiInfoBuilder()
.title(makeApiName())
.version("1.0")
.build();
}
public String makeApiName(){
return "项目接口 API";
}
}
6.Result.java
package com.example.results;
import com.alibaba.fastjson.JSON;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import javax.servlet.ServletResponse;
import java.io.PrintWriter;
import java.util.List;
/**
* @author 李庆伟
* @date 2020/4/16 9:52
*/
@Data
public class Result {
@ApiModelProperty(value = "返回码")
private int code;
@ApiModelProperty(value = "返回数据")
private Object data;
@ApiModelProperty(value = "返回描述")
private String msg;
@ApiModelProperty(value = "返回长度")
private long count;
@ApiModelProperty(value = "详细信息")
private String detailMessage;
/**返回成功 */
public static Result success(List data, long count){
Result result = new Result();
result.setCode(0);//成功
result.setMsg("成功!");//提示语
result.setData(data);
result.setCount(count);
return result;
}
/**返回成功 */
public static Result success(List data){
Result result = new Result();
result.setCode(0);//成功
result.setMsg("成功!");//提示语
result.setData(data);
result.setCount(data == null || data.size() == 0 ? 0 : data.size());
return result;
}
/**返回成功 */
public static Result successForPage(List data,Integer count){
Result result = new Result();
result.setCode(0);//成功
result.setMsg("失败!");//提示语
result.setData(data);
result.setCount(count == null ? 0 : count);
return result;
}
/**返回成功 */
public static Result success(){
Result result = new Result();
result.setCode(0);//成功
result.setMsg("成功!");//提示语
return result;
}
/**返回成功 */
public static Result success(Object object){
Result result = new Result();
result.setCode(0);//成功
result.setMsg("成功!");//提示语
result.setData(object);//返回内容
return result;
}
/**返回失败 */
public static Result error(){
Result result = new Result();
result.setCode(1);//失败
result.setMsg("失败!");//提示语
return result;
}
/**返回失败 */
public static Result error(int code, String msg){
Result result = new Result();
result.setCode(code);//失败
result.setMsg("失败!");//提示语
return result;
}
/**返回失败 */
public static Result error(int code, String msg, String detailMessage){
Result result = new Result();
result.setCode(code);//失败
result.setMsg("失败!");//提示语
result.setDetailMessage(detailMessage);
return result;
}
/**Response输出Json格式 */
public static void responseJson(ServletResponse response, Object data) {
PrintWriter out = null;
try {
response.setCharacterEncoding("UTF-8");
response.setContentType("application/json");
out = response.getWriter();
out.println(JSON.toJSONString(data));
out.flush();
} catch (Exception e) {
System.out.println("Response输出Json异常:" + e);
} finally {
if (out != null) {
out.close();
}
}
}
/**返回信息*/
public static Result response(int code, String msg, Object data) {
Result result = new Result();
result.setCode(code);
result.setMsg(msg);
result.setData(data);
return result;
}
}
7.DbDataSourceConstant.java
package com.example.constant;
/**
* @Description: TODO
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/27 14:09
*/
public class DbDataSourceConstant {
//oracle 驱动名称
public static final String ORACLE_DRIVER_CLASS_NAME = "oracle.jdbc.driver.OracleDriver";
//mysql 低版本驱动名称(6.0以下)
public static final String MYSQL_LOW_DRIVER_CLASS_NAME = "com.mysql.jdbc.Driver";
//mysql 高版本驱动名称(6.0以上)
public static final String MYSQL_HIGH_DRIVER_CLASS_NAME = "com.mysql.cj.jdbc.Driver";
//psotgresql 驱动名称
public static final String PSOTGRESQL_HIGH_DRIVER_CLASS_NAME = "org.postgresql.Driver";
}
8.DbOprUtil.java
package com.example.utils;
import com.baomidou.dynamic.datasource.DynamicRoutingDataSource;
import com.baomidou.dynamic.datasource.creator.DefaultDataSourceCreator;
import com.baomidou.dynamic.datasource.spring.boot.autoconfigure.DataSourceProperty;
import com.baomidou.dynamic.datasource.toolkit.DynamicDataSourceContextHolder;
import com.example.constant.DbDataSourceConstant;
import com.example.dto.DbDataSourceDTO;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import javax.annotation.Resource;
import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Set;
/**
* @Description: 操作数据源工具类
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/6/30 17:14
*/
@Component
public class DbOprUtil {
@Autowired
private DataSource dataSource;
@Resource
private DefaultDataSourceCreator dataSourceCreator;
/**
* @Description: 添加数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/6/30 17:21
*/
public Set addDataSource(DbDataSourceDTO sourceDTO) {
// 根据数据库类型设置驱动名称
switch (sourceDTO.getType().toLowerCase()) {
case "mysql":
sourceDTO.setDriverClassName(DbDataSourceConstant.MYSQL_HIGH_DRIVER_CLASS_NAME);
break;
case "oracle":
sourceDTO.setDriverClassName(DbDataSourceConstant.ORACLE_DRIVER_CLASS_NAME);
break;
case "postgresql":
sourceDTO.setDriverClassName(DbDataSourceConstant.PSOTGRESQL_HIGH_DRIVER_CLASS_NAME);
break;
default:
return null;
}
boolean status = DbLinkUtil.verifyUrlConnStatus(sourceDTO.getUrl(), sourceDTO.getDriverClassName(), sourceDTO.getUsername(), sourceDTO.getPassword());
if (!status) {
throw new RuntimeException("数据源链接失败!");
}
DataSourceProperty dataSourceProperty = new DataSourceProperty();
BeanUtils.copyProperties(sourceDTO, dataSourceProperty);
DynamicRoutingDataSource ds = (DynamicRoutingDataSource) dataSource;
DataSource dataSource = dataSourceCreator.createDataSource(dataSourceProperty);
try {
Connection connection = dataSource.getConnection();
//String schema = connection.getSchema();
///System.err.println(schema);
} catch (SQLException e) {
e.printStackTrace();
}
// 添加数据源
ds.addDataSource(sourceDTO.getPoolName(), dataSource);
return ds.getDataSources().keySet();
}
/**
* @Description: 获取所以数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/6/30 17:22
*/
public Set getAllDataSource() {
DynamicRoutingDataSource ds = (DynamicRoutingDataSource) dataSource;
return ds.getDataSources().keySet();
}
public DynamicRoutingDataSource getDataSource() {
DynamicRoutingDataSource ds = (DynamicRoutingDataSource) dataSource;
return ds;
}
/**
* @Description: 根据数据源名称删除数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/6/30 17:22
*/
public void removeByDataSourceByName(String dataSourceName) {
DynamicRoutingDataSource ds = (DynamicRoutingDataSource) dataSource;
ds.removeDataSource(dataSourceName);
}
/**
* @Description: 手动切换到该数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/6/30 17:22
*/
public void changeByDataSourceByName(String dataSourceName) {
Set set = getAllDataSource();
if(set != null && set.size() > 0 && set.contains(dataSourceName)){
DynamicDataSourceContextHolder.push(dataSourceName);
} else {
throw new RuntimeException("数据源链接切换失败!");
}
}
}
9.DbLinkUtil.java
package com.example.utils;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
/**
* @Description: 校验数据源连接是否成功
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/6/30 17:14
*/
public class DbLinkUtil {
/**
* @Description: 校验数据源连接是否成功,不成功抛异常
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/27 14:37
*/
public static boolean verifyUrlConnStatus(String url,String driverClassName, String username, String password) {
boolean flag;
Connection connection = null;
// 加载驱动类
try {
Class.forName(driverClassName);
connection = DriverManager.getConnection(url, username, password);
flag = true;
} catch (Exception e) {
e.printStackTrace();
throw new RuntimeException("数据源链接不存在!");
}finally {
try {
if (connection != null) {
connection.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
return flag;
}
/**
* @Description: 校验数据源连接是否成功,不成功返回false
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/27 14:37
*/
public static boolean verifyUrlConnStatusForB(String url,String driverClassName, String username, String password) {
boolean flag;
Connection connection = null;
// 加载驱动类
try {
Class.forName(driverClassName);
connection = DriverManager.getConnection(url, username, password);
flag = true;
} catch (Exception e) {
e.printStackTrace();
flag = false;
}finally {
try {
if (connection != null) {
connection.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
return flag;
}
}
10.DataSourceController.java
package com.example.controller;
import com.example.dto.DbDataSourceDTO;
import com.example.results.Result;
import com.example.service.DataSourceService;
import io.swagger.annotations.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import javax.validation.Valid;
import java.util.List;
/**
* 类名称:
*
* @author 李庆伟
* @date 2023年10月27日 15:32
*/
@RestController
@RequestMapping("/operDb")
@Api(tags = "数据源操作")
public class DataSourceController {
@Autowired
private DataSourceService dataSourceService;
/**
* @Description: 数据源分页查询
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/7/7 14:36
*/
@PostMapping(value = "find")
@ApiOperation(value = "查询所有数据源",notes = "查询所有数据源")
@ApiResponses({
@ApiResponse(code = 0, message = "ok", response= DbDataSourceDTO.class),
})
public Result find() {
List result = dataSourceService.find();
return Result.success(result);
}
/**
* @Description: 添加数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/7/7 15:31
* 以下面数据为例:
* poolName:my_demo_02
* type:mysql
* driverClassName:com.mysql.cj.jdbc.Driver
* url:jdbc:mysql://127.0.0.1:3306/my_demo_02?characterEncoding=utf8&useSSL=false&autoReconnect=true&allowPublicKeyRetrieval=true&serverTimezone=GMT%2B8
* username:root
* password:root
*/
@PostMapping(value = "/add")
@ApiOperation(value = "添加数据源", notes = "添加数据源", produces = "application/json")
@ApiResponses({
@ApiResponse(code = 0, message = "ok", response= DbDataSourceDTO.class),
})
public Result add(@Valid DbDataSourceDTO form) {
dataSourceService.add(form);
return Result.success();
}
/**
* @Description: 测试数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/7/7 15:31
*/
@PostMapping(value = "/checked")
@ApiOperation(value = "测试数据源", notes = "测试数据源", produces = "application/json")
@ApiResponses({
@ApiResponse(code = 0, message = "ok", response= DbDataSourceDTO.class),
})
public Result checked(@Valid DbDataSourceDTO form) {
dataSourceService.checked(form);
return Result.success();
}
/**
* @Description: 修改数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/7/10 15:44
*/
@PostMapping(value = "/edit")
@ApiOperation(value = "修改数据源", notes = "修改数据源", produces = "application/json")
@ApiResponses({
@ApiResponse(code = 0, message = "ok", response= DbDataSourceDTO.class),
})
public Result edit(@Valid DbDataSourceDTO form) {
dataSourceService.update(form);
return Result.success();
}
/**
* @Description: 删除数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/7/10 15:54
*/
@PostMapping(value = "/delete")
@ApiOperation(value = "删除数据源", notes = "删除数据源", produces = "application/json")
public Result delete(DbDataSourceDTO form) {
dataSourceService.delete(form);
return Result.success();
}
}
11.DataSourceService.java
package com.example.service;
import com.example.dto.DbDataSourceDTO;
import java.util.List;
/**
* 类名称:
*
* @author 李庆伟
* @date 2023年10月27日 15:41
*/
public interface DataSourceService {
//查询所有数据源
List find();
//添加数据源
void add(DbDataSourceDTO form);
//测试数据源是否能连接上
void checked(DbDataSourceDTO form);
//修改数据源
void update(DbDataSourceDTO form);
//删除数据源
void delete(DbDataSourceDTO form);
}
12.DataSourceServiceImpl.java
package com.example.service.impl;
import com.example.constant.DbDataSourceConstant;
import com.example.dto.DbDataSourceDTO;
import com.example.service.DataSourceService;
import com.example.utils.DbLinkUtil;
import com.example.utils.DbOprUtil;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.*;
/**
* 类名称:
*
* @author 李庆伟
* @date 2023年10月27日 15:41
*/
@Service
public class DataSourceServiceImpl implements DataSourceService {
@Autowired
private DbOprUtil dbOprUtil;
/**
* @Description: 获取所有数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/30 9:52
*/
@Override
public List find() {
Set st = dbOprUtil.getAllDataSource();
List list = new ArrayList<>();
if(st != null && st.size() > 0){
for (String str : st) {
DbDataSourceDTO dbDataSourceDTO = new DbDataSourceDTO();
dbDataSourceDTO.setPoolName(str);
//数据源连接等信息在这里就不获取了,自己debug去找,里面都有
list.add(dbDataSourceDTO);
}
}
return list;
}
/**
* @Description: 添加数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/30 9:52
*/
@Override
public void add(DbDataSourceDTO form) {
//验证数据源是否可用
checked(form);
//添加到源中成功后 在添加到数据源库中
//如果成功 Add到数据源中
dbOprUtil.addDataSource(form);
}
/**
* @Description: 验证数据源是否可用
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/30 9:53
*/
@Override
public void checked(DbDataSourceDTO form) {
//master为系统初始化数据源名称,不能被其他数据源替代和删除
if(form != null && StringUtils.isNotEmpty(form.getPoolName()) && "master".equals(form.getPoolName().toLowerCase())){
throw new RuntimeException("该关键字不能作为名称使用");
}
switch (form.getType().toLowerCase()) {
case "mysql":
form.setDriverClassName(DbDataSourceConstant.MYSQL_HIGH_DRIVER_CLASS_NAME);
break;
case "oracle":
form.setDriverClassName(DbDataSourceConstant.ORACLE_DRIVER_CLASS_NAME);
break;
case "postgresql":
form.setDriverClassName(DbDataSourceConstant.PSOTGRESQL_HIGH_DRIVER_CLASS_NAME);
break;
default:
form.setDriverClassName("");
}
//判断数据源连接是否能够连接成功
DbLinkUtil.verifyUrlConnStatus(form.getUrl(),form.getDriverClassName(),form.getUsername(),form.getPassword());
}
/**
* @Description: 修改数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/30 9:53
*/
@Override
public void update(DbDataSourceDTO form) {
//验证数据源是否可用
checked(form);
//修改数据源库中存储数据源
//删除已有数据源
delete(form);
//如果成功 Add到数据源中
dbOprUtil.addDataSource(form);
}
/**
* @Description: 删除数据源
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/30 9:53
*/
@Override
public void delete(DbDataSourceDTO form) {
if(!form.getPoolName().equals("master")){
dbOprUtil.removeByDataSourceByName(form.getPoolName());
}
}
}
13.FsOrder.java
package com.example.entity;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
/**
* 类名称:订单
*
* @author 李庆伟
* @date 2023年10月27日 15:26
*/
@Data
@TableName
public class FsOrder {
@TableId
private String id;
private String orderNum;//订单号
private String address;//订单地址
}
14.SysUser.java
package com.example.entity;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
/**
* 类名称:用户
*
* @author 李庆伟
* @date 2023年10月27日 15:26
*/
@Data
@TableName
public class SysUser {
@TableId
private String id;
private String userName;//用户名
private String nickName;//昵称
private Integer age;//年龄
}
15.TestController.java
package com.example.controller;
import com.example.entity.FsOrder;
import com.example.entity.SysUser;
import com.example.results.Result;
import com.example.service.TestService;
import io.swagger.annotations.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
/**
* 类名称:
*
* @author 李庆伟
* @date 2023年10月27日 15:32
*/
@RestController
@RequestMapping("/test")
@Api(tags = "测试通过动态数据源查询数据")
public class TestController {
@Autowired
private TestService testService;
/**
* @Description: 查询所有用户【在master数据库中】
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/30 10:58
*
*/
@PostMapping(value = "findAllSysUser")
@ApiOperation(value = "查询所有用户【在master数据库中】",notes = "查询所有用户【在master数据库中】")
@ApiResponses({
@ApiResponse(code = 0, message = "ok", response= Result.class),
})
public Result findAllSysUser() {
List result = testService.findAllSysUser();
return Result.success(result);
}
/**
* @Description: 查询所有的订单【在my_demo_02数据库中】
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/30 10:58
*
* 以下面数据为例:先添加下面为例子的数据源(调用DataSourceController中的add方法,可以在swagger中做,这里就不多说了)
* poolName:my_demo_02
* type:mysql
* driverClassName:com.mysql.cj.jdbc.Driver
* url:jdbc:mysql://127.0.0.1:3306/my_demo_02?characterEncoding=utf8&useSSL=false&autoReconnect=true&allowPublicKeyRetrieval=true&serverTimezone=GMT%2B8
* username:root
* password:root
*/
@PostMapping(value = "findAllFsOrder")
@ApiOperation(value = "查询所有订单【在my_demo_02数据库中】",notes = "查询所有订单【在my_demo_02数据库中】")
@ApiResponses({
@ApiResponse(code = 0, message = "ok", response= Result.class),
})
public Result findAllFsOrder() {
List result = testService.findAllFsOrder();
return Result.success(result);
}
}
16.TestService.java
package com.example.service;
import com.example.entity.FsOrder;
import com.example.entity.SysUser;
import java.util.List;
/**
* 类名称:
*
* @author 李庆伟
* @date 2023年10月30日 11:02
*/
public interface TestService {
//查询所有的用户 【在master数据库中】
List findAllSysUser();
//查询所有的订单【在my_demo_02数据库中】
List findAllFsOrder();
}
17.TestServiceImpl.java
package com.example.service.impl;
import com.baomidou.dynamic.datasource.annotation.DSTransactional;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.example.entity.FsOrder;
import com.example.entity.SysUser;
import com.example.mapper.FsOrderMapper;
import com.example.mapper.SysUserMapper;
import com.example.service.TestService;
import com.example.utils.DbOprUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.List;
/**
* 类名称:
*
* @author 李庆伟
* @date 2023年10月30日 11:02
*/
@Service
public class TestServiceImpl implements TestService {
@Autowired
private DbOprUtil dbOprUtil;
@Resource
private SysUserMapper sysUserMapper;
@Resource
private FsOrderMapper fsOrderMapper;
/**
* @Description: 查询所有的用户 【在master数据库中】
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/30 11:04
*/
@Override
public List findAllSysUser() {
//切换为master数据源,master为DbDataSourceDTO中的poolName(连接池名称:自定义不能重)
dbOprUtil.changeByDataSourceByName("master");
return sysUserMapper.selectList(new QueryWrapper());
}
/**
* @Description: 查询所有的订单【在my_demo_02数据库中】
* @param:
* @return: {@link }
* @throws:
* @author:李庆伟
* @date: 2023/10/30 11:04
*/
@Override
public List findAllFsOrder() {
//切换为my_demo_02数据源,my_demo_02为DbDataSourceDTO中的poolName(连接池名称:自定义不能重)
dbOprUtil.changeByDataSourceByName("my_demo_02");
return fsOrderMapper.selectList(new QueryWrapper());
}
//@DSTransactional//多数据源事务注解
//public void save() {
// dbOprUtil.changeByDataSourceByName("master");
// //insert master对应库数据
// //业务就省略了
// dbOprUtil.changeByDataSourceByName("my_demo_02");
// //insert my_demo_02对应库数据
// //业务就省略了
//}
}
18.FsOrderMapper.java
package com.example.entity;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
/**
* 类名称:订单
*
* @author 李庆伟
* @date 2023年10月27日 15:26
*/
@Data
@TableName
public class FsOrder {
@TableId
private String id;
private String orderNum;//订单号
private String address;//订单地址
}
19.SysUser.java
package com.example.entity;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
/**
* 类名称:用户
*
* @author 李庆伟
* @date 2023年10月27日 15:26
*/
@Data
@TableName
public class SysUser {
@TableId
private String id;
private String userName;//用户名
private String nickName;//昵称
private Integer age;//年龄
}
20.测试看效果:http://localhost:9000/doc.html
动态数据源添加
数据源查询
不同数据源下的表数据查询
记录一点点。。。。。。。。。。。。。。。
你可能感兴趣的:(Java,spring,boot,spring,mybatis,java)
基于web在线餐饮网站的设计与实现——蛋糕甜品店铺(HTML+CSS+JavaScript)
html网页制作
网页设计 前端 javascript html dreamweaver网页设计 web网页设计期末课程大作业
静态网站的编写主要是用HTMLDIV+CSSJS等来完成页面的排版设计,常用的网页设计软件有Dreamweaver、EditPlus、HBuilderX、VScode、Webstorm、Animate等等,用的最多的还是DW,当然不同软件写出的前端Html5代码都是一致的,本网页适合修改成为各种类型的产品展示网页,比如美食、旅游、摄影、电影、音乐等等多种主题,希望对大家有所帮助。精彩专栏推荐❤
如何在简历中巧妙展现你的兴趣爱好
贵州数擎科技有限公司
面试 跳槽
大家好!我是[数擎AI],一位热爱探索新技术的前端开发者,在这里分享前端和Web3D、AI技术的干货与实战经验。如果你对技术有热情,欢迎关注我的文章,我们一起成长、进步!开发领域:前端开发|AI应用|Web3D|元宇宙技术栈:JavaScript、React、ThreeJs、WebGL、Go经验经验:6年+前端开发经验,专注于图形渲染和AI技术开源项目:智简未来、晓智元宇宙、数字孪生引擎在简历中展
【股票数据API接口46】如何获取股票指历史分时BOLL数据之Python、Java等多种主流语言实例代码演示通过股票数据接口获取数据
Athena二哈
python java 开发语言 股票数据接口 api
如今,量化分析在股市领域风靡一时,其核心要素在于数据,获取股票数据,是踏上量化分析之路的第一步。你可以选择亲手编写爬虫来抓取,但更便捷的方式,莫过于利用专业的股票数据API接口。自编爬虫虽零成本,却伴随着时间与精力的巨大消耗,且常因目标页面变动而失效。大家可以依据自己的实际情况来决定数据获取方式。接下来,我将分享200多个实测可用且免费的专业股票数据接口,并通过Python、JavaScript(
【股票数据API接口45】如何获取股票指历史分时MACD数据之Python、Java等多种主流语言实例代码演示通过股票数据接口获取数据
Athena二哈
python java 开发语言 api 股票数据接口
如今,量化分析在股市领域风靡一时,其核心要素在于数据,获取股票数据,是踏上量化分析之路的第一步。你可以选择亲手编写爬虫来抓取,但更便捷的方式,莫过于利用专业的股票数据API接口。自编爬虫虽零成本,却伴随着时间与精力的巨大消耗,且常因目标页面变动而失效。大家可以依据自己的实际情况来决定数据获取方式。接下来,我将分享200多个实测可用且免费的专业股票数据接口,并通过Python、JavaScript(
使用 Three.js 转换 GLSL 粒子效果着色器
贵州数擎科技有限公司
javascript 着色器 开发语言
大家好!我是[数擎AI],一位热爱探索新技术的前端开发者,在这里分享前端和Web3D、AI技术的干货与实战经验。如果你对技术有热情,欢迎关注我的文章,我们一起成长、进步!开发领域:前端开发|AI应用|Web3D|元宇宙技术栈:JavaScript、React、ThreeJs、WebGL、Go经验经验:6年+前端开发经验,专注于图形渲染和AI技术开源项目:AI简历、元宇宙、数字孪生在这篇博客中,我们
SpringBoot - Cookie & Session 用户登录及登录状态保持功能实现
Loop Lee
java spring boot
会话技术功能:提供用户登陆成功后的登陆标记(一次登录,一段时间都登录)会话定义:包含一次或多次请求和响应的访问操作建立会话:用户打开浏览器访问Web服务器资源时建立会话结束会话:一方断开连接时结束会话会话跟踪定义:一种维护浏览器状态的方法功能:服务器通过会话跟踪来识别多次请求是否来自于同一浏览器同一次会话的多次请求间共享数据会话跟踪方案客户端会话跟踪技术:Cookie服务端会话跟踪技术:Sessi
为什么面试狂问Redis,阿里面试官把我问到哑口无言…
2501_90433130
面试 redis 职场和发展
Redis我们在工作中经常会用到,但是为什么要用、redis的一些场景和实战问题,90%以上的人都不是很懂。曾经自己去面试阿里,就被Redis问题问到哑口无言…事后我专门去恶补了Redis,现在算是比较精通了。作为目前主流的NoSQL技术,redis在Java互联网中得到了非常广泛的使用,个时代码代码的秃头人员,对Redis肯定是不陌生的,如果连Redis都没用过,还真不好意思出去面试,指不定被面
项目经验之LZO压缩?思维导图 代码示例(java 架构)
用心去追梦
java 架构 开发语言
LZO(LightweightZip/Unzip)是一种高效的压缩算法,它以快速解压缩著称,适用于需要频繁读取和处理的数据。在Hadoop生态系统中,使用LZO压缩可以显著减少存储空间,并且由于其快速的解压速度,对于大规模数据处理任务来说是非常有利的。以下是关于LZO压缩的项目经验总结、思维导图描述以及Java代码示例。项目经验之LZO压缩LZO的优势快速解压:LZO算法设计时优先考虑了解压速度,
面试之《前端开发者如何优化页面的加载时间?》
只会写Bug的程序员
面试 面试 前端
前端开发者可以从多个方面入手优化页面的加载时间,以下是一些常见且有效的方法:优化资源加载压缩资源文件:对HTML、CSS、JavaScript文件进行压缩,去除不必要的空格、注释等,减小文件体积,加快下载速度。例如使用uglify-js压缩JavaScript文件,cssnano压缩CSS文件。优化图片:对图片进行压缩处理,降低图片的分辨率、色彩深度或采用更高效的图片格式(如WebP)。同时,根据
【SpringCloud】Gateway
m0_74825526
面试 学习路线 阿里巴巴 spring cloud gateway java
目录一、网关路由1.1.认识网关1.2.快速入门?1.2.1.引入依赖1.2.2.配置路由二、网关登录校验2.1.Gateway工作原理?2.2.自定义过滤器2.3.登录校验2.4.微服务获取用户2.4.1.保存用户信息到请求头2.4.2.拦截器获取用户??2.5.OpenFeign传递用户三、配置管理3.1.配置共享?3.2.拉取配置共享3.2.1.引入依赖3.2.2.创建bootstrap.y
计算机复试面试题总结
m0_67400972
面试 学习路线 阿里巴巴 android 前端 后端
时隔两年,重新完善一下以前写的东西:更新!!!!1.c++,408,设计模式,编程技巧,开源框架(适合cpp后端开发)2.数据结构与算法面试题3.c++与STL面试题4.计算机网络面试题面试问题之编程语言1。C++的特点是什么?封装,继承,多态。支持面向对象和面向过程的开发。2.C++的异常处理机制?抛出异常和捕捉异常进行处理。(实际开发)3.c和c++,java的区别c是纯过程,c++是对象加过
计算机毕业设计 ——jspssm507Springboot 的论坛管理系统
程序媛9688
课程设计
作者:程序媛9688开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等。文末获取源码+数据库感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人计算机毕业设计——jspssm507Springboot的论坛管理系统JSPSSM507SpringBoot论坛管理系统功
Hutool - Script:脚本执行封装,以 JavaScript 为例
五行星辰
业务系统应用技术 javascript 开发语言 java 后端
一、简介在Java开发中,有时需要动态执行脚本代码,比如JavaScript脚本,来实现一些灵活的业务逻辑,如动态规则计算、数据处理等。Java本身提供了javax.script包来支持脚本执行,但使用起来较为繁琐。Hutool-Script模块对Java的脚本执行功能进行了封装,提供了更简洁易用的API,让开发者可以方便地执行各种脚本,这里主要介绍JavaScript脚本的执行。二、引入依赖如果
springboot习题
苍曦
java 开发语言
第1章一、填空题1.Pivotal团队在原有Spring框架的基础上开发了全新的SpringBoot框架。2.SpringBoot框架在开发过程中大量使用约定优先配置的思想来摆脱框架中各种复杂的手动配置。3.SpringBoot2.1.3版本要求Java8及以上版本的支持。4.SpringBoot2.1.3版本框架官方声明支持的第三方项目构建工具包括有Maven(3.3+)和Gradle(4.4+
Java 9模块与Maven的深度结合
t0_54program
java maven python 个人开发
在Java9引入模块化之后,如何将模块化与Maven项目结合成为了许多开发者关注的焦点。本文将通过一个简单的示例,展示如何在Maven项目中开发Java9模块,并使用非模块化的外部库(如Jsoup)。1.Maven项目配置首先,我们需要创建一个Maven项目,并在pom.xml中配置相关的依赖和插件。以下是完整的pom.xml文件内容:4.0.0com.logicbig.examplejava9-
计算机毕业设计 ——jspssm508Springboot 的旅游管理
奔强的程序
课程设计 旅游
博主小档案:花花,一名来自世界500强的资深程序猿,毕业于国内知名985高校。技术专长:花花在深度学习任务中展现出卓越的能力,包括但不限于java、python等技术。近年来,花花更是将触角延伸至AI领域,对于机器学习、自然语言处理、智能推荐等前沿技术都有独到的见解和实践经验。服务内容:1、提供科研入门辅导(主要是代码方面)2、代码部署3、定制化需求解决等4、期末考试复习计算机毕业设计——jsps
计算机毕业设计 ——jspssm510springboot 的人职匹配推荐系统
程序媛9688
课程设计
作者:程序媛9688开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等。文末获取源码+数据库感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人计算机毕业设计——jspssm510springboot的人职匹配推荐系统人职匹配推荐系统技术说明本毕业设计项目“jsps
计算机毕业设计 ——jspssm513Springboot 的小区物业管理系统
程序媛9688
课程设计
作者:程序媛9688开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等。文末获取源码+数据库感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人计算机毕业设计——jspssm513Springboot的小区物业管理系统技术说明:小区物业管理系统(基于JSP+SSM+
计算机毕业设计 ——jspssm514Springboot 的校园新闻网站
程序媛9688
课程设计
作者:程序媛9688开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等。文末获取源码+数据库感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人计算机毕业设计——jspssm514Springboot的校园新闻网站技术说明:JSPSSM514Springboot校园
计算机毕业设计 ——jspssm504springboot 职称评审管理系统
程序媛9688
课程设计
作者:程序媛9688开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等。文末获取源码+数据库感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人计算机毕业设计——jspssm504springboot职称评审管理系统JSPSSM504SpringBoot职称评审管理
基于Spring Boot的驾校预约管理系统
超级无敌暴龙战士塔塔开
Java课设与毕设资源 spring boot java mybatis
文章目录项目介绍主要功能截图:登录首页学员管理教练管理车辆管理关系管理车辆维修模块个人中心部分代码展示设计总结项目获取方式作者主页:Java韩立简介:Java领域优质创作者、简历模板、学习资料、面试题库【关注我,都给你】文末获取源码联系项目介绍基于SpringBoot的驾校预约管理系统(可帮忙远程调试),java项目。eclipse和idea都能打开运行。推荐环境配置:eclipse/ideajd
w231乡政府管理系统设计与实现
栗子计算机毕业设计
java spring boot 后端 java spring tomcat
作者简介:多年一线开发工作经验,原创团队,分享技术代码帮助学生学习,独立完成自己的网站项目。代码可以查看文章末尾⬇️联系方式获取,记得注明来意哦~赠送计算机毕业设计600个选题excel文件,帮助大学选题。赠送开题报告模板,帮助书写开题报告。作者完整代码目录供你选择:《Springboot网站项目》400套《ssm网站项目》800套《小程序项目》300套《App项目》500套《Python网站项目
玩转Java微服务:架构设计与实战进阶终极指南
Light60
低代码 实战篇 技能篇 Java微服务 Spring Cloud 分布式架构 容器化部署 服务治理
摘要本文深入解析Java微服务核心原理与落地实践,涵盖SpringCloudAlibaba生态体系实战技巧。通过全链路代码示例演示服务注册发现、分布式配置、熔断限流等关键模块实现,结合电商案例阐述DDD领域驱动设计在微服务拆分的应用。提供可落地的性能优化方案与云原生演进路线,助您构建高可用、易扩展的现代化分布式系统。关键词:Java微服务、SpringCloud、分布式架构、容器化部署、服务治理一
计算机毕业设计Java-ssm餐厅线上点菜系统源码+系统+数据库+lw文档
双双科技
java 数据库 开发语言
计算机毕业设计Java-ssm餐厅线上点菜系统源码+系统+数据库+lw文档计算机毕业设计Java-ssm餐厅线上点菜系统源码+系统+数据库+lw文档本源码技术栈:项目架构:B/S架构开发语言:Java语言开发软件:ideaeclipse前端技术:Layui、HTML、CSS、JS、JQuery等技术后端技术:JAVA运行环境:Win10、JDK1.8数据库:MySQL5.7/8.0源码地址:htt
使用Mapbox GL加载GeoJSON数据并创建热力图
技术驱动者
js
使用MapboxGL加载GeoJSON数据并创建热力图在Web地图应用程序中,将地理数据可视化是一种常见的需求。MapboxGL是一个强大的JavaScript库,可以帮助我们在浏览器中创建交互式地图。本文将介绍如何使用MapboxGL加载GeoJSON数据,并将其转化为热力图。热力图是一种通过颜色来表示密度分布的可视化方式。在地理数据可视化中,热力图常用于显示点数据的密集程度,以便更直观地理解数
基于Linux环境下Jenkins自动化部署【springBoot+Maven+SVN】详细教程(一)
xiaoming行走的力量
项目管理 项目自动化部署 jenkins maven svn spring boot
1.引言在实际项目管理工作中,项目经理除了具有基本的项目管理知识以外,应当熟练使用一些项目管理工具来提高项目管理效率。项目管理工具除了甘特图、PERT、WBS、日历、思维导图、时间线、状态表等基本应用性管理工具,也熟悉一些关于代码整合及发布的常用工具。在软件公司中是熟悉和熟练使用关于软件开发整合部署的一些常用工具(NAVCAT、SSH、FinalShell、JENKINS等),不仅可以提高项目管理
MyBatis Generator(MBG)
斯旺森swanson
【目录】1什么是MyBatisGenerator(MBG)2搭建MBG项目4使用自动生成的文件操作数据库1什么是MyBatisGenerator(MBG)简单来说,MyBatisGenerator是一个Mybatis和ibatis的代码生成器,它可以根据数据库表自动生成Bean对象、Java接口及SqlMapper.xml配置文件。2搭建MBG项目在项目开始之前准备好数据库。数据库database
java集合框架List常见基础面试题
步归猿某人
java list 数据结构 面试
简介:java集合框架List常见基础面试题考点:list的基础知识掌握情况,对应实现的区别、线程安全、使用场景。问:Vector和ArrayList、LinkedList联系和区别?分别的使用场景?答:(1)线程安全:ArrayList:底层是数组实现,线程不安全,查询和修改快,但是增加和删除慢。LinkedList:底层是双向链表,线程不安全,查询和修改慢,新增和删除快。Vector:底层是数
oracle+mybatis批量插入数据
崔lc
java mybatis java spring boot spring 后端
使用oracle+mybatis进行批量添加数据,并且id是传参并不是自增。表user_info有以下两个字段:u_idvarchar,u_namevarchardao层:packagetest.dao;importjava.util.List;importorg.apache.ibatis.annotations.Param;importtest.entity.UserInfo;importtk
HJ48 从单向链表中删除指定值的节点
张紫娃
算法题 链表 数据结构 java
牛客华为机试题库【题号HJ开头】(重点看)牛客在线编程算法篇【题号NC开头】剑指offer【题号JZ开头】力扣1)原题链接2)已有题解3)代码packagelinklist;importjava.io.BufferedReader;importjava.io.IOException;importjava.io.InputStreamReader;importjava.util.Arrays;/**
关于旗正规则引擎规则中的上传和下载问题
何必如此
文件下载 压缩 jsp 文件上传
文件的上传下载都是数据流的输入输出,大致流程都是一样的。
一、文件打包下载
1.文件写入压缩包
string mainPath="D:\upload\"; 下载路径
string tmpfileName=jar.zip; &n
【Spark九十九】Spark Streaming的batch interval时间内的数据流转源码分析
bit1129
Stream
以如下代码为例(SocketInputDStream):
Spark Streaming从Socket读取数据的代码是在SocketReceiver的receive方法中,撇开异常情况不谈(Receiver有重连机制,restart方法,默认情况下在Receiver挂了之后,间隔两秒钟重新建立Socket连接),读取到的数据通过调用store(textRead)方法进行存储。数据
spark master web ui 端口8080被占用解决方法
daizj
8080 端口占用 spark master web ui
spark master web ui 默认端口为8080,当系统有其它程序也在使用该接口时,启动master时也不会报错,spark自己会改用其它端口,自动端口号加1,但为了可以控制到指定的端口,我们可以自行设置,修改方法:
1、cd SPARK_HOME/sbin
2、vi start-master.sh
3、定位到下面部分
oracle_执行计划_谓词信息和数据获取
周凡杨
oracle 执行计划
oracle_执行计划_谓词信息和数据获取(上)
一:简要说明
在查看执行计划的信息中,经常会看到两个谓词filter和access,它们的区别是什么,理解了这两个词对我们解读Oracle的执行计划信息会有所帮助。
简单说,执行计划如果显示是access,就表示这个谓词条件的值将会影响数据的访问路径(表还是索引),而filter表示谓词条件的值并不会影响数据访问路径,只起到
spring中datasource配置
g21121
dataSource
datasource配置有很多种,我介绍的一种是采用c3p0的,它的百科地址是:
http://baike.baidu.com/view/920062.htm
<!-- spring加载资源文件 -->
<bean name="propertiesConfig"
class="org.springframework.b
web报表工具FineReport使用中遇到的常见报错及解决办法(三)
老A不折腾
finereport FAQ 报表软件
这里写点抛砖引玉,希望大家能把自己整理的问题及解决方法晾出来,Mark一下,利人利己。
出现问题先搜一下文档上有没有,再看看度娘有没有,再看看论坛有没有。有报错要看日志。下面简单罗列下常见的问题,大多文档上都有提到的。
1、repeated column width is largerthan paper width:
这个看这段话应该是很好理解的。比如做的模板页面宽度只能放
mysql 用户管理
墙头上一根草
linux mysql user
1.新建用户 //登录MYSQL@>mysql -u root -p@>密码//创建用户mysql> insert into mysql.user(Host,User,Password) values(‘localhost’,'jeecn’,password(‘jeecn’));//刷新系统权限表mysql>flush privileges;这样就创建了一个名为:
关于使用Spring导致c3p0数据库死锁问题
aijuans
spring Spring 入门 Spring 实例 Spring3 Spring 教程
这个问题我实在是为整个 springsource 的员工蒙羞
如果大家使用 spring 控制事务,使用 Open Session In View 模式,
com.mchange.v2.resourcepool.TimeoutException: A client timed out while waiting to acquire a resource from com.mchange.
百度词库联想
annan211
百度
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>RunJS</title&g
int数据与byte之间的相互转换实现代码
百合不是茶
位移 int转byte byte转int 基本数据类型的实现
在BMP文件和文件压缩时需要用到的int与byte转换,现将理解的贴出来;
主要是要理解;位移等概念 http://baihe747.iteye.com/blog/2078029
int转byte;
byte转int;
/**
* 字节转成int,int转成字节
* @author Administrator
*
简单模拟实现数据库连接池
bijian1013
java thread java多线程 简单模拟实现数据库连接池
简单模拟实现数据库连接池
实例1:
package com.bijian.thread;
public class DB {
//private static final int MAX_COUNT = 10;
private static final DB instance = new DB();
private int count = 0;
private i
一种基于Weblogic容器的鉴权设计
bijian1013
java weblogic
服务器对请求的鉴权可以在请求头中加Authorization之类的key,将用户名、密码保存到此key对应的value中,当然对于用户名、密码这种高机密的信息,应该对其进行加砂加密等,最简单的方法如下:
String vuser_id = "weblogic";
String vuse
【RPC框架Hessian二】Hessian 对象序列化和反序列化
bit1129
hessian
任何一个对象从一个JVM传输到另一个JVM,都要经过序列化为二进制数据(或者字符串等其他格式,比如JSON),然后在反序列化为Java对象,这最后都是通过二进制的数据在不同的JVM之间传输(一般是通过Socket和二进制的数据传输),本文定义一个比较符合工作中。
1. 定义三个POJO
Person类
package com.tom.hes
【Hadoop十四】Hadoop提供的脚本的功能
bit1129
hadoop
1. hadoop-daemon.sh
1.1 启动HDFS
./hadoop-daemon.sh start namenode
./hadoop-daemon.sh start datanode
通过这种逐步启动的方式,比start-all.sh方式少了一个SecondaryNameNode进程,这不影响Hadoop的使用,其实在 Hadoop2.0中,SecondaryNa
中国互联网走在“灰度”上
ronin47
管理 灰度
中国互联网走在“灰度”上(转)
文/孕峰
第一次听说灰度这个词,是任正非说新型管理者所需要的素质。第二次听说是来自马化腾。似乎其他人包括马云也用不同的语言说过类似的意思。
灰度这个词所包含的意义和视野是广远的。要理解这个词,可能同样要用“灰度”的心态。灰度的反面,是规规矩矩,清清楚楚,泾渭分明,严谨条理,是决不妥协,不转弯,认死理。黑白分明不是灰度,像彩虹那样
java-51-输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
bylijinnan
java
public class PrintMatrixClockwisely {
/**
* Q51.输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
例如:如果输入如下矩阵:
1 2 3 4
5 6 7 8
9
mongoDB 用户管理
开窍的石头
mongoDB用户管理
1:添加用户
第一次设置用户需要进入admin数据库下设置超级用户(use admin)
db.addUsr({user:'useName',pwd:'111111',roles:[readWrite,dbAdmin]});
第一个参数用户的名字
第二个参数
[游戏与生活]玩暗黑破坏神3的一些问题
comsci
生活
暗黑破坏神3是有史以来最让人激动的游戏。。。。但是有几个问题需要我们注意
玩这个游戏的时间,每天不要超过一个小时,且每次玩游戏最好在白天
结束游戏之后,最好在太阳下面来晒一下身上的暗黑气息,让自己恢复人的生气
&nb
java 二维数组如何存入数据库
cuiyadll
java
using System;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Xml;
using System.Xml.Serialization;
using System.IO;
namespace WindowsFormsApplication1
{
本地事务和全局事务Local Transaction and Global Transaction(JTA)
darrenzhu
java spring local global transaction
Configuring Spring and JTA without full Java EE
http://spring.io/blog/2011/08/15/configuring-spring-and-jta-without-full-java-ee/
Spring doc -Transaction Management
http://docs.spring.io/spri
Linux命令之alias - 设置命令的别名,让 Linux 命令更简练
dcj3sjt126com
linux alias
用途说明
设置命令的别名。在linux系统中如果命令太长又不符合用户的习惯,那么我们可以为它指定一个别名。虽然可以为命令建立“链接”解决长文件名的问 题,但对于带命令行参数的命令,链接就无能为力了。而指定别名则可以解决此类所有问题【1】。常用别名来简化ssh登录【见示例三】,使长命令变短,使常 用的长命令行变短,强制执行命令时询问等。
常用参数
格式:alias
格式:ali
yii2 restful web服务[格式响应]
dcj3sjt126com
PHP yii2
响应格式
当处理一个 RESTful API 请求时, 一个应用程序通常需要如下步骤 来处理响应格式:
确定可能影响响应格式的各种因素, 例如媒介类型, 语言, 版本, 等等。 这个过程也被称为 content negotiation。
资源对象转换为数组, 如在 Resources 部分中所描述的。 通过 [[yii\rest\Serializer]]
MongoDB索引调优(2)——[十]
eksliang
mongodb MongoDB索引优化
转载请出自出处:http://eksliang.iteye.com/blog/2178555 一、概述
上一篇文档中也说明了,MongoDB的索引几乎与关系型数据库的索引一模一样,优化关系型数据库的技巧通用适合MongoDB,所有这里只讲MongoDB需要注意的地方 二、索引内嵌文档
可以在嵌套文档的键上建立索引,方式与正常
当滑动到顶部和底部时,实现Item的分离效果的ListView
gundumw100
android
拉动ListView,Item之间的间距会变大,释放后恢复原样;
package cn.tangdada.tangbang.widget;
import android.annotation.TargetApi;
import android.content.Context;
import android.content.res.TypedArray;
import andr
程序员用HTML5制作的爱心树表白动画
ini
JavaScript jquery Web html5 css
体验效果:http://keleyi.com/keleyi/phtml/html5/31.htmHTML代码如下:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"><head><meta charset="UTF-8" >
<ti
预装windows 8 系统GPT模式的ThinkPad T440改装64位 windows 7旗舰版
kakajw
ThinkPad 预装 改装 windows 7 windows 8
该教程具有普遍参考性,特别适用于联想的机器,其他品牌机器的处理过程也大同小异。
该教程是个人多次尝试和总结的结果,实用性强,推荐给需要的人!
缘由
小弟最近入手笔记本ThinkPad T440,但是特别不能习惯笔记本出厂预装的Windows 8系统,而且厂商自作聪明地预装了一堆没用的应用软件,消耗不少的系统资源(本本的内存为4G,系统启动完成时,物理内存占用比
Nginx学习笔记
mcj8089
nginx
一、安装nginx 1、在nginx官方网站下载一个包,下载地址是:
http://nginx.org/download/nginx-1.4.2.tar.gz
2、WinSCP(ftp上传工
mongodb 聚合查询每天论坛链接点击次数
qiaolevip
每天进步一点点 学习永无止境 mongodb 纵观千象
/* 18 */
{
"_id" : ObjectId("5596414cbe4d73a327e50274"),
"msgType" : "text",
"sendTime" : ISODate("2015-07-03T08:01:16.000Z"
java术语(PO/POJO/VO/BO/DAO/DTO)
Luob.
DAO POJO DTO po VO BO
PO(persistant object) 持久对象
在o/r 映射的时候出现的概念,如果没有o/r映射,就没有这个概念存在了.通常对应数据模型(数据库),本身还有部分业务逻辑的处理.可以看成是与数据库中的表相映射的java对象.最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合.PO中应该不包含任何对数据库的操作.
VO(value object) 值对象
通
算法复杂度
Wuaner
Algorithm
Time Complexity & Big-O:
http://stackoverflow.com/questions/487258/plain-english-explanation-of-big-o
http://bigocheatsheet.com/
http://www.sitepoint.com/time-complexity-algorithms/