zoukankan      html  css  js  c++  java
  • spring boot + druid + 封装JdbcTemplate

    本源码内容如下:

    • spring boot项目
    • 用的druid连接池
    • druid监控页面配置
    • 数据操作用spring jdbctemplate
    • 进一步封装spring jdbctemplate支持用对象进行增删改查
    • 封装jdbctemplate的是单独一个项目,可以打包到任务项目中使用

    详细介绍请查看 http://cxytiandi.com/blog/detail/3881

    封装部分代码

    public <T> T getByParams(Class<T> entityClass, String[] params, Object... values) {
        String[] fieldNames = BeanUtils.getFieldNames(entityClass, "");
        return doGetByParams(entityClass, fieldNames, params, values);
    }
    
    public <T> T getByParams(Class<T> entityClass, String[] fieldNames, String[] params, Object... values) {
        return doGetByParams(entityClass, fieldNames, params, values);
    }
    
    private <T> T doGetByParams(Class<T> entityClass, String[] fieldNames, String[] params, Object... values) {
        StringBuilder sql = getParamSql(entityClass, fieldNames, params, values);
        return get(entityClass, sql.toString(), values);
    }
    
    public <T> List<T> findByParams(Class<T> entityClass, String[] params, Object... values) {
        String[] fieldNames = BeanUtils.getFieldNames(entityClass, "");
        return doFindByParams(entityClass, fieldNames, params, values);
    }
    

    使用部分代码

    @Transactional
    public void save() {
         Users u = new Users();
         u.setMobile("13112021223");
         //id自增不需要插入所以排除
         cxytiandiJdbcTemplate.save(Users.class, u, "id");
    }
    
    @Transactional
    public void updateUser(Users user) {
        //根据ID修改用户信息,只修改mobile字段
        cxytiandiJdbcTemplate.updateByContainsFields(Users.class, user, "id", "mobile");
    }
    
    @Transactional
    public void deleteUser() {
         cxytiandiJdbcTemplate.deleteByParams(Users.class, new String[]{"id", "mobile"}, 2, "13858521245");
    }
    
    public List<Users> findByParams() {
        return cxytiandiJdbcTemplate.findByParams(Users.class, new String[]{"mobile"}, "13985854512");
    }
    
    public long count() {
        return cxytiandiJdbcTemplate.count(Users.class);
    }
    
    public long count(String mobile) {
        return cxytiandiJdbcTemplate.count(Users.class, "mobile", mobile);
    }
    
    public List<Users> queryAllUsers() {
        return cxytiandiJdbcTemplate.list(Users.class);
    }
    
    public List<Users> getUsersByPage(int page, int limit) {
        PageQueryParam param = new PageQueryParam(page, limit);
        return cxytiandiJdbcTemplate.listForPage(Users.class, param.getStart(), param.getLimit());
    }
  • 相关阅读:
    prometheus 文档
    go
    nginx
    python使用xlrd读取合并单元格
    python使用xlrd模块读取Excel
    创建Excel文件:ModuleNotFoundError: No module named 'openpyxl'
    openpyxl模块安装时报错: You are using pip version 19.2.3, however version 20.0.2 is available. You should consider upgrading via the 'python -m pip install --upgrade pip' command.
    Python定义字典函数报错TypeError: takes 0 positional arguments but 1 was given
    Mysql--information_scherma(虚拟库)
    day07--MySQL索引
  • 原文地址:https://www.cnblogs.com/a8457013/p/7825111.html
Copyright © 2011-2022 走看看