小小的日常维护,Magic-1.0.5 发布

本次更新如下:

1. 添加了对PosrgreSQL的分页支持。
2. 在使用ConditionBuilder时可以只查一条数据。
3. 对查询入参的处理方式换成了反射处理,这样可以保持原类型。
4. 去除了ConcurrentTaskSync的回调,因为意义不大,不如在runner里直接try catch

Magic是Magician旗下的一个工具包,支持并发处理、生产者与消费者模型、数据库操作等.

01 数据库操作

首先需要创建一个Spring的JdbcTemplate对象

@Resource
private JdbcTemplate jdbcTemplate;

单表查询

// 创建查询条件
ConditionBuilder conditionBuilder = ConditionBuilder.createCondition()
                .add("age = ?", "300")
                .add(" order by age desc", Condition.NOT_WHERE);

// 执行查询操作
List<DemoPO> demoPOS = MagicDBUtils.get(jdbcTemplate)
        .select("m_user_info", conditionBuilder, DemoPO.class);

单表插入

// 创建要插入的对象和值
DemoPO demoPO = DemoPO.builder()
                    .id(UUID.randomUUID().toString())
                    .age(18)
                    .content("哈哈哈")
                    .amount(new BigDecimal("10000"))
                    .length(new BigInteger("10000000000"))
                    .createTime(new Date())
                    .updateTime(new Date())
                    .build();

// 执行插入操作
MagicDBUtils.get(jdbcTemplate).insert("m_user_info", demoPO);

单表更新

// 创建修改条件
ConditionBuilder = conditionBuilder = ConditionBuilder.createCondition()
                .add("id = ? and age = ?", "00df4362-d7ad-48d2-8bcb-05cf859b7e64", 500);

// 需要修改的字段和对应的值
DemoPO demoPO = DemoPO.builder()
        .age(122)
        .content("嘿嘿嘿")
        .amount(new BigDecimal("100002.33"))
        .length(new BigInteger("100000000002"))
        .createTime(new Date())
        .updateTime(new Date())
        .build();

// 执行修改操作
MagicDBUtils.get(jdbcTemplate).update("m_user_info", demoPO, conditionBuilder);

单表删除

// 创建删除条件
ConditionBuilder = conditionBuilder = ConditionBuilder.createCondition()
                .add("id = ?", "00df4362-d7ad-48d2-8bcb-05cf859b7e64");
// 执行删除操作
MagicDBUtils.get(jdbcTemplate).delete("m_user_info", conditionBuilder);

自定义SQL查询

DemoPO demoPO = DemoPO.builder()
                .age(122)
                .build();

MagicDBUtils.get(jdbcTemplate).selectList("select * from m_user_info where age > {age}", demoPO, DemoPO.class);

自定义SQL分页

// 查询参数
PageParamModel pageParamModel = PageParamModel
                .getPageParamModel(1, 10)
                        .setParam(
                                DemoPO.builder()
                                    .age(10)
                                    .build()
                        );

// 执行查询操作
PageModel<DemoPO> pageModel = MagicDBUtils.get(jdbcTemplate).selectPage("select * from m_user_info where age > {age}", pageParamModel, DemoPO.class);

02 并发处理任务

MagicDataProcessing.getConcurrentTaskSync()
                .setTimeout(1000) // 超时时间
                .setTimeUnit(TimeUnit.MILLISECONDS) // 超时时间的单位
                .add(() -> { // 添加一个任务

                    // 在这里可以写上任务的业务逻辑

                })
                .add(() -> { // 添加一个任务

                    // 在这里可以写上任务的业务逻辑

                })
                .start();

03 并发处理List,Set等所有Collection类集合里的元素

// 假如有一个List需要并发处理里面的元素
List<String> dataList = new ArrayList<>();

// 只需要将他传入syncRunner方法即可,每个参数的具体含义可以参考文档
MagicDataProcessing.getConcurrentCollectionSync()
        .syncRunner(dataList, data -> {

            // 这里可以拿到List里的元素,进行处理
            System.out.println(data);
        
        }, 10, 1, TimeUnit.MINUTES);

// 也可以用syncGroupRunner方法,每个参数的具体含义可以参考文档
MagicDataProcessing.getConcurrentCollectionSync()
        .syncGroupRunner(dataList, data -> {

            // 这里是每一组List
            for(String item : data){
                // 这里可以拿到List里的元素,进行处理
                System.out.println(data);
            }
        
        }, 10, 1, TimeUnit.MINUTES);

04 生产者与消费者

// 创建一组生产者与消费者,支持多对多
MagicDataProcessing.getProducerAndConsumerManager()
        .addProducer(new MagicianProducer() { // 添加一个生产者(可以添加多个)
            
            @Override
            public void producer() {
                // 查询这张表里符合条件的数据
                List<Object> dataList = selectList();
        
                // 然后将他推送给消费者
                this.publish(dataList);
            }
            
        }).addConsumer(new MagicianConsumer() { // 添加一个消费者(可以添加多个)
            
            @Override
            public void doRunner(Object data) {
                // 处理生产者发来的数据
                System.out.println(data);
            }
            
        }).start();

因同名软件太多,选择关联软件时无法分辨,所以选了自己的另一个项目。

本项目的链接如下:

github: https://github.com/JMagician/Magic

gitee: https://gitee.com/jmagician/Magic

优秀的个人博客,低调大师

微信关注我们

原文链接:https://www.oschina.net/news/382507

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
优质分享Android(本站安卓app)

优质分享Android(本站安卓app)

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Mario,低调大师唯一一个Java游戏作品

Mario,低调大师唯一一个Java游戏作品

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的、适应高吞吐量的数据库方案。

Sublime Text 一个代码编辑器

Sublime Text 一个代码编辑器

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。