04-JDBC模板工具
1. JDBC工具类
- 前面讲过数据库连接池帮传统JDBC解决了连接的创建和管理方面的问题,有兴趣的可以查看连接池技术这篇文章。然而JDBC编程还存在可以继续加工封装的部分,来分析一段JDBC查询数据代码:
// 定义sql语句
String sql = "select pk_id, username, password, sex, birthday from user";// 获取数据库操作对象
Statement statement = connection.createStatement();// 执行sql语句并获得结果
ResultSet resultSet = statement.executeQuery(sql);// 遍历结果集
while (resultSet.next())
{// 提取数据Integer id = resultSet.getInt("pk_id");String userName = resultSet.getString("username");String passWord = resultSet.getString("password");String sex = resultSet.getString("sex");Date birthday = resultSet.getDate("birthday");// 组装实体UserDO user = new UserDO();user.setId(id);user.setUserName(userName);user.setPassWord(passWord);user.setSex(sex);user.setBirthday(birthday);// 打印实体System.out.println("user = " + user);
}
针对上述代码可以从一个宏观的角度来分析,操作数据库就是为了拿到数据库的字段数据把它转成我们程序中所要用到的实体对象。然而针对不同的SQL每次获取的字段数据不同,需要转成实体对象也不同,这就面临着如何对查询到的字段数据进行解析,如何将解析的数据组装成对应的实体对象。获取什么样的字段数据,组装成什么样的实体对象这个只有程序员知道,怎么组装这就需要对类进行解剖,需要用到反射的技术。
- 为了简化这种查询数据组装实体的操作,在JDBC的基础上出现了很多工具类,比如Apache的DBUtils、Spring的JdbcTemplate等。
2. 创建数据库环境
基于MySQL数据库建立用户表方便对JDBC工具类的操作使用。
# 创建用户表
CREATE TABLE IF NOT EXISTS `user`
(`pk_id` INT AUTO_INCREMENT,`username` VARCHAR(20) NOT NULL,`password` VARCHAR(20) NOT NULL,`sex` CHAR(1),`birthday` DATETIME,CONSTRAINT `pk_user` PRIMARY KEY(`pk_id`)
);# 添加用户数据
INSERT INTO `user`(`username`, `password`, `sex`, `birthday`)
VALUES ('刘备', '01234', '男', '2020-11-15 10:34:12'), ('关羽', '12345', '男', '2020-11-24 10:34:12'),('张飞', '23456', '男', '2020-12-08 10:34:12'),('赵云', '34567', '男', '2020-12-18 10:34:12'),('大乔', '45678', '女', '2020-11-01 10:34:12'),('小乔', '56789', '女', '2020-12-01 10:34:12');
3. DBUtils工具类
DBUtils是Apache组织提供的一个对JDBC进行简单封装的开源工具类库,使用它能够简化JDBC应用程序的开发,同时也不会影响性能。
在DBUtils工具类中有两个比较核心的东西,一个是QueryRunner,一个是ResultSetHandler。前者是我们发送SQL的关键,后者就是将字段数据封装成实体对象的关键,而且ResultSetHandler有很多实现,不同的实现对应着不同的封装策略。
3.1 添加依赖
- DBUtils是Apache组织提供的,要想使用必须导入相应的jar包,这里采用maven构建方式。
(1)连接数据库必须的mysql驱动依赖。
(2)连接池技术用HikariCP技术。
(3)JDBC工具类采用Apache的DBUtils。
(4)Junit用来进行单元测试。
<!-- 依赖管理 -->
<dependencies><!-- mysql --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.49</version></dependency><!-- HikariCP --><dependency><groupId>com.zaxxer</groupId><artifactId>HikariCP</artifactId><version>3.4.5</version></dependency><!-- commons-dbutils --><dependency><groupId>commons-dbutils</groupId><artifactId>commons-dbutils</artifactId><version>1.7</version></dependency><!-- junit --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.13</version><scope>test</scope></dependency>
</dependencies>
3.2 核心对象
- QueryRunner是DBUtils的核心,如何创建一个QueryRunner对象呢?它需要使用到数据源对象,也就是所谓的连接池对象。
QueryRunner queryRunner = new QueryRunner(datasource);
@Test
public void dbutilsTest()
{// 创建数据源HikariDataSource dataSource = new HikariDataSource();dataSource.setDriverClassName("com.mysql.jdbc.Driver");dataSource.setJdbcUrl("jdbc:mysql://127.0.0.1:3306/zw_test");dataSource.setUsername("root");dataSource.setPassword("root");// 创建QueryRunner对象QueryRunner queryRunner = new QueryRunner(dataSource);// 打印对象System.out.println("queryRunner = " + queryRunner);// 关闭资源datasource.close();
}
- 拿到了QueryRunner核心对象就可以发SQL了,它有两个核心的方法
(1)queryRunner.update(String sql):执行增删改的SQL语句,支持占位符。
(2)queryRunner.query(String sql):执行查询的SQL语句,支持占位符。
@Test
public void test01() throws SQLException
{// 定义SQL语句String sql = "insert into user(pk_id, username, password, sex, birthday) values(null, ?, ?, ?, ?)";// 增删改:添加数据int count = queryRunner.update(sql, "马超", "654321", "男", new Date());// 打印结果System.out.println("count = " + count);
}
- 执行结果
- 添加数据前
- 添加数据后
3.3 封装策略
- QueryRunner对象的update方法是用来执行增删改等写操作,而QueryRunner对象的query方法用来执行查询等读操作,此时就可以指定查询到的字段数据要封装成什么样的数据结构,这个就是ResultSetHandler来完成的。
- ResultSetHandler是一个接口,它有很多的实现,不同的实现就是不同的封装策略,一般使用到如下策略:
3.3.1 ArrayHandler策略
- 它是将结果集中的第一条记录封装到一个数组中,显然是针对一条记录的。
- 假如查询到一条记录为:
- 经过ArrayHandler封装后是一个数组:
/*** ArrayHandler* @throws SQLException*/
@Test
public void test02() throws SQLException
{String sql = "select * from user where pk_id = ?";Object[] userObject = queryRunner.query(sql, new ArrayHandler(), 1);for (Object object : userObject){System.out.println("object = " + object);}
}
3.3.2 ArrayListHandler策略
- 它是将结果集中每一条记录封装到数组中后组成一个List集合,显然是针对多条记录,ArrayHandler的升级版。
- 假如查询到多条记录如下:
- 进过ArrayListHandler封装后是一个List,List中每一个元素是一个数组:
/*** ArrayListHandler* @throws SQLException*/
@Test
public void test03() throws SQLException
{String sql = "select * from user";List<Object[]> userList = queryRunner.query(sql, new ArrayListHandler());for (Object[] userArray : userList){for (Object object : userArray){System.out.println("object = " + object);}System.out.println("-----------------------------------");}
}
3.3.3 BeanHandler策略
- 它是将一条记录封装到我们自己定义的JavaBean中,针对单个记录,应该是用的比较多的一种。
需要注意的是这个JavaBean中的字段必须提供Getter和Setter方法,而且查询到的字段要和属性名对应。
如果字段与属性不对应可以采用取别名的方式。
- 用户实体类
package com.intest.template.domain;import java.io.Serializable;
import java.text.SimpleDateFormat;
import java.util.Date;/*** @ClassName: UserDO* @Description: 用户实体类* @Author: ZhouWei* @Date: 2020-11-22 - 17:11*/
public class UserDO implements Serializable
{/*** 用户编号*/private Integer id;/*** 用户账号*/private String userName;/*** 用户密码*/private String passWord;/*** 用户性别*/private String sex;/*** 用户生日*/private Date birthday;/*** Getter和Setter方法*/public Integer getId(){return id;}public void setId(Integer id){this.id = id;}public String getUserName(){return userName;}public void setUserName(String userName){this.userName = userName;}public String getPassWord(){return passWord;}public void setPassWord(String passWord){this.passWord = passWord;}public String getSex(){return sex;}public void setSex(String sex){this.sex = sex;}public Date getBirthday(){return birthday;}public void setBirthday(Date birthday){this.birthday = birthday;}/*** toString方法*/@Overridepublic String toString(){return "UserDO{" +"id=" + id +", userName='" + userName + '\'' +", passWord='" + passWord + '\'' +", sex='" + sex + '\'' +", birthday=" + new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(birthday) +'}';}
}
- 查询示例
/*** BeanHandler* @throws SQLException*/
@Test
public void test04() throws SQLException
{String sql = "select pk_id as id, username as userName, password as passWord, sex as sex, birthday as birthday from user where pk_id = ?";UserDO user = queryRunner.query(sql, new BeanHandler<UserDO>(UserDO.class), 1);System.out.println("user = " + user);
}
- 查询结果
3.3.4 BeanListHandler策略
-
它是将多条记录封装到自己定义的JavaBean中然后组成一个List,针对多个记录,也是用的比较多的一种,类似BeanHandler。
-
查询示例
/*** BeanListHandler* @throws SQLException*/
@Test
public void test05() throws SQLException
{String sql = "select pk_id as id, username as userName, password as passWord, sex as sex, birthday as birthday from user";List<UserDO> users = queryRunner.query(sql, new BeanListHandler<UserDO>(UserDO.class));for (UserDO user : users){System.out.println("user = " + user);}
}
- 查询结果
3.3.5 ColumnListHandler策略
- 它是将多条记录的某个字段封装到一个List中,针对多条记录的一个字段。
- 查询示例
/*** ColumnListHandler* @throws SQLException*/
@Test
public void test06() throws SQLException
{String sql = "select * from user";List<String> userNames = queryRunner.query(sql, new ColumnListHandler<String>("username"));for (String userName : userNames){System.out.println("userName = " + userName);}
}
- 查询结果
3.3.6 KeyedHandler策略
- 这个策略很少用到,它有两层Map结构,类似于Map<Integer, Map<String, String>>这种。外层map的key一般指定为主键,外层map的value也是一个map,这个map就一条记录。内层map的key是字段名称,内层map的value就是字段对应的值。
- 假如查询到的结果如下:
- 封装后是一个Map嵌套:
- 查询示例
/*** KeyedHandler* @throws SQLException*/
@Test
public void test07() throws SQLException
{String sql = "select * from user";Map<Integer, Map<String, Object>> userMaps = queryRunner.query(sql, new KeyedHandler<Integer>("pk_id"));for (Map.Entry<Integer, Map<String, Object>> userMapEntry : userMaps.entrySet()){Integer key = userMapEntry.getKey();System.out.println("key = " + key);Map<String, Object> value = userMapEntry.getValue();for (Map.Entry<String, Object> userMap : value.entrySet()){String key1 = userMap.getKey();Object value1 = userMap.getValue();System.out.println("key1 = " + key1);System.out.println("value1 = " + value1);}System.out.println("----------------------------");}
}
- 查询结果
3.3.7 MapHandler策略
-
它是将第一条记录封装成一个map结构,map的key就是字段名称,map的value就是字段对应的值,针对单条记录。
-
查询示例
/*** MapHandler* @throws SQLException*/
@Test
public void test08() throws SQLException
{String sql = "select * from user where pk_id = ?";Map<String, Object> userMap = queryRunner.query(sql, new MapHandler(), 1);for (Map.Entry<String, Object> filedEntry : userMap.entrySet()){String key = filedEntry.getKey();System.out.println("key = " + key);Object value = filedEntry.getValue();System.out.println("value = " + value);}
}
- 查询结果
3.3.8 MapListHandler策略
-
它是将多条记录封装到Map中后组成一个List结构,是MapHandler的升级版,针对多条记录。
-
查询示例
/*** MapListHandler* @throws SQLException*/
@Test
public void test09() throws SQLException
{String sql = "select * from user";List<Map<String, Object>> userMapList = queryRunner.query(sql, new MapListHandler());for (Map<String, Object> userMap : userMapList){for (Map.Entry<String, Object> filedEntry : userMap.entrySet()){String key = filedEntry.getKey();System.out.println("key = " + key);Object value = filedEntry.getValue();System.out.println("value = " + value);}System.out.println("--------------------------------");}
}
- 查询结果
3.3.9 ScalarHandler策略
- 它是将查询到的单一值封装,也就是标量封装,只有一条记录并且这个记录只有一个字段,比如select count(*) from user可以使用它。
- 查询示例
/*** ScalarHandler* @throws SQLException*/
@Test
public void test10() throws SQLException
{String sql = "select count(*) from user";Long count = queryRunner.query(sql, new ScalarHandler<Long>());System.out.println("count = " + count);
}
- 查询结果
4. JdbcTemplate模板
jdbcTemplate是spring提供的JDBC模板,旨在简化JDBC操作。
4.1 添加依赖
(1)连接数据库必须的mysql驱动依赖。
(2)连接池技术用HikariCP技术。
(3)JDBC工具类采用Spring的JdbcTemplate。
(4)Junit用来进行单元测试。
<!-- 依赖管理 -->
<dependencies><!-- mysql --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.49</version></dependency><!-- HikariCP --><dependency><groupId>com.zaxxer</groupId><artifactId>HikariCP</artifactId><version>3.4.5</version></dependency><!-- spring-jdbc --><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>5.2.9.RELEASE</version></dependency><!-- junit --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.13</version><scope>test</scope></dependency>
</dependencies>
4.2 核心对象
JdbcTemplate的核心对象就是JdbcTemplate,它的创建也是依赖于数据源。
JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource);
@Test
public void jdbcTemplateTest()
{// 创建数据源HikariDataSource dataSource = new HikariDataSource();dataSource.setDriverClassName("com.mysql.jdbc.Driver");dataSource.setJdbcUrl("jdbc:mysql://127.0.0.1:3306/zw_test");dataSource.setUsername("root");dataSource.setPassword("root");// 创建JDBC模板对象JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource);// 打印对象System.out.println("jdbcTemplate = " + jdbcTemplate);// 关闭资源datasource.close();
}
4.3 写操作
- JdbcTemplate并没有像DBUtils那样提供很多的封装策略,但是它的API也是满足我们需求的。
4.3.1 单独写操作
- JdbcTemplate提供update方法来执行增删改操作,并且支持占位符。
int update(String sql)int update(String sql, Object... object)
4.3.2 批量写操作
- JdbcTemplate提供batchUpdate方法来执行增删改批量操作,并且支持占位符。
int[] batch(String[] sql)int[] batchUpdate(String[] sql, List<Object[]> list)
4.4 读操作
- JdbcTemplate针对查询的API就比较丰富了,主要分为两类,查询单列、查询多列。
4.4.1 查询单列
- 查询单列单行
T queryForObject(String sql, Class<T> classObject)T queryForObject(String sql, Class<T> classObject, Object... object)
- 查询单列多行
List<T> queryForList(String sql, Class<T> classObject)List<T> queryForList(String sql, Class<T> classObject, Object... object)
4.4.2 查询多列
- 查询多列单行封装为Map
Map<String, Object> queryForMap(String sql)Map<String, Object> queryForMap(String sql, Object... object)
- 查询多列多行封装为Map
List<Map<String, Object>> queryForList(String sql)List<Map<String, Object>> queryForList(String sql, Object... object)
- 查询多列单行封装为Bean
T queryForObject(String sql, new BeanPropertyRowMapper<T>(Class<T>))T queryForObject(String sql, new BeanPropertyRowMapper<T>(Class<T>), Object... object)
- 查询多列多行封装为Bean
List<T> query(String sql, new BeanPropertyRowMapper<T>(Class<T>))List<T> query(String sql, new BeanPropertyRowMapper<T>(Class<T>), Object... object)
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- Python数据可视化高级库pyecharts的用法入门(二)相关环境的安装部署和第一个简单的可视化柱状统计图
文章目录一、Python、Pycharm和pyecharts库的安装部署1、Python、Pycharm2、pyecharts库安装二、第一个pyecharts项目1、代码2、操作3、查看文件一、Python、Pycharm和pyecharts库的安装部署 1、Python、Pycharm PythonPycharm安装教程 2、pyecharts库安装 点击 “文件”(F…...
2024/3/30 10:50:16 - 69.为什么要捕获异常?Java异常处理、finally 、throw和throws的区别?
0、为什么要捕获异常 可以预防错误的程序代码所造成的不可预期的结果发生 把握代码的灵活性等 1、Java异常处理 1 try...catch、try...catch...finally、try...finally 2 throws 异常类型 3、finally 不管try...catch是否捕获异常,fianlly包含的语句一定会执行 …...
2024/4/21 5:19:20 - Unity Shader multi_compileshader_feature 变体
变体相当于条件判断,当然简单的数值判断可以用step直接代替,这个不提 但是if条件判断对于Shader来说不是一个有效率的方法,为什么说if不好呢?因为GPU是并行计算的,保证一样的执行顺序是有利于GPU的。而当你使用if时&a…...
2024/4/19 14:06:29 - SAP Spartacus org unit list点击item之后的页面跳转实现
如下图所示,organization unit list选中一行点击后,会跳转到明细页面: 这个list行项目点击后跳转的触发事件为launch,执行的函数为launchItem($event): 我选中的这个item,一共有7个子元素: getDetailsRoute…...
2024/4/4 3:49:09 - Qt之QGraphicsView入门篇
Qt之QGraphicsView入门篇 lucky-billy 2020-04-05 20:28:40 5503 已收藏 62 分类专栏: Qt 文章标签: QGraphicsView 最后发布:2020-04-05 20:28:40首次发布:2020-04-05 20:28:40版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA …...
2024/4/17 6:24:53 - FFmpeg使用滤镜链为视频插入多张图片
以下命令定义了三个图片mask,使用滤镜链的方式,分别在视频的右下角在三个不同的时间段保持。 ffmpeg -i input.mp4 -strict -2 -vf "movie1.jpg,scale456:280[mask1];movie2.jpg,scale456:280[mask2];movie3.jpg,scale456:280[mask3];[in][mask1]…...
2024/4/19 17:36:33 - 这是一个不成熟的想法,能不能实现?
这是一个不成熟的想法,能不能实现? #include<stdio.h> int main() {char ch[65535];int t,i;i0;t-1;while(i<65535&&t-1){scanf("%c",&ch[i]); //输入 if(ch[i]\n){t1;}i; }t-1;int a[65535];int k;k0;i0;int temp;wh…...
2024/4/24 16:26:18 - DIV属性
1 标准属性 包括各种css样式,例如border,background,A:active等等 2 事件属性 可绑定的各种事件,例如onclick(单击),onmousedown(鼠标按下)等等 3 全局属…...
2024/4/3 8:19:29 - C# 奇偶数
输入一个整数,判断奇偶数 Console.Write("请输入一个整数:");int z int.Parse(Console.ReadLine());//读取输入的整数,并赋值给zif (z % 2 0)//通过取余数判断是否为奇偶数Console.WriteLine("{0}是偶数", z);elseConsole.WriteLi…...
2024/4/20 4:26:03 - python爬虫一般格式
写在前面:建议安装BeautifulSoup模块,写爬虫可以节省不少时间。一般出错,参考终端给出的建议。 pip3 install bs4 -i http://pypi.douban.com/simple/ --trusted-host pypi.douban.com伴随bs4安装的还有 lxml 模块 pip3 install lxml -i ht…...
2024/4/24 18:25:12 - 运算符重载(位操作运算符和逻辑运算符)
运算符重载 //位操作运算符 & | ~ ^ << >> //逻辑运算符 ! && ||#include <iostream> #include <stdio.h> using namespace std;class Interger{ public:Interger(const int i 10):val(i){}Interger(const Interger &obj){val obj.…...
2024/4/24 18:25:11 - 说起分布式系统的难点,不得不说著名的CAP定律FDSGFDH
作为一名游戏设计师,楚河一直希望有一天能够从自己的手里面诞生出如GTA,COD,WOW这种响彻世界的游戏大作。 但现实是很残酷的,毕业于一所普通的二本院校,毫无实践的经验,不说国外如EA、育碧这种世界一流的游…...
2024/4/24 18:25:10 - StringBuffer和StringBuilder的区别
1:StringBuffer、StringBuilder和String一样,也用来代表字符串。String类是不可变类,任何对String的改变都 会引发新的String对象的生成;StringBuffer则是可变类,任何对它所指代的字符串的改变都不会产生新的对象。 2&…...
2024/4/24 18:25:12 - APP开发学习记录 1————Activity的概述
** APP开发学习记录1 ** (PS:利用dimens方法可以调整不同大小的图标的清晰度。) 在app开发学习中,一共提供了四大组件:Activity、Service、BroadcastReceiver和ContentProvider。 在这其中Activity是在Android之中…...
2024/4/24 18:25:08 - 2020-12-05 学习笔记
补上,沟通训练营的学习笔记和感悟,同时,也是一次复习和再学习 第七讲:破冰 破冰的目的: 什么是破冰? 破冰的目的不是为了展现自己,而是为了“赢得信任” 破冰关键要看谁来破,谁…...
2024/4/24 18:25:14 - 数组-丢失的数字(哈希表法)
题意: 给定一个包含 [0, n] 中 n 个数的数组 nums ,找出 [0, n] 这个范围内没有出现在数组中的那个数。 示例 1: 输入:nums [3,0,1] 输出:2 解释:n 3,因为有 3 个数字,所以所有的…...
2024/4/24 18:25:06 - 2020-12-5周总结
课好多好多,,每天不是在上课就是在上课的路上。下周就结课了,实习周只能更忙,期末的考试每一门都不好搞,网路安全还得自己写论文,还得去查重…唉,还想着专业选修能轻松些,结果全是考…...
2024/4/24 18:25:05 - 普通话练习(韵母)
口部操 提高唇和舌的灵活度。 唇部操: 喷:双唇紧闭,将唇的力量集中于唇中央的1/3部位。 咧:向两边嘴角用力咧嘴。 撇:撅嘴,然后上下左右转动。 绕: 舌部操: 顶舌:舌头在…...
2024/3/6 19:33:28 - Linux网络的设置
Linux网络的设置 目录Linux网络的设置一、 查看网络接口信息二、查看主机名三、查看路由表条目四、查看网络连接情况netstat五、获取socket统计信息ss六、 测试网络连接ping七、跟踪数据包traceroute八、域名解析nslookup九、设置网络参数的方法1、临时配置————使用命令调整…...
2024/3/6 19:33:27 - 记录生产一次linux负载高cpu使用率低的分析
前言 本文记录下生产一次cpu使用率低,但是load average高的情况,如下两图,load average很高,但是cpu使用率很低 目录 前言 load average定义 平均负载与CPU使用率关系 case1:CPU密集型java应用 case2:…...
2024/3/11 13:00:35
最新文章
- MessageBox的模版语法上如何注册事件
目标: 想要在MessageBox中的文本中写一些事件,如何处理 在vue中进行操作: coding // 弹窗提示 this.$confirm({customClass: "add-fail",title: this.$t(add_error),type: error,dangerouslyUseHTMLString: true, // 将消息使用…...
2024/4/25 4:01:10 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - 与机器对话:ChatGPT 和 AI 语言模型的奇妙故事
原文:Talking to Machines: The Fascinating Story of ChatGPT and AI Language Models 译者:飞龙 协议:CC BY-NC-SA 4.0 从 ELIZA 到 ChatGPT:会话式人工智能的简史 会话式人工智能是人工智能(AI)的一个分…...
2024/4/23 6:37:10 - Linux中的shell脚本之流程控制循环遍历
3 条件判断 4 流程控制语句 1)if 语句 案例,用户输入用户名和密码,判断用户名是否是admin,密码是否是123,如果正确,则显示登录成功 首先我创建了shell文件,touch getpawer 其中getpawer 是我自己命的名 #!/bin/bas…...
2024/4/23 6:09:12 - 416. 分割等和子集问题(动态规划)
题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义:dp[i][j]表示当背包容量为j,用前i个物品是否正好可以将背包填满ÿ…...
2024/4/25 1:03:45 - 【Java】ExcelWriter自适应宽度工具类(支持中文)
工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...
2024/4/24 1:17:44 - Spring cloud负载均衡@LoadBalanced LoadBalancerClient
LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon,直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件,我们讨论Spring负载均衡以Spring Cloud2020之后版本为主,学习Spring Cloud LoadBalance,暂不讨论Ribbon…...
2024/4/24 11:04:21 - TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案
一、背景需求分析 在工业产业园、化工园或生产制造园区中,周界防范意义重大,对园区的安全起到重要的作用。常规的安防方式是采用人员巡查,人力投入成本大而且效率低。周界一旦被破坏或入侵,会影响园区人员和资产安全,…...
2024/4/24 9:59:40 - VB.net WebBrowser网页元素抓取分析方法
在用WebBrowser编程实现网页操作自动化时,常要分析网页Html,例如网页在加载数据时,常会显示“系统处理中,请稍候..”,我们需要在数据加载完成后才能继续下一步操作,如何抓取这个信息的网页html元素变化&…...
2024/4/24 11:04:20 - 【Objective-C】Objective-C汇总
方法定义 参考:https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...
2024/4/24 11:04:20 - 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】
👨💻博客主页:花无缺 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】🌏题目描述🌏输入格…...
2024/4/24 9:58:43 - 【ES6.0】- 扩展运算符(...)
【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数࿰…...
2024/4/24 11:04:19 - 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?
文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕,各大品牌纷纷晒出优异的成绩单,摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称,在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁,多个平台数据都表现出极度异常…...
2024/4/24 11:04:19 - Go语言常用命令详解(二)
文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令,这些命令可以帮助您在Go开发中进行编译、测试、运行和…...
2024/4/24 11:04:18 - 用欧拉路径判断图同构推出reverse合法性:1116T4
http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b,我们在 a i a_i ai 和 a i 1 a_{i1} ai1 之间连边, b b b 同理,则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然࿰…...
2024/4/24 11:04:18 - 【NGINX--1】基础知识
1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息,并安装一些有助于配置官方 NGINX 软件包仓库的软件包: apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...
2024/4/24 11:04:17 - Hive默认分割符、存储格式与数据压缩
目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限(ROW FORMAT)配置标准HQL为: ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...
2024/4/25 3:28:56 - 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法
文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中,传感器和控制器产生大量周…...
2024/4/25 3:39:58 - --max-old-space-size=8192报错
vue项目运行时,如果经常运行慢,崩溃停止服务,报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中,通过JavaScript使用内存时只能使用部分内存(64位系统&…...
2024/4/24 11:04:13 - 基于深度学习的恶意软件检测
恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞,例如可以被劫持的合法软件(例如浏览器或 Web 应用程序插件)中的错误。 恶意软件渗透可能会造成灾难性的后果,包括数据被盗、勒索或网…...
2024/4/24 11:04:13 - JS原型对象prototype
让我简单的为大家介绍一下原型对象prototype吧! 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定,每一个构造函数都有一个 prototype 属性,指向另一个对象,所以我们也称为原型对象…...
2024/4/24 11:04:13 - C++中只能有一个实例的单例类
C中只能有一个实例的单例类 前面讨论的 President 类很不错,但存在一个缺陷:无法禁止通过实例化多个对象来创建多名总统: President One, Two, Three; 由于复制构造函数是私有的,其中每个对象都是不可复制的,但您的目…...
2024/4/24 9:54:49 - python django 小程序图书借阅源码
开发工具: PyCharm,mysql5.7,微信开发者工具 技术说明: python django html 小程序 功能介绍: 用户端: 登录注册(含授权登录) 首页显示搜索图书,轮播图࿰…...
2024/4/24 10:43:15 - 电子学会C/C++编程等级考试2022年03月(一级)真题解析
C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...
2024/4/25 1:03:22 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57