上一章:[Spring+SpringMVC+Mybatis]框架学习笔记(二):Spring-IOC-DI

下一章:[Spring+SpringMVC+Mybatis]框架学习笔记(四):Spring实现AOP

第3章 Spring实现JDBC

利用springJdbcTemplate实现一个表的简单的增删改查。

事先建表:

CREATE DATABASE STUDENT;

USE STUDENT;

CREATE TABLE STUDENT(
ID INT PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(20) NOT NULL,
AGE INT NOT NULL,
SEX TINYINT(1) UNSIGNED DEFAULT 0 NOT NULL
)AUTO_INCREMENT = 100000; INSERT INTO STUDENT(NAME,AGE,SEX) VALUES("STEVEN",31,1);
INSERT INTO STUDENT(NAME,AGE) VALUES("LUCY",28);

注入数据库连接的四要素(数据库类型、地址、用户名、密码):

  • 引入数据库驱动包

    mysql-connector-java-5.1.39-bin.jar

    ojdbc5.jar
  • 引入spring-jdbc的jar包

    spring-jdbc-4.2.1.RELEASE.jar

    spring-tx-4.2.1.RELEASE.jar(跟事务相关)

3.1 实现方式1:配置文件方式

3.1.1 实体类

package com.steven.spring.sysmgr.entity;

import java.io.Serializable;

/**
* 实体类
* @author chenyang
*
*/
public class Student implements Serializable{
/**
*
*/
private static final long serialVersionUID = -3587920774423955014L; public Student(){ } private int id;
private String name;
private int age;
private int sex;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public int getSex() {
return sex;
}
public void setSex(int sex) {
this.sex = sex;
} }

3.1.2 DAO层的接口和实现类

1)DAO接口:

package com.steven.spring.sysmgr.dao;

import java.util.List;
import java.util.Map; import com.steven.spring.sysmgr.entity.Student; public interface IStudentDao { public boolean addStudent(Student student); public boolean delStudent(Integer studentId); public boolean updateStudent(Student student); public List<Map<String, Object>> getStudentMap(); public List<Student> getStudentList();
}

2)DAO接口的实现:

package com.steven.spring.sysmgr.dao.impl;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import java.util.Map; import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper; import com.steven.spring.sysmgr.dao.IStudentDao;
import com.steven.spring.sysmgr.entity.Student; public class StudentDao implements IStudentDao{ private JdbcTemplate jdbcTemplate; public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
} @Override
public boolean addStudent(Student student) {
boolean flag = false;
String addSql = "INSERT INTO STUDENT(NAME,AGE,SEX) VALUES(?,?,?)";
int rows = this.jdbcTemplate.update(addSql, student.getName(), student.getAge(), student.getSex());
if(rows > 0){
flag = true;
}
return flag;
} @Override
public boolean delStudent(Integer studentId) {
boolean flag = false;
String delSql = "DELETE FROM STUDENT WHERE ID = ?";
int rows = this.jdbcTemplate.update(delSql, studentId);
if(rows > 0){
flag = true;
} return flag;
} @Override
public boolean updateStudent(Student student) {
boolean flag = false;
String updateSql = "UPDATE STUDENT SET NAME=?, AGE=?, SEX=? WHERE ID=? ";
int rows = this.jdbcTemplate.update(updateSql, student.getName(), student.getAge(), student.getSex(), student.getId());
if(rows > 0){
flag = true;
}
return flag;
} @Override
public List<Map<String, Object>> getStudentMap() {
return this.jdbcTemplate.queryForList("SELECT ID,NAME,AGE,SEX FROM STUDENT");
} @Override
public List<Student> getStudentList() {
String querySql = "SELECT ID, NAME, AGE, SEX FROM STUDENT";
//第1种方式:用接口的匿名内部类来实现,优点:可以根据需求做二次改造
/*return this.jdbcTemplate.query(querySql, new RowMapper<Student>(){ @Override
public Student mapRow(ResultSet rs, int rowNum) throws SQLException {
Student student = new Student();
student.setId(rs.getInt("ID"));
student.setName(rs.getString("NAME"));
student.setAge(rs.getInt("AGE"));
student.setSex(rs.getInt("SEX"));
return student;
} });*/ //第2种方式:直接将行结果集映射到实体类中,优点:简便
return this.jdbcTemplate.query(querySql, new BeanPropertyRowMapper<Student>(Student.class)); }
}

3.1.3 服务层的接口和实现类

1)服务类接口:

package com.steven.spring.sysmgr.service;

import java.util.List;
import java.util.Map; import com.steven.spring.sysmgr.entity.Student; public interface IStudentService { public boolean addStudent(Student student); public boolean delStudent(Integer studentId); public boolean updateStudent(Student student); public List<Map<String, Object>> getStudentMap(); public List<Student> getStudentList();
}

2)服务类接口的实现,它依赖于IStudentDao:

package com.steven.spring.sysmgr.service.impl;

import java.util.List;
import java.util.Map; import com.steven.spring.sysmgr.dao.IStudentDao;
import com.steven.spring.sysmgr.entity.Student;
import com.steven.spring.sysmgr.service.IStudentService; public class StudentService implements IStudentService{ private IStudentDao studentDao; public void setStudentDao(IStudentDao studentDao) {
this.studentDao = studentDao;
} @Override
public boolean addStudent(Student student) {
// TODO Auto-generated method stub
return this.studentDao.addStudent(student);
} @Override
public boolean delStudent(Integer studentId) {
// TODO Auto-generated method stub
return this.studentDao.delStudent(studentId);
} @Override
public boolean updateStudent(Student student) {
// TODO Auto-generated method stub
return this.studentDao.updateStudent(student);
} @Override
public List<Map<String, Object>> getStudentMap() {
// TODO Auto-generated method stub
return this.studentDao.getStudentMap();
} @Override
public List<Student> getStudentList() {
// TODO Auto-generated method stub
return this.studentDao.getStudentList();
} }

3.1.4 spring-IOC的配置文件

spring-IOC的配置文件applicationContext.xml:利用SpringIOC实现服务类和DAO类的依赖

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd"> <!-- 注册服务类,并描述依赖关系 -->
<bean id="studentService" class="com.steven.spring.sysmgr.service.impl.StudentService">
<property name="studentDao" ref="studentDao"/>
</bean> <!-- 注册DAO类 -->
<bean id="studentDao" class="com.steven.spring.sysmgr.dao.impl.StudentDao">
<property name="jdbcTemplate" ref="jdbcTemplate"/>
</bean> <!-- 注册springJdbc查询模板,模板依赖于数据源 -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"/>
</bean> <!-- 注册spring自带的管理数据库连接的数据源 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://127.0.0.1:3306/student"/>
<property name="username" value="root"/>
<property name="password" value="123"/>
</bean> </beans>

3.1.5 测试类

package com.steven.spring.sysmgr.test;

import org.junit.Before;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; import com.steven.spring.sysmgr.entity.Student;
import com.steven.spring.sysmgr.service.IStudentService; public class SpringJdbcTest {
private ApplicationContext ac; @Before
public void init(){
ac = new ClassPathXmlApplicationContext("applicationContext.xml");
} //模拟增加功能
@Test
public void testAddStudent(){
IStudentService studentService = (IStudentService) ac.getBean("studentService"); Student student = new Student();
student.setName("Jacky");
student.setAge(35);
student.setSex(1); System.out.println(studentService.addStudent(student)); } //模拟删除功能
@Test
public void testDelStudent(){
IStudentService studentService = (IStudentService) ac.getBean("studentService"); int delStudentId = 100000; System.out.println(studentService.delStudent(delStudentId)); } //模拟更改功能
@Test
public void testUpdateStudent(){
IStudentService studentService = (IStudentService) ac.getBean("studentService"); Student student = new Student();
student.setId(100001);
student.setName("Lily");
student.setAge(26);
student.setSex(0); System.out.println(studentService.updateStudent(student)); } //模拟查询功能,返回List<Student>
@Test
public void testGetStudentList(){
IStudentService studentService = (IStudentService) ac.getBean("studentService");
System.out.println(studentService.getStudentList());
} //模拟查询功能,返回List<Map<String, object>>
@Test
public void testGetStudentMap(){
IStudentService studentService = (IStudentService) ac.getBean("studentService");
System.out.println(studentService.getStudentMap());
}
}

3.2 实现方式2:注解方式

1、在服务层接口实现类(@Service(...))和Dao层接口实现类(@Repository(...))中分别加入注解表示符,并声明依赖关系(@Autowired)

1)DAO的实现类

package com.steven.spring.sysmgr.dao.impl;

import java.util.List;
import java.util.Map; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository; import com.steven.spring.sysmgr.dao.IStudentDao;
import com.steven.spring.sysmgr.entity.Student; @Repository("studentDao")
public class StudentDao implements IStudentDao{
@Autowired
private JdbcTemplate jdbcTemplate; public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
} @Override
public boolean addStudent(Student student) {
boolean flag = false;
String addSql = "INSERT INTO STUDENT(NAME,AGE,SEX) VALUES(?,?,?)";
int rows = this.jdbcTemplate.update(addSql, student.getName(), student.getAge(), student.getSex());
if(rows > 0){
flag = true;
}
return flag;
} @Override
public boolean delStudent(Integer studentId) {
boolean flag = false;
String delSql = "DELETE FROM STUDENT WHERE ID = ?";
int rows = this.jdbcTemplate.update(delSql, studentId);
if(rows > 0){
flag = true;
} return flag;
} @Override
public boolean updateStudent(Student student) {
boolean flag = false;
String updateSql = "UPDATE STUDENT SET NAME=?, AGE=?, SEX=? WHERE ID=? ";
int rows = this.jdbcTemplate.update(updateSql, student.getName(), student.getAge(), student.getSex(), student.getId());
if(rows > 0){
flag = true;
}
return flag;
} @Override
public List<Map<String, Object>> getStudentMap() {
return this.jdbcTemplate.queryForList("SELECT ID,NAME,AGE,SEX FROM STUDENT");
} @Override
public List<Student> getStudentList() {
String querySql = "SELECT ID, NAME, AGE, SEX FROM STUDENT";
//第1种方式:用接口的匿名内部类来实现,优点:可以根据需求做二次改造
/*return this.jdbcTemplate.query(querySql, new RowMapper<Student>(){ @Override
public Student mapRow(ResultSet rs, int rowNum) throws SQLException {
Student student = new Student();
student.setId(rs.getInt("ID"));
student.setName(rs.getString("NAME"));
student.setAge(rs.getInt("AGE"));
student.setSex(rs.getInt("SEX"));
return student;
} });*/ //第2种方式:直接将行结果集映射到实体类中,优点:简便
return this.jdbcTemplate.query(querySql, new BeanPropertyRowMapper<Student>(Student.class)); }
}

2)服务层的实现类

package com.steven.spring.sysmgr.service.impl;

import java.util.List;
import java.util.Map; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import com.steven.spring.sysmgr.dao.IStudentDao;
import com.steven.spring.sysmgr.entity.Student;
import com.steven.spring.sysmgr.service.IStudentService; @Service("studentService")
public class StudentService implements IStudentService{
@Autowired
private IStudentDao studentDao; public void setStudentDao(IStudentDao studentDao) {
this.studentDao = studentDao;
} @Override
public boolean addStudent(Student student) {
// TODO Auto-generated method stub
return this.studentDao.addStudent(student);
} @Override
public boolean delStudent(Integer studentId) {
// TODO Auto-generated method stub
return this.studentDao.delStudent(studentId);
} @Override
public boolean updateStudent(Student student) {
// TODO Auto-generated method stub
return this.studentDao.updateStudent(student);
} @Override
public List<Map<String, Object>> getStudentMap() {
// TODO Auto-generated method stub
return this.studentDao.getStudentMap();
} @Override
public List<Student> getStudentList() {
// TODO Auto-generated method stub
return this.studentDao.getStudentList();
} }

2、在配置文件中进行加入约束和扫描包

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd"> <!-- 扫描包 -->
<context:component-scan base-package="com.steven.spring.sysmgr"></context:component-scan> <!-- 注册springJdbc查询模板,模板依赖于数据源 -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"/>
</bean> <!-- 注册spring自带的管理数据库连接的数据源 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://127.0.0.1:3306/student"/>
<property name="username" value="root"/>
<property name="password" value="123"/>
</bean>
</beans>

3.3 实现方式3:Dao实现类继承JdbcDaoSupport

在Dao接口实现里,不用引入JdbcTemplate的接口,而是继承JdbcDaoSupport。因为JdbcDaoSupport类引入了JdbcTemlate。

使用这种方式时,可以不用注入jdbcTemplate,即dao实现类直接依赖于dataSource。因为在类JdbcDaoSupport中会实例化JdbcTemplate。

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"> <!-- 注册服务类,并描述依赖关系 -->
<bean id="studentService" class="com.steven.spring.sysmgr.service.impl.StudentService">
<property name="studentDao" ref="studentDao"/>
</bean> <!-- 注册DAO类: 当Dao实现类继承了JdbcDaoSupport,可以直接注入dataSource-->
<bean id="studentDao" class="com.steven.spring.sysmgr.dao.impl.StudentDao">
<property name="dataSource" ref="dataSource"/>
</bean> <!-- 注册spring自带的管理数据库连接的数据源 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://127.0.0.1:3306/student"/>
<property name="username" value="root"/>
<property name="password" value="123"/>
</bean>
</beans>

3.4 实现方式4:利用properties配置文件方式

1、在src根目录下新建一个配置文件jdbc.properties

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/student
jdbc.user=root
jdbc.password=123

2、让spring加载配置文件

1)加载properties配置文件内容

方式1:

<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="location" value="classpath:jdbc.properties"/>
</bean>

方式2:

首先在xml配置文件中引入context头文件标签。

	<context:property-placeholder location="classpath:jdbc.properties"/>

2)将dataSource的bean标签更改为:

<!-- 注册spring自带的管理数据库连接的数据源 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.user}"/>
<property name="password" value="${jdbc.password}"/>
</bean>

3.5 实现方式5:c3p0数据源连接池

1)引入c3p0数据连接池的jar包:c3p0-0.9.0.jar

2)xml配置文件数据源连接部分改为(注意不同点):

<!-- 注册c3p0数据源连接池 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${jdbc.driver}"/>
<property name="jdbcUrl" value="${jdbc.url}"/>
<property name="user" value="${jdbc.user}"/>
<property name="password" value="${jdbc.password}"/>
</bean>

3.6 实现方式6:dbcp数据源连接池

1)引入dbcp数据源连接池(Apache公司)需要的jar包

commons-dbcp-1.4.jar

commons-pool-1.6.jar

2)xml配置文件数据源连接部分改为(注意不同点):

<!-- 注册dbcp数据源连接池 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.user}"/>
<property name="password" value="${jdbc.password}"/>
</bean>

上一章:[Spring+SpringMVC+Mybatis]框架学习笔记(二):Spring-IOC-DI

下一章:[Spring+SpringMVC+Mybatis]框架学习笔记(四):Spring实现AOP

[Spring+SpringMVC+Mybatis]框架学习笔记(三):Spring实现JDBC的更多相关文章

  1. [Spring+SpringMVC+Mybatis]框架学习笔记(六):事务

    第7讲 事务 7.1 事务的概念 事务是一系列作为一个逻辑单元来执行的操作集合. 它是数据库维护数据一致性的单位,它讲数据库从一个一致状态,转变为新的另外一个一致状态.说的简单一点就是:如果一组处理步 ...

  2. 用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建三:配置spring并测试

    这一部分的主要目的是 配置spring-service.xml  也就是配置spring  并测试service层 是否配置成功 用IntelliJ IDEA 开发Spring+SpringMVC+M ...

  3. Spring+SpringMVC+MyBatis集成学习笔记【一】

    一,首先要清楚,SpringMVC其实就是Spring的一个组件       例如我们知道Spring中有类似于,AOP TX等等类似的组件,所以SpringMVC其实就是Spring的一个组件,是S ...

  4. 搭建Spring + SpringMVC + Mybatis框架之三(整合Spring、Mybatis和Spring MVC)

    整合Spring和SpringMVC 之前已经整合了spring和mybatis,现在在此基础上整合SSM. 项目目录: 思路:SpringMVC的配置文件独立,然后在web.xml中配置整合. (1 ...

  5. 用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建四:配置springmvc

    在用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建三:配置spring并测试的基础上 继续进行springmvc的配置 一:配置完善web.xml文件

  6. 用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建二:配置MyBatis 并测试(2 配置spring-dao和测试)

    用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建二:配置MyBatis 并测试(1 搭建目录环境和依赖) 四:在\resources\spring 下面 ...

  7. Spring+SpringMVC+MyBatis深入学习及搭建(三)——MyBatis全局配置文件解析

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6874672.html 前面有写到Spring+SpringMVC+MyBatis深入学习及搭建(二)——My ...

  8. Spring+SpringMVC+MyBatis深入学习及搭建(十七)——SpringMVC拦截器

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7098753.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(十六)--S ...

  9. 用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建二:配置MyBatis 并测试(1 构建目录环境和依赖)

    引言:在用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建一   的基础上 继续进行项目搭建 该部分的主要目的是测通MyBatis 及Spring-dao ...

  10. SSM(Spring +SpringMVC + Mybatis)框架搭建

    SSM(Spring +SpringMVC + Mybatis)框架的搭建 最近通过学习别人博客发表的SSM搭建Demo,尝试去搭建一个简单的SSMDemo---实现的功能是对用户增删改查的操作 参考 ...

随机推荐

  1. Python实现网络工具

    使用python编写网络工具 基础内容 介绍基本的网络编程 Socket编程 Socket又称"套接字",应用程序通常通过"套接字"向网络发出请求或者应答网络请 ...

  2. UE中根据场景模型,导出缩略图

    在实际使用中,我们有了很多模型,但是有时候我们需要这些模型对应的缩略图,比如我有很多物品,我想弄个仓库,有2种方式,要么,弄个仓库场景,一个物体一个格子摆放第二种,就是为每个物体制作一个缩略图 如果一 ...

  3. [C++基础入门] 2、数据类型

    文章目录 2 数据类型 2.1 整型 2.2 sizeof关键字 2.3 实型(浮点型) 2.4 字符型 2.5 转义字符 2.6 字符串型 2.7 布尔类型 bool 2.8 数据的输入 2 数据类 ...

  4. MQTT-会话

    MQTT会话 为什么需要会话 ​ 假如有以下场景,客户端A发送消息到服务端,服务端转发给客户端B,如果这个时候服务端和客户端B的网络连接断开,那么就无法保证消息到达,并且客户端A不知道B连接断开,还会 ...

  5. 如何在SpringBoot项目中兼容Jersey和SpringMVC框架?

    文章目录 Jersey框架介绍 常用的注解: SpringBoot中SpringMVC兼容Jersey 整合Jersey REST(Representational State Transfer)表象 ...

  6. cryptohack wp day(3)

    第二节模运算----第一题( GCD ) 在做这道题前,了解下欧几里得算法: 欧几里得算法,也叫辗转相除法,用于求解两个非负整数a和b的最大公约数(Greatest Common Divisor, G ...

  7. Vulhub activewq_漏洞复现——源码分析

    Vulhub activewq_漏洞复现--源码分析 漏洞简介 Apache ActiveMQ是由美国阿帕奇(Apache)软件基金会开发的开源消息中间件,支持Java消息服务.集群.Spring框架 ...

  8. [Flink] Flink Job运行状态正常,但日志中偶报“FlinkException: The file LOG does not exist on the TaskExecutor.”

    0 序言 Flink : 1.12 job start running time : 2022-12-27 17:40:47 problem throw time : 2023-05-11 16:41 ...

  9. sourcetree和git无法识别新增文件

    在工程中新建文件,但是git和sourcetree无法识别,我是用的是Xcode添加的文件和图片,全都无法识别.例如,新建一个类文件,.h和.m都是别不出来,但是工程文件显示已经添加相对应的类,所以肯 ...

  10. 2022-06-01:给定一个数组arr,可能有正、有负、有0,无序。 只能挑选两个数字,想尽量让两个数字加起来的绝对值尽量小。 返回可能的最小的值。

    2022-06-01:给定一个数组arr,可能有正.有负.有0,无序. 只能挑选两个数字,想尽量让两个数字加起来的绝对值尽量小. 返回可能的最小的值. 答案2022-06-01: 排序,双指针. 代码 ...