通用 Mappper(一)
文章目录
- 1. 通用 Mapper 介绍
- 2. 快速入门
- 2.1 搭建环境
- 2.2 集成通用 Mapper
- 3. 常用注解
- 3.1 @Table
- 3.2 @Column
- 3.3 @Id
- 3.4 @GeneratedValue
- 3.5 @Transient
- 4. 基础方法
- 4.1 selectOne 方法
- 4.2 select 方法
- 4.3 selectAll 方法
- 4.4 selectByPrimaryKey 方法
- 4.5 selectCount 方法
- 4.6 insert 方法
- 4.7 insertSelective 方法
- 4.8 updateByPrimaryKey 方法
- 4.9 updateByPrimaryKeySelective 方法
- 4.10 delete 方法
- 4.11 deleteByPrimaryKey 方法
- 5. Example 方法
- 5.1 selectByExample 方法
- 5.2 selectCountByExample 方法
- 5.3 updateByExample 方法
- 5.4 updateByExampleSelective 方法
- 5.5 deleteByExample 方法
1. 通用 Mapper 介绍
通用 Mapper 是一个辅助 MyBatis 单表开发的组件,它使我们能极其方便的使用 MyBatis 单表的增删改查。
2. 快速入门
2.1 搭建环境
-
创建数据库 mapper,和 table_user 表
DROP TABLE IF EXISTS `table_user`; CREATE TABLE `table_user` (`user_id` int(11) NOT NULL AUTO_INCREMENT,`user_name` varchar(20) DEFAULT NULL,`user_gender` char(2) DEFAULT '未知',`user_address` varchar(30) DEFAULT NULL,`user_birthday` date DEFAULT NULL,PRIMARY KEY (`user_id`) ) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8;-- ---------------------------- -- Records of table_user -- ---------------------------- INSERT INTO `table_user` VALUES ('1', '张三', '男', '北京', '2020-01-15'); INSERT INTO `table_user` VALUES ('2', '李四', '男', '上海', '2020-01-14'); INSERT INTO `table_user` VALUES ('3', '王五', '女', '广州', '2020-01-12');
-
创建工程
- 打开 IDEA --> Create New Project --> Empty Project --> 填写项目名 --> Finish
- New Module --> Maven --> Next --> 填写项目信息 --> Finish
-
引入依赖
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.zt</groupId><artifactId>mapper_demo1</artifactId><version>1.0-SNAPSHOT</version><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.2.1.RELEASE</version></parent><dependencies><!--jdbc的启动器,默认使用 HikariCP 连接池--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency><!--mysql驱动--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><!--mybatis--><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>1.3.2</version></dependency><!--SpringBoot-test--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies></project>
-
配置 application.properties
# 连接四大参数 spring.datasource.url=jdbc:mysql://localhost:3306/mapper?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf-8 spring.datasource.username=root spring.datasource.password=123456
-
创建引导类
@SpringBootApplication public class MapperApplication {public static void main(String[] args) {SpringApplication.run(MapperApplication.class,args);} }
-
创建测试类,测试能否获取数据库连接
@RunWith(SpringRunner.class) @SpringBootTest(classes = MapperApplication.class) public class ConnectionTest {@Autowiredprivate DataSource dataSource;@Testpublic void testGetConnection() throws SQLException {Connection connection = dataSource.getConnection();System.out.println(connection);} }
运行结果:
HikariProxyConnection@737756161 wrapping com.mysql.cj.jdbc.ConnectionImpl@2532b351
2.2 集成通用 Mapper
-
引入依赖
<!--通用 Mapper--> <dependency><groupId>tk.mybatis</groupId><artifactId>mapper-spring-boot-starter</artifactId><version>2.1.5</version> </dependency>
-
创建实体类 User
/*** 建立数据库与实体类之间的关系*/ @Table(name = "table_user") public class User implements Serializable {private Integer userId;private String userName;private String userGender;private String userAddress;private Date userBirthday;public User() {}public User(Integer userId, String userName, String userGender, String userAddress, Date userBirthday) {this.userId = userId;this.userName = userName;this.userGender = userGender;this.userAddress = userAddress;this.userBirthday = userBirthday;}public Integer getUserId() {return userId;}public void setUserId(Integer userId) {this.userId = userId;}public String getUserName() {return userName;}public void setUserName(String userName) {this.userName = userName;}public String getUserGender() {return userGender;}public void setUserGender(String userGender) {this.userGender = userGender;}public String getUserAddress() {return userAddress;}public void setUserAddress(String userAddress) {this.userAddress = userAddress;}public Date getUserBirthday() {return userBirthday;}public void setUserBirthday(Date userBirthday) {this.userBirthday = userBirthday;}@Overridepublic String toString() {return "User{" +"userId=" + userId +", userName='" + userName + '\'' +", userGender='" + userGender + '\'' +", userAddress='" + userAddress + '\'' +", userBirthday=" + userBirthday +'}';} }
-
创建持久层 UserMapper
/*** 具体操作数据库的 Mapper 接口,需要继承通用 mapper 提供的核心接口:Mapper<User>
-
泛型类型就是实体类的类型
*/
@org.apache.ibatis.annotations.Mapper
public interface UserMapper extends Mapper {}
-
创建 UserMapper 测试类
@RunWith(SpringRunner.class) @SpringBootTest(classes = MapperApplication.class) public class MapperTest {@Autowiredprivate UserMapper userMapper;@Testpublic void testSelectOne() {User user = new User(null, "张三", null, null, null);System.out.println(userMapper.selectOne(user));} }
运行结果:
User{userId=1, userName='张三', userGender='男', userAddress='北京', userBirthday=Wed Jan 15 00:00:00 CST 2020}
3. 常用注解
3.1 @Table
-
作用:建立实体类和数据库表之间的对应关系。
-
默认规则:实体类类名首字母小写作为表名。User 类 --> user 表。
-
实例:
@Table(name = "table_user") public class User implements Serializable {
3.2 @Column
-
作用:建立实体类字段和数据库表字段之间的对应关系。
-
默认规则:
实体类字段:驼峰式命名
数据库表字段:使用 “_” 区分各个单词
-
实例:
@Column(name = "user_id") private Integer id;
3.3 @Id
-
作用:建立实体类主键字段和数据库表主键字段之间的对应关系。
-
实例:
@Id private Integer userId;
3.4 @GeneratedValue
-
作用:让通用 Mapper 在执行 insert 操作之后将数据库自动生成的主键值回写到实体类对象中。
-
实例:
@Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Integer userId;
@Test public void testInsert() {User user = new User(null, "小红", "女", "杭州", new java.util.Date());userMapper.insert(user);System.out.println(user); }
运行结果:
User{userId=10, userName='小红', userGender='女', userAddress='杭州', userBirthday=Sat Jan 18 14:52:38 CST 2020}
3.5 @Transient
-
作用:用于标记不与数据库表字段对应的实体类字段。
-
实例:
@Transient private String otherThings; //非数据库表中字段
4. 基础方法
4.1 selectOne 方法
-
说明:根据实体中的属性进行查询,只能有一个返回值,有多个结果是抛出异常,查询条件使用等号
-
实例:
@Test public void testSelectOne() {User user = new User(null, "张三", null, null, null);System.out.println(userMapper.selectOne(user)); }
运行结果:
User{id=1, userName='张三', userGender='男', userAddress='北京', userBirthday=Wed Jan 15 00:00:00 CST 2020}
4.2 select 方法
-
说明:根据实体中的属性值进行查询,查询条件使用等号
-
实例:
@Test public void testSelect() {User user = new User(null, null, "男", null, null);List<User> users = userMapper.select(user);for (User user1 : users) {System.out.println(user1);} }
运行结果:
User{userId=1, userName='张三', userGender='男', userAddress='北京', userBirthday=Wed Jan 15 00:00:00 CST 2020} User{userId=2, userName='李四', userGender='男', userAddress='上海', userBirthday=Tue Jan 14 00:00:00 CST 2020} User{userId=7, userName='小明', userGender='男', userAddress='深圳', userBirthday=Sat Jan 18 00:00:00 CST 2020}
4.3 selectAll 方法
-
说明:查询全部结果,select(null)方法能达到同样的效果
-
实例:
@Test public void testSelectAll() {List<User> users = userMapper.selectAll();for (User user : users) {System.out.println(user);} }
运行结果:
User{userId=1, userName='张三', userGender='男', userAddress='北京', userBirthday=Wed Jan 15 00:00:00 CST 2020} User{userId=2, userName='李四', userGender='男', userAddress='上海', userBirthday=Tue Jan 14 00:00:00 CST 2020} User{userId=3, userName='王五', userGender='女', userAddress='广州', userBirthday=Sun Jan 12 00:00:00 CST 2020} User{userId=7, userName='小明', userGender='男', userAddress='深圳', userBirthday=Sat Jan 18 00:00:00 CST 2020}
4.4 selectByPrimaryKey 方法
-
说明:根据主键字段进行查询,方法参数必须包含完整的主键属性,查询条件使用等号
-
注意:该方法需要使用 @Id 指定实体类中的主键,否则通用 Mapper 会默认将所有实体类字段作为联合主键
-
实例:
@Test public void testSelectByPrimaryKey() {System.out.println(userMapper.selectByPrimaryKey(3)); }
运行结果:
User{userId=3, userName='王五', userGender='女', userAddress='广州', userBirthday=Sun Jan 12 00:00:00 CST 2020}
4.5 selectCount 方法
-
说明:根据实体中的属性查询总数,查询条件使用等号
-
实例:
@Test public void testSelectCount() {User user = new User(null, null, "男", null, null);System.out.println(userMapper.selectCount(user)); }
运行结果:
3
4.6 insert 方法
-
说明:保存一个实体,null 的属性也会保存,不会使用数据库默认值
-
实例:
@Test public void testInsert() {User user = new User(null, "小红", "女", "杭州", new java.util.Date());userMapper.insert(user);System.out.println(userMapper.selectOne(new User(null,"小红",null,null,null))); }
运行结果:
User{userId=14, userName='小红', userGender='女', userAddress='杭州', userBirthday=Sat Jan 18 00:00:00 CST 2020}
4.7 insertSelective 方法
-
说明:保存一个实体,null 的属性不会保存,会使用数据库默认值
-
实例:
@Test public void testInsertSelective() {User user = new User(null, "小美", null, "南京", new java.util.Date());userMapper.insertSelective(user);System.out.println(userMapper.selectOne(new User(null,"小美",null,null,null))); }
运行结果:
User{userId=15, userName='小美', userGender='未知', userAddress='南京', userBirthday=Sat Jan 18 00:00:00 CST 2020}
4.8 updateByPrimaryKey 方法
-
说明:根据主键更新实体全部字段,null 值会被更新
-
实例:
@Test public void testUpdateByPrimaryKey() {User user = new User(3, "建国", null, null, null);userMapper.updateByPrimaryKey(user);System.out.println(userMapper.selectOne(new User(3, null, null, null, null))); }
运行结果:
User{userId=3, userName='建国', userGender='null', userAddress='null', userBirthday=null}
4.9 updateByPrimaryKeySelective 方法
-
说明:根据主键更新属性不为 null 的值
-
实例:
@Test public void testUpdateByPrimaryKeySelective() {User user = new User(2, "建军", null, null, null);userMapper.updateByPrimaryKeySelective(user);System.out.println(userMapper.selectOne(new User(2, null, null, null, null))); }
运行结果:
User{userId=2, userName='建军', userGender='男', userAddress='上海', userBirthday=Tue Jan 14 00:00:00 CST 2020}
4.10 delete 方法
-
说明:根据实体属性作为条件进行删除,查询条件使用等号
-
注意:如果所有实体属性都为空,会删除表中所有记录
-
实例:
@Test public void testDelete() {User user = new User(null, "小美", null, null, null);userMapper.delete(user); }
4.11 deleteByPrimaryKey 方法
-
说明:根据主键字段进行删除,方法参数必须包含完整的主键属性
-
实例:
@Test public void testDeleteByPrimaryKey() {userMapper.deleteByPrimaryKey(14); }
5. Example 方法
Mybatis 的逆向工程中会生成实例及实例对应的 example,example 用于添加条件,相当 where 后面的部分
5.1 selectByExample 方法
-
说明:根据 Example 条件进行查询
-
实例:
/*** 相当于:select * from table_user where (user_address = "北京") or (user_name like "%王%");*/ @Test public void testSelectByExample() {// 1. 创建 Example 对象Example example = new Example(User.class);// 2. 通过 Example 对象创建 Criteria 对象Example.Criteria criteria1 = example.createCriteria();Example.Criteria criteria2 = example.createCriteria();// 3. 在两个 Criteria 对象中分别设置查询条件criteria1.andEqualTo("userAddress","北京");criteria2.andLike("userName","%王%");// 4. 使用 or 关键词组装两个 Criteria 对象example.or(criteria2);// 5. 执行查询List<User> users = userMapper.selectByExample(example);for (User user : users) {System.out.println(user);} }
运行结果:
User{userId=1, userName='张三', userGender='男', userAddress='北京', userBirthday=Wed Jan 15 00:00:00 CST 2020} User{userId=3, userName='王五', userGender='女', userAddress='广州', userBirthday=Sun Jan 12 00:00:00 CST 2020}
5.2 selectCountByExample 方法
-
说明:根据 Example 条件进行查询总数
-
实例:
/*** 相当于:select COUNT(*) from table_user where user_gender = "男";*/ @Test public void testSelectCountByExample() {Example example = new Example(User.class);Example.Criteria criteria = example.createCriteria();criteria.andEqualTo("userGender", "男");System.out.println(userMapper.selectCountByExample(example)); }
运行结果:
3
5.3 updateByExample 方法
-
说明:根据 Example 条件更新实体包含的全部属性,null 值会被更新
-
实例:
/*** 相当于:update table_user set user_name = "小红",user_gender = null,user_address = null,user_birthday = null where user_id = 7;*/ @Test public void testUpdateByExample() {User user = new User(null, "小红", null, null, null);Example example = new Example(User.class);Example.Criteria criteria = example.createCriteria();criteria.andEqualTo("userId", 7);userMapper.updateByExample(user, example);System.out.println(userMapper.selectOne(user)); }
运行结果:
User{userId=7, userName='小红', userGender='null', userAddress='null', userBirthday=null}
5.4 updateByExampleSelective 方法
-
说明:根据 Example 条件更新实体包含的不是 null 的属性值
-
实例:
/*** 相当于:update table_user set user_name = "小花" where user_id = 3;*/ @Test public void testUpdateByExampleSelective() {User user = new User(null, "小花", null, null, null);Example example = new Example(User.class);Example.Criteria criteria = example.createCriteria();criteria.andEqualTo("userId", 3);userMapper.updateByExampleSelective(user,example);System.out.println(userMapper.selectOne(user)); }
运行结果:
User{userId=3, userName='小花', userGender='女', userAddress='广州', userBirthday=Sun Jan 12 00:00:00 CST 2020}
5.5 deleteByExample 方法
-
说明:根据 Example 条件删除数据
-
实例:
/*** 相当于:delete from table_user where user_name = "小红";*/@Testpublic void testDeleteByExample() {Example example = new Example(User.class);Example.Criteria criteria = example.createCriteria();criteria.andEqualTo("userName","小红");userMapper.deleteByExample(example);}```
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- 第一行代码之文件存储
使用工具Android Studio 3.5.3 首先我找不到Tools->Android,需要通过其他方式找到Android Device Monitor。双击monitor.bat即可。(其中AppData是隐藏文件,要在用户名后输入。) 参考自https://blog.csdn.net/qq_39284848/article/details/79770142(侵删) 但是无法打开data文…...
2024/5/3 4:53:09 - 聚类算法(三)
8.特征降维 1)降维:就是在某些限定条件下,降低随机变量个数,得到一组“不相关”主变量的过程。 2)降维的两种方式特征选择 主成分分析1.特征选择 1.1 定义: 数据中包含冗余或无关变量,从原有特征中找出主要特征。 1.2 方法:Filter(过滤式):主要探究特征本身特点、特…...
2024/5/8 14:32:04 - 数独_单元测试
单元测试主要分为4部分,数独生成模块的测试,main函数的测试,...
2024/3/29 15:12:32 - Caused by: org.gradle.api.resources.ResourceException: Could not get resource...
我的具体报错如下:Caused by: org.gradle.api.resources.ResourceException: Could not get resource ‘https://jcenter.bintray.com/com/google/guava/guava/23.0/guava-23.0.jar’ 我是因为将AS从3.1.2升级到了3.5.3才出现了这个错误。 处理方法: 在根目录下的gradle中加入…...
2024/4/19 17:43:42 - 高度自适应输入框的清晰解题思路
前言 业务开发中,经常会遇到文本输入框高度随着输入内容高度变化的情况,下面我们来详细说明一下实现这种输入框的方案和解题思路方案一为一种扩展思路,仅供参考 方案二为常规思路,急着用的小伙伴建议直接看二 第三个板块 附上了react native和react native to web的代码实现…...
2024/3/29 15:12:30 - MATLAB强化学习入门——二、网格迷宫、Q-learning算法、Sarsa算法
一、多步决策问题和网格迷宫 上一篇文章里讨论多臂赌机问题是单步最优决策问题的对应模型。而在这之后,则可以考虑离散的多步决策问题。离散的多步决策问题,对应的典型问题模型则是网格迷宫(Grid World)。 前文中,ε-greedy策略,softmax策略的原理及其特点得到了讨论。而这…...
2024/4/29 20:45:19 - java核心:运算符
java的运算符和c语言基本一样,都是从上到下,从左到右运行 算术运算符 加+,减-,乘*,除/,取余%,注意整型和整型运算得出的结果也是整型,像10除以3得到的是整数3,而不是3.3333…的小数,不只是整型是这样,其他的也是,以此类推。 字符和字符串参与的加法运算 加号两边是…...
2024/3/29 15:12:28 - 真机安装centos7
真机安装centos7 第一步:下载iso文件 中科大镜像: http://centos.ustc.edu.cn/centos/7/isos/ 清华大学镜像:http://mirror.tuna.tsinghua.edu.cn/centos/7/isos/ 第二步:制作U盘启动盘 本文所使用的是软碟通工具,操作步骤如下 在菜单栏上找到"文件"—>“…...
2024/4/14 0:02:58 - Routing模块之A*搜索算法
Routing模块之A*搜索算法 Routing模块的结果是Planning模块生成参考线的基础,也就是通常所说的全局路径规划,Routing模块中除了对地图的抽象处理为可供搜索的topo地图,以及通过KDtree生成黑名单地图外核心算法是通过A* 算法生成全局路径,本文这里主要介绍Routing模块中如何…...
2024/3/29 15:12:26 - C++17标准在windows和 Linux环境下更新使用【补充】
dll的生成,基本上根据下面的步骤可以生成,这儿需要主要一个问题。https://www.toutiao.com/i6672956378023199243/如果dll给别人用,不希望别人看到源码,则需要将下面【生成调试信息】修改为否,否则调试过程中是可以看到源码的。如果dll给自己调试用,那么设置为 是 方便调…...
2024/3/29 15:12:25 - 我发现了一个Java特别有意思的问题,请大佬们过来看看
今天学习了java的接口,在练习中发现了一个特别有意思的问题,希望可以和大家一起讨论一下,请看源代码: interface A{public double more(); } interface B{public void more(); }public class Test implements A,B{//怎么实现?}我既要使用A接口中的方法,也要使用B接口中的方法,…...
2024/3/29 6:54:12 - 集合
集合 一、集合框架图(图片来源于网络)这是两个集合框架接口的总体图分为两个集合接口,分别是Collection接口和map接口 二、collection集合接口 下面的接口主要有:List、Set、Queue; (1)Queue接口与List、Set同一级别,都是继承了Collection接口。 (2)LinkedList既可以…...
2024/3/29 6:54:10 - 位运算小记
位运算符 算术移位与逻辑移位 位运算的应用理解并记住...
2024/3/29 6:54:09 - 「Python网络编程」如果让蔡徐坤同时唱跳rap篮球/初识多线程(二)
博主前言:通过第一篇文章的学习,读者已经认识了网络编程中的套接字编程,已经具备了实现基于TCP协议和基于UDP协议网络编程中客户端的实现。第二篇文章打算让读者感受一下多线程的魅力,通过仔细阅读本篇文章完全可达到一文入门多线程的目的。1. 几个基本概念 1.1 单核CPU与多…...
2024/3/29 6:54:08 - 一次程序修改记录
起因 最近在做《C Primer Plus》第六版的课后编程题学习C语言。在做P174第2题时遇到了一个问题,就是代码我认为写得没有问题,但是编译运行后出现的不是我想要的结果,找了很久终于找到了问题所在,在此做一个记录。 问题描述 使用嵌套循环,按下面的格式打印字符。 $ $$ $$$ …...
2024/3/29 6:54:08 - html/css面试题(3)
一、一次完整的HTTP事务是怎么一个过程 域名解析 --> 发起TCP的3次握手 --> 建立TCP连接后发起http请求 --> 服务器响应http请求,浏览器得到html代码 --> 浏览器解析html代码,并请求html代码中的资源(如js、css、图片等) --> 浏览器对页面进行渲染呈现给用户…...
2024/3/29 6:54:06 - 一个流氓软件(文本管控客户端)的实现
【管控客户端第2版】项目概况背景项目来源:2019 深度软件开发大赛项目名称:文件管控客户端运行环境deepin Linux x86_64 系统,理论上也兼容其他 x86_64 Linux 系统条件与限制区分服务端与客户端,一般运行在不同的机器上 正式的运行环境是N(N>=2)台计算机节点,通过有线或…...
2024/3/29 6:54:05 - 什么是同构渲染
首先写一个React 16的 remderToNodeStream方法的使用。 // An highlighted block var foo = bar;import express from experss; import React from react; import { renderToNodeStream } from react-dom/server; import App from ../shanred/App;const app = express();app.us…...
2024/3/29 6:54:04 - Python定时任务APScheduler框架
文章目录1. 安装2. 四大组件3. 调度器4. 触发器5. 实例5.1 触发器date(特定时间点执行一次)5.2 触发器interval :周期任务 1. 安装 pip install apscheduler 2. 四大组件触发器triggers: 用于设定触发任务的条件 任务存贮器job store: 用于存放任务, 把任务存放在内存或数据…...
2024/3/29 15:12:24 - A+B 输入输出练习I
题目描述 你的任务是计算a+b。这是为了acm初学者专门设计的题目。你肯定发现还有其他题目跟这道题的标题类似,这些问题也都是专门为初学者提供的。 输入 输入包含一系列的a和b对,通过空格隔开。一对a和b占一行。 输出 对于输入的每对a和b,你需要依次输出a、b的和。 如对于输…...
2024/3/29 15:12:24
最新文章
- QX---mini51单片机学习---(6)独立键盘
目录 1键盘简绍 2按键的工作原理 3键盘类型 4独立键盘与矩阵键盘的特点 5本节相关原理图 6按键特性 7实践 1键盘简绍 2按键的工作原理 内部使用轻触按键,常态按下按键触点才闭合 3键盘类型 编码键盘与非编码键盘 4独立键盘与矩阵键盘的特点 5本节相关原理…...
2024/5/10 12:33:11 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/5/9 21:23:04 - 探索进程控制第一弹(进程终止、进程等待)
文章目录 进程创建初识fork函数fork函数返回值fork常规用法fork调用失败的原因 写时拷贝进程终止进程终止是在做什么?进程终止的情况代码跑完,结果正确/不正确代码异常终止 如何终止 进程等待概述进程等待方法wait方法waitpid 进程创建 初识fork函数 在…...
2024/5/9 18:30:09 - 【干货】零售商的商品规划策略
商品规划,无疑是零售业的生命之源,是推动业务腾飞的强大引擎。一个精心策划的商品规划策略,不仅能帮助零售商在激烈的市场竞争中稳固立足,更能精准捕捉客户需求,实现利润最大化。以下,我们将深入探讨零售商…...
2024/5/10 0:24:47 - 【外汇早评】美通胀数据走低,美元调整
原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...
2024/5/8 6:01:22 - 【原油贵金属周评】原油多头拥挤,价格调整
原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...
2024/5/9 15:10:32 - 【外汇周评】靓丽非农不及疲软通胀影响
原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...
2024/5/4 23:54:56 - 【原油贵金属早评】库存继续增加,油价收跌
原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...
2024/5/9 4:20:59 - 【外汇早评】日本央行会议纪要不改日元强势
原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...
2024/5/4 23:54:56 - 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响
原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...
2024/5/4 23:55:05 - 【外汇早评】美欲与伊朗重谈协议
原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...
2024/5/4 23:54:56 - 【原油贵金属早评】波动率飙升,市场情绪动荡
原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...
2024/5/7 11:36:39 - 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试
原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...
2024/5/4 23:54:56 - 【原油贵金属早评】市场情绪继续恶化,黄金上破
原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...
2024/5/6 1:40:42 - 【外汇早评】美伊僵持,风险情绪继续升温
原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...
2024/5/4 23:54:56 - 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势
原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...
2024/5/8 20:48:49 - 氧生福地 玩美北湖(上)——为时光守候两千年
原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...
2024/5/7 9:26:26 - 氧生福地 玩美北湖(中)——永春梯田里的美与鲜
原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...
2024/5/4 23:54:56 - 氧生福地 玩美北湖(下)——奔跑吧骚年!
原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...
2024/5/8 19:33:07 - 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!
原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...
2024/5/5 8:13:33 - 「发现」铁皮石斛仙草之神奇功效用于医用面膜
原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...
2024/5/8 20:38:49 - 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者
原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...
2024/5/4 23:54:58 - 广州械字号面膜生产厂家OEM/ODM4项须知!
原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...
2024/5/10 10:22:18 - 械字号医用眼膜缓解用眼过度到底有无作用?
原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...
2024/5/9 17:11:10 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下: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