MyBatis框架的使用:mybatis介绍+环境搭建+基础sql的使用+如何使用Map传入多个参数+返回多个实体用List或者Map接收+特殊sql的使用
MyBatis框架的使用:mybatis介绍+环境搭建+基础sql的使用+如何使用Map传入多个参数+返回多个实体用List或者Map接收+特殊sql的使用
- 一、MyBatis介绍
- 1.1 特性
- 1.2 下载地址
- 1.3 和其它持久层技术对比
- 二、搭建环境
- 2.1配置maven
- 2.2 创建mybatis配置文件
- 2.3 搭建测试环境
- 三、基础的sql语句
- 3.1 配置接口
- 3.2 配置映射文件
- 3.3 map集合类型的参数
- 四、各种查询功能的实现
- 五、特殊的sql语句
一、MyBatis介绍
1.1 特性
1) MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架
2) MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集
3) MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录
4) MyBatis 是一个半自动的ORM(Object Relation Mapping)框架
1.2 下载地址
在github上下载,在里面可以挑选我们需要的版本
https://github.com/mybatis/mybatis-3
1.3 和其它持久层技术对比
JDBC
-
SQL 夹杂在Java代码中耦合度高,导致硬编码内伤
-
维护不易且实际开发需求中 SQL 有变化,频繁修改的情况多见
-
代码冗长,开发效率低
Hibernate和JPA
- 操作简便,开发效率高
- 程序中的长难复杂 SQL 需要绕过框架
- 内部自动生产的 SQL,不容易做特殊优化
- 基于全映射的全自动框架,大量字段的 POJO 进行部分映射时比较困难。
- 反射操作太多,导致数据库性能下降
Mybatis
- 轻量级,性能出色
- SQL 和 Java 编码分开,功能边界清晰。Java代码专注业务、SQL语句专注数据
- 开发效率稍逊于Hibernate,但是完全能够接受
二、搭建环境
新建maven项目
2.1配置maven
加入pom依赖
<dependencies><!-- Mybatis核心 --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.7</version></dependency><!-- junit测试 --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><!-- MySQL驱动 --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.6</version></dependency><!-- log4j日志 --><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency></dependencies>
2.2 创建mybatis配置文件
习惯上命名为mybatis-config.xml,这个文件名仅仅只是建议,并非强制要求。将来整合Spring 之后,这个配置文件可以省略
核心配置文件主要用于配置连接数据库的环境以及MyBatis的全局配置信息
在标签中,使用引入属性文件 ,这里跟数据库的配置一一对应
<properties resource="jdbc.properties"></properties>
- < typeAliases > 标签设置类型别名,对于实体类可以直接使用类名,不区分大小写
- < environments >配置数据库环境
- < transactionManager >设置事务管理
- < dataSource >设置数据源
这里数据库中的驱动jdbc.driver跟jdbc.properties文件中的value值对应
引入mybatis映射文件的方式有两种:
-
直接引入,映射文件有多个的话需要一个一个的引入
-
以包为单位引入,将包下的映射文件全部引入
注意第二种方式:
1.mapper接口所在的包要和映射文件所在的包一致
2.mapper接口要和映射文件的名字一致
MySQL不同版本的注意事项
1、驱动类driver-class-name
MySQL 5版本使用jdbc5驱动,驱动类使用:com.mysql.jdbc.Driver
MySQL 8版本使用jdbc8驱动,驱动类使用:com.mysql.cj.jdbc.Driver
2、连接地址url
MySQL 5版本的url:
jdbc:mysql://localhost:3306/ssm
MySQL 8版本的url:
jdbc:mysql://localhost:3306/ssm?serverTimezone=UTC
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><properties resource="jdbc.properties"></properties>
<!-- 设置类型的别名--><typeAliases>
<!-- typeAliases 设置类型别名 以包为单位,将包下所有的类型设置默认的类型别名,即类名,且不区分大小写 --><package name="com.entity"/></typeAliases><!-- 数据库环境-->
<!-- environments配置多个连接数据库的环境default:设置默认使用的环境的idenvironment配置某个具体的环境属性:id 表示连接数据库环境的唯一标识,不能重复 --><environments default="development"><environment id="development"><transactionManager type="JDBC"/>
<!-- transactionManager:设置事务管理的方式属性 JDBC | MANAGEDJDBC:表示当前环境中,执行SQL时使用的是JDBC中原生的事务管理方式,事务的提交或回滚需要手动处理MANAGED:被管理,例如SpringdataSource:配置数据源type:设置数据源的类型type:POOLED | UNPOOLED | JNDIPOOLED:表示使用数据库连接池缓存数据库连接UNPOOLED:表示不使用数据库连接池缓存数据库连接JNDI:表示使用上下文中的数据源--><dataSource type="POOLED">
<!-- 设置数据库的驱动--><property name="driver" value="${jdbc.driver}"/>
<!-- 设置数据库的链接地址--><property name="url" value="${jdbc.url}"/>
<!-- 设置连接数据库的用户名--><property name="username" value="root"/>
<!-- 设置连接数据库的密码--><property name="password" value="2020"/></dataSource></environment></environments>
<!-- 引入mybatis映射文件-->
<!-- 方式一-->
<!-- <mappers>-->
<!-- <mapper resource="mappers/UserMapper.xml"/>-->
<!-- </mappers>-->
<!-- 方式二-->
<!-- 以包为单位引入映射文件要求:mapper接口所在的包要和映射文件所在的包一致mapper接口要和映射文件的名字一致
--><mappers><package name="com.mapper"/></mappers>
</configuration>
创建属性文件,配置数据库连接的key-value值
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis_demo
接下来建好各级层次的包,尤其要注意com.mapper这里有两个,在resources下的目录是放置映射文件的,这两个包名需要对应
2.3 搭建测试环境
在utils下新建SqlSessionUtil类
package com.util;import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;
import java.io.InputStream;public class SqlSessionUtil {//获取核心配置文件的输入流private static InputStream inputStream = null;public static SqlSession getSqlSession(){SqlSession sqlSession = null;try {inputStream = Resources.getResourceAsStream("mybatis-config.xml");//获取SqlSessionFactoryBuilder对象SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();//获取SqlSessionFactory对象SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(inputStream);//获取SqlSession对象,不会自动提交事务//SqlSession sqlSession = sqlSessionFactory.openSession();//获取SqlSession对象,会自动提交事务sqlSession = sqlSessionFactory.openSession(true);} catch (IOException e) {e.printStackTrace();}return sqlSession;}public static void inputStreamClose(){try {inputStream.close();} catch (IOException e) {e.printStackTrace();}}
}
SqlSession:代表Java程序和数据库之间的会话(HttpSession是Java程序和浏览器之间的会话)
SqlSessionFactory:是“生产”SqlSession的“工厂”
工厂模式:如果创建某一个对象,使用的过程基本固定,就可以把创建这个对象的相关代码封装到一个“工厂类”中,以后都使用这个工厂类来“生产”所需要的对象。
然后在test.java下新建测试类SelectMapperTest,在run方法中编写需要测试的内容
public class SelectMapperTest {private SqlSession sqlSession = null;private SelectMapper mapper = null;@Beforepublic void init(){//获取sqlSession对象sqlSession = SqlSessionUtil.getSqlSession();//获取UserMapper的代理实现类对象mapper = sqlSession.getMapper(SelectMapper.class);}@Testpublic void run(){}@Afterpublic void destroy(){//提交事务//sqlSession.commit();//关闭资源sqlSession.close();SqlSessionUtil.inputStreamClose();}}
接下来可以在com.mapper中创建接口,在resource下的com.mapper中创建配置文件
public interface UserMapper {}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><!-- 接口文件所在的包-->
<mapper namespace="com.mapper.UserMapper"></mapper>
三、基础的sql语句
测试用的数据库信息
使用sql之前,在entity生成实体类User
3.1 配置接口
/**
* 插入
* @param user
* @return
*/
int insertUser(User user);
/**
* 删除
* @return
*/
void deleteUser();/*** 更新用户信息* @return*/
int updateUser();
/*** 查询用户信息*/
List<User> findUser();/*** 根据用户名查询用户信息*/
User getUserByUserName(String userName);
/*** 根据用户名和年龄查询用户信息*/
User gerUserByUserNameAndAge(@Param("userName") String userName,@Param("age") Integer age);
这里的注解@Param里面的内容与映射文件中的变量名对应
MyBatis获取参数值的两种方式:${}和#{}
- ${}的本质就是字符串拼接,采用sql拼接,无法防止sql注入
- #{}的本质就是占位符赋值 ,采用预编译 防止sql注入
如果mapper接口中的方法参数为单个的字面量类型,此时可以使用#{}和 以任意的名称获取参数的值,如果使用 {}以任意的名称获取参数的值,如果使用 以任意的名称获取参数的值,如果使用{},注意需要手动添加单引号
如果mapper接口中的方法参数为多个时,此时MyBatis会自动将这些参数放在一个map集合(key,value)中,以arg0, arg1…为键,以参数为值;或者以param1, param2…为键,以参数为值。因此只需要通过#{}和 访问 m a p 集合的键就可以获取相对于的值,如果使用 {}访问map集合的键就可以获取相对于的值,如果使用 访问map集合的键就可以获取相对于的值,如果使用{},注意需要手动添加单引号。
3.2 配置映射文件
查询的标签select必须设置属性resultType或resultMap,用于设置实体类和数据库表的映射 关系
resultType:自动映射,用于属性名和表中字段名一致的情况
resultMap:自定义映射,用于一对多或多对一或字段名和属性名不一致的情况
<insert id="insertUser">insert into user values(null ,#{userName},#{password},#{age},#{sex},#{email});
</insert><delete id="deleteUser">delete from user where id = 2;
</delete><update id="updateUser">update user set userName="李明" ,password="123456" where id = 3;
</update><select id="findUser" resultType="com.entity.User">select * from user;
</select><select id="getUserByUserName" resultType="user">select * from user where userName='${userName}';
</select><select id="gerUserByUserNameAndAge" resultType="user">select * from user where userName='${userName}' and age = '${age}';
</select>
3.3 map集合类型的参数
如果mapper接口中的方法参数为多个时,此时可以手动创建一个map集合,将这些参数放在map集合中,只需要通过#{}和 访问 m a p 集合的键(自己定义的键)就可以获取相对于的值,如果使用 {}访问map集合的键(自己定义的键)就可以获取相对于的值,如果使用 访问map集合的键(自己定义的键)就可以获取相对于的值,如果使用{},注意需要手动添加单引号。
接口,byMap方法传入一个Map
User byMap(Map<String , Object> map);
映射文件,userName是用户名,age是年龄,大括号里面的是自定义的,传入的map也应该使用这两个变量名
<select id="byMap" resultType="user">select * from user where userName='${userName}' and age = '${age}';
</select>
测试类,查询指定姓名和年龄的用户
Map<String,Object> map=new HashMap<>();map.put("age",18);
map.put("userName","李明");
System.out.println(mapper.byMap(map));
四、各种查询功能的实现
配置接口
public interface SelectMapper {/*** 根据id查询用户信息** @param id* @return*/User getUserById(@Param("id") Integer id);/*** 查询所有用户信息,不确定有多少用户可以用集合* @return*/List<User> getAllUser();/**** 获取数量* @return*/Integer getCount();/*** 查询单个用户信息,返回一个map* @param id* @return*/Map<String,Object> getUserByIdToMap(Integer id);/*** 方式一:* 查询所有,结果返回一个list* @return*/List<Map<String,Object>> getAllUserToList();/*** 方式二:* 加入注解,返回一个 id:用户信息 的map* @return*/@MapKey("id")Map<String,Object> getAllUserToMap();}
配置映射文件
<select id="getUserById" resultType="user">select * from user where id = #{id};
</select><select id="getAllUser" resultType="user">select * from user;
</select><select id="getCount" resultType="java.lang.Integer">select count(*) from user;
</select><select id="getUserByIdToMap" resultType="map">select * from user where id = #{id};
</select><select id="getAllUserToList" resultType="map">select * from user;
</select><select id="getAllUserToMap" resultType="map">select * from user;
</select>
getUserByIdToMap查询单个用户信息,返回一个map
Map<String,Object> map = mapper.getUserByIdToMap(3);
System.out.println(map);
getAllUserToList查询所有,结果返回一个list
System.out.println(mapper.getAllUserToList());
getAllUserToMap加入注解,返回一个 id:用户信息 的map
System.out.println(mapper.getAllUserToMap());
五、特殊的sql语句
/*** 模糊查询* @param temp* @return*/
List<User> getUserLike(@Param("temp") String temp);/*** 批量删除* @param ids*/
void deleteMoreUser(@Param("ids") String ids);
<select id="getUserLike" resultType="user">
<!--1. select * from user where userName like concat('%',#{temp},'%') 会使可移植性变差2.select * from user where userName like ”%“#{temp}“%”3.select * from user where userName like '%${temp}%';-->select * from user where userName like '%${temp}%';</select><delete id="deleteMoreUser" ><--这里注意使用${}的方式,且不能加单引号-->delete from user where id in(${ids});</delete>
模糊查询中字符串的拼接有三种方式,temp是传入的值
- select * from user where userName like concat(‘%’,#{temp},‘%’)
- select * from user where userName like ”%“#{temp}“%”
- select * from user where userName like ‘%${temp}%’
System.out.println(mapper.getUserLike("lm"));
mapper.deleteMoreUser("10,11");
这里的10,11是需要删除信息的id范围
相关文章:

MyBatis框架的使用:mybatis介绍+环境搭建+基础sql的使用+如何使用Map传入多个参数+返回多个实体用List或者Map接收+特殊sql的使用
MyBatis框架的使用:mybatis介绍环境搭建基础sql的使用如何使用Map传入多个参数返回多个实体用List或者Map接收特殊sql的使用 一、MyBatis介绍1.1 特性1.2 下载地址1.3 和其它持久层技术对比 二、搭建环境2.1配置maven2.2 创建mybatis配置文件2.3 搭建测试环境 三、基…...

linux centos nginx配置浏览器访问后端(tomcat日志)
1、配置nginx访问tomcat日志路径 vim /usr/local/nginx/conf/nginx,conflocation ^~ /logs {autoindex on;autoindex_exact_size on;autoindex_localtime on;alias /home/tomcat/apache-tomcat-9.0.89-1/logs;}###配置讲解### 1、location ^~ /logs { … }: location…...
01-03.Vue:v-on的事件修饰符
01-03.Vue:v-on的事件修饰符 前言v-on的事件修饰符.stop的举例.capture举例.prevent的举例1.prevent的举例2.self举例 前言 我们接着上一篇文章 01-02.Vue的常用指令(二) 来讲 下一篇文章 01-04.Vue的使用示例:列表功能 v-on的事件修饰符 v-on 提供了很…...

MSI U盘重装系统
MSI U盘重装系统 1. 准备一块U盘 首先需要将U盘格式化,这个格式化并不是在文件管理中将U盘里面的所有东西都删干净就可以了,需要在磁盘管理中,将这块U盘格式化,如果这块U盘有分区的话,那将所有的分区都格式化并且删除…...
ubuntu如何安装gitlab runner
一、什么是GitLab Runner GitLab Runner 是 GitLab 提供的一个开源工具,用于在构建、测试和部署过程中执行作业。它是 GitLab 持续集成和持续部署(CI/CD)工作流的核心组件之一。 GitLab Runner 有以下主要功能: 作业执行:GitLab Runner 会接收来自 GitLab 的作业请求,并在指定…...

Java整合ELK实现日志收集 之 Elasticsearch、Logstash、Kibana
简介 Logstash:用于收集并处理日志,将日志信息存储到Elasticsearch里面 Elasticsearch:用于存储收集到的日志信息 Kibana:通过Web端的可视化界面来查看日志(数据可视化) Logstash 是免费且开放的服务器端数…...

如何判断自己的情商高低?
什么是情商? 情商(简称为EQ),也叫情绪智力,和我们通常提到的智商智力有所不同(侧重于理性思维),情商更贴近实际生活,如:情绪识别和自我管理,自我…...

JAVA:Spring Boot整合MyBatis Plus持久层
1、简述 MyBatis Plus是MyBatis的增强工具包,它在MyBatis的基础上进行了扩展,提供了许多便捷的功能,例如通用CRUD操作、分页插件、代码生成器等。使用MyBatis Plus,开发者可以更加方便地进行持久层操作,并且减少了很多…...

如何选择优质的气膜体育馆工程服务商—轻空间
随着现代生活的便利化和时代感的增强,气膜体育馆成为越来越多人的选择。这种美观实用的建筑在学校、社区和体育中心等地广泛应用。许多投资者和客户都有意建造气膜体育馆,但在选择工程服务商时,往往面临困惑。以下几点将帮助您做出明智的选择…...

Anti Desgin Vue 实现 表格可编辑、新增、删除功能
1、效果图 新增: 删除: 修改: 代码: <template><div><button click"add">添加</button><span style"margin-left: 8px"><template v-if"hasSelected">{…...

黄金这轮回调会有多深?
华福策略表示,综合来看,22年3月和23年5月两次回调时美联储尚在加息,后续如果美联储降息,将对黄金价格构成显著支撑,因此本次黄金价格的回调幅度应小于前两次回调幅度。 2022年3月以来,黄金共有两次大的回调…...

自定义类型:结构体详解
1.结构体 1.1 结构的基础知识 结构是一些值的集合,这些值称为成员变量。一个整型数组,它的每个数组元素只能是整型,字符型的数组它的每个元素只能是字符型。但是结构体的每个成员可以是各种不同类型的变量。 1.2结构的声明 //声明 struct t…...

嵌入式进阶——舵机控制PWM
🎬 秋野酱:《个人主页》 🔥 个人专栏:《Java专栏》《Python专栏》 ⛺️心若有所向往,何惧道阻且长 文章目录 舵机信号线代码示例初始化PWM初始化UART打印日志初始化外部中断Extimain函数 舵机最早用于船舶上实现转向功能,由于可以通过程序连…...
Java实现抢红包算法——详细注释,标准语法
package learn;import java.math.BigDecimal; import java.util.ArrayList; import java.util.List; import java.util.Random;public class RobRedPacket {// 发红包算法,金额参数以分为单位public static List<Integer> divideRedPacket(Integer totalAmoun…...

【优选算法】位运算 {位运算符及其优先级;位运算的应用:判断位,打开位,关闭位,转置位,位图,get lowbit,close lowbit;相关编程题解析}
一、位运算符及其优先级 我们知道,计算机中的数在内存中都是以二进制形式进行存储的 ,而位运算就是直接对整数在内存中的二进制位进行操作,因此其执行效率非常高,在程序中尽量使用位运算进行操作,这会大大提高程序的性…...

服务器数据恢复—服务器正常断电重启后raid信息丢失的数据恢复案例
服务器数据恢复环境: 一台某品牌DL380 G4服务器,服务器通过该服务器品牌smart array控制器挂载了一台国产的磁盘阵列,磁盘阵列中有一组由14块SCSI硬盘组建的RAID5。服务器安装LINUX操作系统,搭建了NFSFTP,作为内部文件…...

如何理解kmp的套娃式算法啊?
概念 KMP算法,全称Knuth Morris Pratt算法 。文章大部分内容出自《数据结构与算法之美》 核心思想 假设主串是a,模式串是b 在模式串与主串匹配的过程中,当遇到不可匹配的字符的时候,对已经对比过的字符,是否能找到…...
python中树的运用样例
目录 一、文件系统样例 二、Trie树 一、文件系统样例 class FileNode:def __init__(self, name, is_fileFalse):self.name nameself.is_file is_fileself.children []def add_child(self, child):self.children.append(child)# 创建文件系统结构 root FileNode("roo…...

C++学习/复习5--构造函数与初始化/static成员/友元/内部类/匿名对象/编译器的拷贝构造优化
一、本章概要 二、再谈构造函数 1.构造体赋初值与初始化 2.初始化列表与初始化 2.1定义 2.2注意事项与举例 3.explicit关键字与构造函数 3.1隐式类型转换 也叫做自动类型转换 这种转换通常是从存储范围小的类型到存储范围大的类型,或者是从低精度的数值类型到高…...

数学建模--LaTeX基本介绍和入门
1.引言 (1)上次我们介绍到了我们这个团队第一次参加这个数学建模比赛,就是这个电工杯,我是一名论文手,我们在这个下午也是对于这个比赛过程中出现的问题做了相应的分析,每个人也是进行了反思,知…...
Java 8 Stream API 入门到实践详解
一、告别 for 循环! 传统痛点: Java 8 之前,集合操作离不开冗长的 for 循环和匿名类。例如,过滤列表中的偶数: List<Integer> list Arrays.asList(1, 2, 3, 4, 5); List<Integer> evens new ArrayList…...

P3 QT项目----记事本(3.8)
3.8 记事本项目总结 项目源码 1.main.cpp #include "widget.h" #include <QApplication> int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 2.widget.cpp #include "widget.h" #include &q…...
Java 加密常用的各种算法及其选择
在数字化时代,数据安全至关重要,Java 作为广泛应用的编程语言,提供了丰富的加密算法来保障数据的保密性、完整性和真实性。了解这些常用加密算法及其适用场景,有助于开发者在不同的业务需求中做出正确的选择。 一、对称加密算法…...
大语言模型(LLM)中的KV缓存压缩与动态稀疏注意力机制设计
随着大语言模型(LLM)参数规模的增长,推理阶段的内存占用和计算复杂度成为核心挑战。传统注意力机制的计算复杂度随序列长度呈二次方增长,而KV缓存的内存消耗可能高达数十GB(例如Llama2-7B处理100K token时需50GB内存&a…...

用机器学习破解新能源领域的“弃风”难题
音乐发烧友深有体会,玩音乐的本质就是玩电网。火电声音偏暖,水电偏冷,风电偏空旷。至于太阳能发的电,则略显朦胧和单薄。 不知你是否有感觉,近两年家里的音响声音越来越冷,听起来越来越单薄? —…...

C# 表达式和运算符(求值顺序)
求值顺序 表达式可以由许多嵌套的子表达式构成。子表达式的求值顺序可以使表达式的最终值发生 变化。 例如,已知表达式3*52,依照子表达式的求值顺序,有两种可能的结果,如图9-3所示。 如果乘法先执行,结果是17。如果5…...
LOOI机器人的技术实现解析:从手势识别到边缘检测
LOOI机器人作为一款创新的AI硬件产品,通过将智能手机转变为具有情感交互能力的桌面机器人,展示了前沿AI技术与传统硬件设计的完美结合。作为AI与玩具领域的专家,我将全面解析LOOI的技术实现架构,特别是其手势识别、物体识别和环境…...
离线语音识别方案分析
随着人工智能技术的不断发展,语音识别技术也得到了广泛的应用,从智能家居到车载系统,语音识别正在改变我们与设备的交互方式。尤其是离线语音识别,由于其在没有网络连接的情况下仍然能提供稳定、准确的语音处理能力,广…...
华为OD最新机试真题-数组组成的最小数字-OD统一考试(B卷)
题目描述 给定一个整型数组,请从该数组中选择3个元素 组成最小数字并输出 (如果数组长度小于3,则选择数组中所有元素来组成最小数字)。 输入描述 行用半角逗号分割的字符串记录的整型数组,0<数组长度<= 100,0<整数的取值范围<= 10000。 输出描述 由3个元素组成…...

从0开始学习R语言--Day17--Cox回归
Cox回归 在用医疗数据作分析时,最常见的是去预测某类病的患者的死亡率或预测他们的结局。但是我们得到的病人数据,往往会有很多的协变量,即使我们通过计算来减少指标对结果的影响,我们的数据中依然会有很多的协变量,且…...