当前位置: 首页 > news >正文

laravel 多次查询请求,下次请求清除上次请求的where 条件

在Laravel中,可以使用`where`方法来添加查询条件,但是每次添加`where`条件时,都会在查询构造器中持久化这些条件,直到你手动重置它们。所以,如果你想在下一次查询中清除上次查询的`where`条件,有以下几种选择:

1. 使用`getQuery`方法:
可以使用`getQuery`方法获取查询构造器的实例,并使用`wheres`属性来获取所有`where`条件,然后使用`reset`方法重置条件。


$query = Model::where('column1', 'value1')->orWhere('column2', 'value2');
// 获取查询构造器实例
$builder = $query->getQuery();
// 清除所有 where 条件
$builder->wheres = [];

2. 创建新的查询构造器实例:

$query = Model::query(); // 创建新的查询构造器实例
$query = $query->where('column1', 'value1')->orWhere('column2', 'value2');
// 下一次查询时,创建新的查询构造器实例
$query = Model::query();

3. 使用闭包:

$query = Model::query();
$query = $query->where(function ($query) {$query->where('column1', 'value1')->orWhere('column2', 'value2');
});
// 下一次查询时,不添加任何条件
$query = Model::query();

4.如果你想清空某个字段的查询条件,可以使用`getQuery`方法获取查询构造器的实例,并使用`wheres`属性来获取所有的`where`条件,然后遍历条件数组,找到需要清空的条件并删除。

以下是一个示例代码片段,演示如何清空某个字段的查询条件:

$query = Model::where('column1', 'value1')->where('column2', 'value2')->where('column3', 'value3');
// 获取查询构造器实例
$builder = $query->getQuery();
// 获取所有 where 条件
$wheres = $builder->wheres;// 遍历条件数组
foreach ($wheres as $key => $where) {// 检查条件是否为字段 'column2'if (isset($where['column']) && $where['column'] === 'column2') {// 删除条件unset($wheres[$key]);}
}// 重新设置查询构造器的 wheres 属性
$builder->wheres = $wheres;// 执行查询
$results = $query->get();

在上面的示例中,我们首先获取查询构造器实例,然后获取所有的`where`条件,并遍历条件数组。如果条件的字段等于 `'column2'`,我们就删除该条件。最后,我们重新设置查询构造器的 `wheres` 属性,并执行查询。

请根据你的具体需求修改示例代码,以适应你的查询条件和模型。

 public function likeVisit(Request $request){$userId = $request->user()->id;$params = $request->all();$page = $params['page'] ?? self::PAGE;$limit = $params['limit'] ?? self::LIMIT;$type = $params['type'] ?? 1; //1 我喜欢的 2喜欢我的 3最近来访 4互相喜欢$zSetCache = new ZsetCache();$stringCache = new SysConfigStringCache();$cacheKey = 'Visit:' . $type . '_' . $page . '_' . $limit . '_' . $userId;$stringCache->setKeyParameter([$cacheKey]);$cacheData = $stringCache->get();if ($cacheData) {return $this->success(json_decode($cacheData, 320));} else {$info = ['my_like_user' => [],'like_me_user' => [],'visit_user' => [],'each_like_list' => [],];$myLikeUserIds = UserLike::myLikeUserIds($userId);$likeMeUserIds = UserLike::likeMeUserIds($userId);$eachLikeIds = array_intersect($myLikeUserIds, $likeMeUserIds);//我已经解锁的用户[喜欢我的 最近来访]$myUnLockId = [];if ($type == 2 || $type == 3) {$myUnLockId = UserUnlock::getLockStatus(['user_id' => $userId]);}$select = ['nickname', 'birthday', 'avatar', 'stature', 'location_city_id', 'user_id', 'like_user_id', 'ip'];$query = User::query()->select($select);if ($type == 1) {  //1.我喜欢的$myLike = $query->leftJoin('meet_user_like', 'meet_user.id', '=', 'meet_user_like.like_user_id')->where(['user_id' => $userId, 'meet_user_like.type' => 1])->where('meet_user.status', '<>', User::USER_STATUS_LOG_OFF)->orderBy('meet_user_like.id', 'desc')->offset($page * $limit)->limit($limit)->get();$myLike = !empty($myLike) ? $myLike->toArray() : [];foreach ($myLike as &$item) {$item['each_like'] = in_array($item['like_user_id'], $likeMeUserIds);}$info['my_like_user'] = (new UserLike())->formatUser($myLike);} elseif ($type == 2) { //2.喜欢我的$query = $query->leftJoin('meet_user_like', 'meet_user.id', '=', 'meet_user_like.user_id')->orWhere(function ($query) use ($userId) {$query->where('meet_user.identity_status', 1)->where('meet_user.score', '>', 70)->where('meet_user.status', '<>', User::USER_STATUS_LOG_OFF)->where(['like_user_id' => $userId, 'meet_user_like.type' => 1]);})->orWhere(function ($query) use ($userId) {$query->where('meet_user.status', 1)->where('meet_user.status', '<>', User::USER_STATUS_LOG_OFF)->where(['like_user_id' => $userId, 'meet_user_like.type' => 1]);})->orWhere(function ($query) use ($userId) {$query->where('meet_user.vip_status', 1)->where(['like_user_id' => $userId, 'meet_user_like.type' => 1])->where('meet_user.status', '<>', User::USER_STATUS_LOG_OFF);});//年龄范围if (isset($params['age_min']) && !empty($params['age_min']) && isset($params['age_max']) && !empty($params['age_max'])) {$ageMin = now()->subYears($params['age_max'])->toDateString();$ageMax = now()->subYears($params['age_min'])->toDateString();$query->where('birthday', '>=', $ageMin);$query->where('birthday', '<=', $ageMax);}//城市if (isset($params['location_city_id']) && !empty($params['location_city_id'])) {$query->where('location_city_id', $params['location_city_id']);}//身高if (isset($params['stature_min']) && !empty($params['stature_min']) && isset($params['stature_max']) && !empty($params['stature_max'])) {$query->where('stature', '>=', $params['stature_min']);$query->where('stature', '<=', $params['stature_max']);}//学历if (isset($params['education_level']) && !empty($params['education_level'])) {$query->where('education_level', '>=', $params['education_level']);}$likeMe = $query->orderBy('meet_user_like.id', 'desc')->offset($page * $limit)->limit($limit)->get();$likeMe = !empty($likeMe) ? $likeMe->toArray() : [];foreach ($likeMe as &$item) {$item['each_like'] = in_array($item['user_id'], $myLikeUserIds);$item['lock_status'] = isset($myUnLockId[$item['user_id']]);}$info['like_me_user'] = (new UserLike())->formatUser($likeMe);//销毁动态新增喜欢(红色标记样式)$newLikeMeKey = 'Like:new_like_me_' . $userId;$stringCache->del($newLikeMeKey);} elseif ($type == 3) {//3最近来访//销毁动态新增来访$newVisitMeKey = 'Visit:new_visit_me_' . $userId;$stringCache->del($newVisitMeKey);//阅后即焚,将该成员销毁掉,避免影响新的值比对$visitNumKey = 'Visit:new_visit_num';$zSetCache->zRem($visitNumKey, $newVisitMeKey);//3.最近来访$tomorrow = Carbon::tomorrow()->toDateString();$today = Carbon::today()->toDateString();$yesterday = Carbon::yesterday()->toDateString();$select = ['nickname', 'birthday', 'avatar', 'stature', 'location_city_id', 'user_id', 'visit_num', 'meet_user_visit.created_at as visit_time', 'ip'];//$todayVisitKey = 'Visit:' . 'total_visit_ids_' . $userId;//$todayVisitIds = $zSetCache->zRangeByScore($todayVisitKey, strtotime(date('Y-m-d')), time()); //今日访客ids//$yesterdayVisitIds = $zSetCache->zRangeByScore($todayVisitKey, strtotime(date("Y-m-d", strtotime("-1 day"))), strtotime(date('Y-m-d'))); //昨日访客ids//$historyVisitIds = $zSetCache->zRangeByScore($todayVisitKey, '-inf', strtotime(date("Y-m-d", strtotime("-1 day")))); //历史访客ids$recentVisitData = ['todayVisit' => [],'yesterdayVisit' => [],'historyVisit' => [],];/*$recentVisit = User::query()->select($select)->leftJoin('meet_user_visit', 'meet_user.id', '=', 'meet_user_visit.user_id')->where('visited_id', $userId)->where('avatar', '!=', '') // 过滤掉空头像用户->orWhere(function ($query) use ($userId) {$query->where('meet_user.identity_status', 1)->where('meet_user.score', '>', 70)->where('visited_id', $userId)->where('avatar', '!=', ''); // 附加条件})->orWhere(function ($query) use ($userId) {$query->where('meet_user.status', 1)->where('visited_id', $userId)->where('meet_user.status', '<>', User::USER_STATUS_LOG_OFF)->where('avatar', '!=', ''); // 附加条件})->orWhere(function ($query) use ($userId) {$query->where('meet_user.vip_status', 1)->where('visited_id', $userId)->where('meet_user.status', '<>', User::USER_STATUS_LOG_OFF)->where('avatar', '!=', ''); // 附加条件})->where('meet_user.status', '<>', User::USER_STATUS_LOG_OFF)->orderBy('meet_user_visit.id', 'desc')->offset($page * $limit)->limit($limit)->get();*/$recentVisitQuery = User::query()->select($select)->leftJoin('meet_user_visit', 'meet_user.id', '=', 'meet_user_visit.user_id')->where(['visited_id' => $userId])->where('avatar', '!=', '') //过滤掉空头像用户->where('meet_user.status', '<>', User::USER_STATUS_LOG_OFF) //没有注销的用户->orWhere(function ($query) use ($userId) {$query->where('meet_user.identity_status', 1)->where('meet_user.score', '>', 70)->where('visited_id', $userId)->where('avatar', '!=', ''); // 附加条件})->orWhere(function ($query) use ($userId) {$query->where('meet_user.status', 1)->where('visited_id', $userId)->where('meet_user.status', '<>', User::USER_STATUS_LOG_OFF)->where('avatar', '!=', ''); // 附加条件})->orWhere(function ($query) use ($userId) {$query->where('meet_user.vip_status', 1)->where('visited_id', $userId)->where('meet_user.status', '<>', User::USER_STATUS_LOG_OFF)->where('avatar', '!=', ''); // 附加条件})->orderByDesc('meet_user_visit.created_at');foreach ($recentVisitData as $key => $datum) {if ($key == 'todayVisit') {//今天访客$todayVisit = $recentVisitQuery->where('meet_user_visit.created_at', '>', $today)->where('meet_user_visit.created_at', '<', $tomorrow)->get()->groupBy('user_id');$todayVisit = $todayVisit->isNotEmpty() ? $todayVisit->toArray() : [];$newTodayVisit = [];foreach ($todayVisit as $todayItem) {$visitUser = (array)$todayItem[0];$visitUser['each_like'] = in_array($visitUser['user_id'], $eachLikeIds);$visitUser['lock_status'] = isset($myUnLockId[$visitUser['user_id']]);$newTodayVisit[] = $visitUser;}$recentVisitData['todayVisit'] = (new UserLike())->formatUser($newTodayVisit);//dd($recentVisitData['todayVisit']);} elseif ($key == 'yesterdayVisit') {//昨天//1. 获取查询构造器实例$builder = $recentVisitQuery->getQuery();//2. 获取所有 where 条件$wheres = $builder->wheres;$bindings = $builder->bindings;//3. 遍历条件数组foreach ($wheres as $key => $where) {// 检查条件是否为字段 'column2'if (isset($where['column']) && $where['column'] === 'meet_user_visit.created_at') {//unset($wheres[$key]); // 删除条件if ($wheres[$key]['operator'] == '>') {$wheres[$key]['value'] = $yesterday;$bindings['where'][$key] = $yesterday;} elseif ($wheres[$key]['operator'] == '<') {$wheres[$key]['value'] = $today;$bindings['where'][$key] = $today;}}}//4. 重新设置查询构造器的 wheres 属性$builder->wheres = $wheres;$builder->bindings = $bindings;// 清除所有 where 条件//  $builder->wheres = [];//5. 执行查询$yesterdayVisit = $builder->get()->groupBy('user_id');//$builder = $recentVisitQuery->getQuery();//dd($builder,$builder->bindings);//$yesterdayVisit = $builder->where('meet_user_visit.created_at', '>', $yesterday)->where('meet_user_visit.created_at', '<', $today)->get()->groupBy('user_id');$yesterdayVisit = $yesterdayVisit->isNotEmpty() ? $yesterdayVisit->toArray() : [];$newYesterdayVisit = [];foreach ($yesterdayVisit as $item) {$visitUser = (array)$item[0];$visitUser['each_like'] = in_array($visitUser['user_id'], $eachLikeIds);$visitUser['lock_status'] = isset($myUnLockId[$visitUser['user_id']]);$newYesterdayVisit[] = $visitUser;}$recentVisitData['yesterdayVisit'] = (new UserLike())->formatUser($newYesterdayVisit);//dd( $recentVisitData['yesterdayVisit']);} else {//历史来访//1. 获取查询构造器实例$builder = $recentVisitQuery->getQuery();//2. 获取所有 where 条件$wheres = $builder->wheres;$bindings = $builder->bindings;//3. 遍历条件数组foreach ($wheres as $key => $where) {if (isset($where['column']) && $where['column'] === 'meet_user_visit.created_at') {if ($wheres[$key]['operator'] == '>') {unset($wheres[$key], $bindings['where'][$key]); // 删除条件} else {$wheres[$key]['value'] = $yesterday;$bindings['where'][$key] = $yesterday;}}}//4. 重新设置查询构造器的 wheres 属性$builder->wheres = $wheres;$builder->bindings = $bindings;//5. 执行查询$historyVisit = $builder->get()->groupBy('user_id');// $historyVisit = $recentVisitQuery->withoutGlobalScope('meet_user_visit.created_at')->where('meet_user_visit.created_at', '<', $yesterday)->offset($page * $limit)->limit($limit)->get()->groupBy('user_id');$historyVisit = $historyVisit->isNotEmpty() ? $historyVisit->toArray() : [];$newHistoryVisit = [];foreach ($historyVisit as $item) {$visitUser = (array)$item[0];$visitUser['each_like'] = in_array($visitUser['user_id'], $eachLikeIds);$visitUser['lock_status'] = isset($myUnLockId[$visitUser['user_id']]);$newHistoryVisit[] = $visitUser;}$recentVisitData['historyVisit'] = (new UserLike())->formatUser($newHistoryVisit);//dd( $recentVisitData['historyVisit']);}}//dd($recentVisitData);/*if ($recentVisit->isNotEmpty()) {$recentVisit = $recentVisit->toArray();$recentVisit = (new UserLike())->formatUser($recentVisit);// dd($recentVisit);$visitData = $yesterdayVisitData = $historyVisitData = [];foreach ($recentVisit as $visit) {$visit['each_like'] = in_array($visit['user_id'], $eachLikeIds);$visit['lock_status'] = isset($myUnLockId[$visit['user_id']]);if ($tomorrow > $visit['visit_time'] && $visit['visit_time'] > $today) {//今天访客if (!isset($visitData[$visit['user_id']])) {$visitData[$visit['user_id']] = $visit;$recentVisitData['todayVisit'][] = $visit;}} elseif ($today > $visit['visit_time'] && $visit['visit_time'] > $yesterday) { //昨天if (!isset($yesterdayVisitData[$visit['user_id']])) {$yesterdayVisitData[$visit['user_id']] = $visit;$recentVisitData['yesterdayVisit'][] = $visit;}} elseif ($yesterday > $visit['visit_time']) {if (!isset($historyVisitData[$visit['user_id']])) {$historyVisitData[$visit['user_id']] = $visit;$recentVisitData['historyVisit'][] = $visit;}}}unset($visitData, $yesterdayVisitData, $historyVisitData);}*/$info['visit_user'] = $recentVisitData;unset($recentVisitData);} elseif ($type == 4) { //4互相喜欢//$eachLikeIds = array_intersect($myLikeUserIds, $likeMeUserIds);$select = ['id as like_user_id', 'nickname', 'birthday', 'avatar', 'stature', 'location_city_id', 'ip'];$eachLikeList = User::query()->select($select)->where('meet_user.status', '<>', User::USER_STATUS_LOG_OFF)->whereIn('meet_user.id', $eachLikeIds)->offset($page * $limit)->limit($limit)->get();$eachLikeList = !empty($eachLikeList) ? $eachLikeList->toArray() : [];foreach ($eachLikeList as &$item) {$item['user_id'] = $userId;$item['each_like'] = true;}$info['each_like_list'] = (new UserLike())->formatUser(array_values($eachLikeList));$info['each_like_count'] = count($eachLikeIds);}//缓存1小时//$stringCache->set(json_encode($info, 320));//$stringCache->expire(3600);return $this->success($info);}}

相关文章:

laravel 多次查询请求,下次请求清除上次请求的where 条件

在Laravel中&#xff0c;可以使用where方法来添加查询条件&#xff0c;但是每次添加where条件时&#xff0c;都会在查询构造器中持久化这些条件&#xff0c;直到你手动重置它们。所以&#xff0c;如果你想在下一次查询中清除上次查询的where条件&#xff0c;有以下几种选择&…...

C++根据如下使用类MyDate的程序,写出类MyDate的定义,MyDate中有三个数据成员:年year,月month,日day完成以下要求

题目&#xff1a; 根据如下使用类MyDate的程序&#xff0c;写出类MyDate的定义&#xff0c;MyDate中有三个数据成员&#xff1a; 年year&#xff0c;月month&#xff0c;日day int year,month,day; void main() { MyDate d1, d2; d1.set(2015, 12, 31); d2.set(d1); d1.…...

微盟集团中报增长稳健 重点发力智慧零售AI赛道

零售数字化进程已从渠道构建走向了用户的深度运营。粗放式用户运营体系无法适应“基于用户增长所需配套的精细化运营能力”,所以需要有个体、群体、个性化、自动化运营——即在对的时候、以对的方式、把对的内容推给用户。 出品|产业家 2023年已经过半&#xff0c;经济复苏成为…...

设计模式(7)模板方法模式

一、定义&#xff1a; 定义一个操作中的算法骨架&#xff0c;而将算法的一些步骤延迟到子类中&#xff0c;使得子类可以不改变该算法结构的情况下重定义该算法的某些特定步骤。它是一种类行为型模式。 //模板方法抽象类 public abstract class AbstractClass {//模板方法publ…...

2308C++协程流程9

参考 #include <协程> #include "简异中.cpp" //用来中文定义的.元<类 T>构 P;元<类 T>构 任务{用 承诺型P<T>;任务()默认;动 符号 协待()常 无异{构 等待器{极 直接协()常 无异{中 p.是准备好();}协柄 挂起协(协柄<>o)常 无异{p.连续…...

基于学习交流社区的自动化测试实现

一 项目介绍 项目名称 项目名称&#xff1a; 学习交流社区 项目介绍 项目介绍&#xff1a; 学习交流社区是一个基于Spring的前后端分离的在线论坛系统。使用了MySQL数据库来存储相关信息&#xff0c;项目完成后使用Xshell将其部署到云服务器上。 前端页面&#xff1a; 前端共由…...

2023-08-21力扣每日一题

链接&#xff1a; 2337. 移动片段得到字符串 题意&#xff1a; L可以和左边的_交换&#xff0c;R可以和右边的_交换&#xff0c;求判断A是否能通过交换&#xff08;不限次数&#xff09;变成B 解&#xff1a; 观察可知&#xff0c;如果存在RL,一定不能交换出LR&#xff0c…...

对象存储服务-MinIO基本集成

是什么 MinIO 是一个高性能的分布式对象存储服务&#xff0c;适合存储非结构化数据&#xff0c;如图片&#xff0c;音频&#xff0c;视频&#xff0c;日志等。对象文件最大可以达到5TB。 安装启动 mkdir -p /usr/local/minio cd /usr/local/minio# 下载安装包 wget https:/…...

Yarn介绍及快速安装 - Debian/Ubuntu Linux

1.Yarn介绍 Yarn 是一个用于管理 JavaScript 包的快速、可靠和安全的包管理器。它是由 Facebook、Google、Exponent 和 Tilde 团队共同开发的&#xff0c;旨在提供比 npm 更快速、可靠的包管理体验。 以下是 Yarn 的一些主要特点和优势&#xff1a; 快速安装&#xff1a;Yarn…...

【新日语(2)】第10課 中国の生活に慣れるかどうか少し心配です

第10課 中国の生活に慣れるかどうか少し心配です 注释&#xff1a; &#xff5e;かどうか&#xff1a;“是否”。 练习A 一、例句 田中さんは鈴木さんに、30分ぐらい遅れると言いました。 田中先生告诉铃木先生&#xff0c;他会迟到大约30分钟。 注释&#xff1a; &…...

Python 网页解析初级篇:BeautifulSoup库的入门使用

在Python的网络爬虫中&#xff0c;网页解析是一项重要的技术。而在众多的网页解析库中&#xff0c;BeautifulSoup库凭借其简单易用而广受欢迎。在本篇文章中&#xff0c;我们将学习BeautifulSoup库的基本用法。 一、BeautifulSoup的安装与基本使用 首先&#xff0c;我们需要使…...

Spring Schedular 定时任务

大家好 , 我是苏麟 , 今天带来定时任务的实现 . Spring网站 : 入门 |计划任务 (spring.io) 什么是定时任务 通过时间表达式来进行调度和执行的一类任务被称为定时任务 定时任务实现 1.Spring Schedule (Spring boot 默认整合了) 2.Quartz(独立于Spring 存在的定时任务框架…...

营业额统计

营业额统计 # 题目描述 Tiger 最近被公司升任为营业部经理&#xff0c;他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况。 Tiger 拿出了公司的账本&#xff0c;账本上记录了公司成立以来每天的营业额。分析营业情况是一项相当复杂的工作。由于节假日&…...

使用lodash的throttle函数会触发两次

当使用lodash的throttle函数时会触发两次&#xff0c;分别在最开始和最后。 严格来说不算是bug&#xff0c;因为官方文档写的很清楚。throttle函数其实有三个参数&#xff1a; _.throttle(func, [wait0], [options]) func: 要节流的函数 wait: 等待时间 options: 选项 op…...

如何使用CSS实现一个瀑布流布局?

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 使用CSS实现瀑布流布局⭐ 写在最后 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带你启航前端之旅 欢迎来到前端入门之旅&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚…...

dfs之有重复字符串的排列组合

https://leetcode.cn/problems/permutation-ii-lcci/description/ ■ 题目描述 考古问题&#xff0c;假设以前的石碑被打碎成了很多块&#xff0c;每块上面都有一个或若干个字符&#xff0c;请你写个程序来把之前石碑上文字可能的组合全部写出来&#xff0c;按升序进行排列。…...

Java之抽象类

Java之抽象类 抽象类概念抽象类如何使用抽象类的特性 作者简介&#xff1a; zoro-1&#xff0c;目前大一&#xff0c;正在学习Java&#xff0c;数据结构等 作者主页&#xff1a;zoro-1的主页 欢迎大家点赞 &#x1f44d; 收藏 ⭐ 加关注哦&#xff01;&#x1f496;&#x1f49…...

“无Internet连接但是可以上网” 解决全流程

先说我的最后解决方法&#xff1a; 修改注册表下\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\NlaSvc\Parameters\Internet下 的 EnableActiveProbing 项&#xff1a;将 1 改成 0 为什么要解决“无Internet连接但是可以上网”这个问题&#xff1f; 因为虽然可以上百…...

VS2022 CMake报错解决小结

目录 一、问题背景 二、问题分析 三、问题解决 一、问题背景 VS2022中能够跨平台的工程类型就是CMake项目&#xff0c;一套代码能跨windows/Linux/Mac多种操作系统。而实际使用时&#xff0c;发现相关资料比较少&#xff0c;需要摸索一下。 碰到的问题简述&#xff1a; 1、C…...

java之webservice_aegis.xml学习

开门见山,直奔主题,让我们先来看一个接口: public interface UserInfo {public Collection findRoleInfosByUserID(String userUniqueID);public User findUserInfosByUserID(String userUniqueID);public String test();} 观察此接口,首先我们看findRoleInfosByUserID方法…...

总结 TCP 协议的相关特性

TCP协议段格式: 如图, 端口号: 是其中一个重要的部分,知道端口号才能确认数据交给哪个应用程序(端口号属于传输层的概念). 4位首部长度:4bit表示的范围是0->15,在此处,单位是"4字节",因此,将这里的数值 * 4&#xff0c;才是真正的报头长度,即TCP 报头最大长度,60…...

不负众望~历时4年修炼,这本册子终于成书了(文末赠书)

名字&#xff1a;阿玥的小东东 学习&#xff1a;Python、C/C 主页链接&#xff1a;阿玥的小东东的博客_CSDN博客-python&&c高级知识,过年必备,C/C知识讲解领域博主 目录 精进Spring Boot首选读物 “小册”变“大书”&#xff0c;彻底弄懂Spring Boot 全方位配套资源…...

【校招VIP】java语言考点之垃圾回收算法

考点介绍&#xff1a; 垃圾回收算法是必考题。GC中的垃圾指的是存在于内存中的、不会再被使用的对象。而垃圾回收就是把那些不再被使用的对象进行清除&#xff0c;收回占用的内存空间...... 『java语言考点之垃圾回收算法』相关题目及解析内容可点击文章末尾链接查看&#xff…...

juc概述和Lock接口

目录 一、什么是JUC 1、JUC概述 2、进程与线程 3、线程的状态 4、wait/sleep 的区别 5、并发与并行 6、管程 7、用户线程和守护线程 二、Lock接口 1、Synchronized 使用synchronized实现售票案例 使用synchronized实现增减变量操作 2、什么是 Lock 买票例子使用lo…...

图像降采样的计算原理:F.interpolate INTER_AREA

一、F.interpolate——数组采样操作 torch.nn.functional.interpolate(input, size=None, scale_factor=None, mode=nearest, align_corners=None, recompute_scale_factor=None) 功能:利用插值方法,对输入的张量数组进行上\下采样操作,换句话说就是科学合理地改变数组的尺…...

云上的甜蜜早安:腾讯云云函数助力PHP打造女友专属每日推送

用腾讯云的云函数做一个微信公众号早安&#xff0c;每天定时发送早安给你的女朋友&#xff01; 1.首先我们登录腾讯云&#xff0c;在搜索栏搜索云函数 2.进入云函数&#xff0c;点击立即体验 3.这里我们选择 按照步骤选择 php 4.再就是配置页面&#xff0c;这里我们只需要配…...

Javaweb基础学习(3)

Javaweb基础学习 web核心介绍一、HTTP1.1 HTTP介绍1.2、HTTP请求数据格式1.3、HTTP响应数据格式 二、Tomcat2.1 简介2.2 基本使用2.3 Tomcat配置2.4 Tomcat部署项目2.5 Web项目结构2.6 创建Maven Web项目 三、Servlet3.1、Servlet简介&快速入门3.2 创建Servlet步骤3.3 Serv…...

使用在 Web 浏览器中运行的 VSCode 实现 ROS2 测程法

一、说明 Hadabot是软件工程师学习ROS2和机器人技术的机器人套件。我们距离Hadabot套件的测试版还有一周左右的时间。我们将在本文末尾披露有关如何注册的更多信息。 新的Hadabot套件完全支持ROS2。除了硬件套件外&#xff0c;Hadabot软件环境将主要基于Web浏览器&#xff0c;以…...

快速学习GO语言总结

备注&#xff1a;本博客将自己初步学习GO的总结进行分享&#xff0c;希望大家通过本博客可以在短时间内快速掌握GO的基本程序编码能力&#xff0c;如有错误请留言指正&#xff0c;谢谢&#xff01; 一、初步了解Go语言 &#xff08;一&#xff09;Go语言诞生的主要问题和目标…...

尚硅谷宋红康MySQL笔记 10-18

是记录&#xff0c;我不会记录的特别详细 第10章 创建和管理表 标识符命名规则 数据库名、表名不得超过30个字符&#xff0c;变量名限制为29个只能包含 A–Z, a–z, 0–9, _共63个字符数据库名、表名、字段名等对象名中间不要包含空格同一个MySQL软件中&#xff0c;数据库不能…...

Java 面试题--SpringBoot篇

一、什么是 SpringBoot&#xff1f; Spring Boot 是 Spring 开源组织下的子项目&#xff0c; 是 Spring 组件一站式解决方案&#xff0c;主要是简化 了使用 Spring 的难度&#xff0c;简省了繁重 xml 的配 置&#xff0c;提供了各种启动器&#xff0c;在运行过程中自定 配置,&a…...

GitKraken 详细图文教程

前言 写这篇文章的原因是组内的产品和美术同学&#xff0c;开始参与到git工作流中&#xff0c;但是网上又没有找到一个比较详细的使用教程&#xff0c;所以干脆就自己写了一个[doge]。文章的内容比较基础&#xff0c;介绍了Git内的一些基础概念和基本操作&#xff0c;适合零基…...

ubuntu20.04 root用户下使用中文输入法——root用户pycharm无法用中文输入法问题

因为一些众所不周知的bug&#xff0c;我的pycharm使用apt或者snap安装都不行了&#xff0c;官网下了“绿色版”&#xff0c;运行pycharm.sh也运行不起来&#xff0c;有个java相关环境报错&#xff0c;jre和jdk都装了&#xff0c;还是有点问题&#xff0c;最后尝试发现可以用roo…...

FastDFS与Nginx结合搭建文件服务器,并实现公网访问【内网穿透】

文章目录 前言1. 本地搭建FastDFS文件系统1.1 环境安装1.2 安装libfastcommon1.3 安装FastDFS1.4 配置Tracker1.5 配置Storage1.6 测试上传下载1.7 与Nginx整合1.8 安装Nginx1.9 配置Nginx 2. 局域网测试访问FastDFS3. 安装cpolar内网穿透4. 配置公网访问地址5. 固定公网地址5.…...

嵌入式蓝海变红海?其实是大浪淘沙!

嵌入式是当下热门的职业方向之一&#xff0c;吸引了众多求职者的目光。然而&#xff0c;有人担心大家一拥而上&#xff0c;导致嵌入式就业竞争激烈&#xff0c;找工作难度大。其实&#xff0c;嵌入式行业的竞争并非无法逾越的天堑&#xff0c;也远远没有从蓝海变成红海&#xf…...

【附安装包】Solid Edge2023安装教程最强CAD选择

软件下载 软件&#xff1a;Solid Edge版本&#xff1a;2023语言&#xff1a;简体中文大小&#xff1a;3.85G安装环境&#xff1a;Win11/Win10/Win8/Win7硬件要求&#xff1a;CPU2.0GHz 内存4G(或更高&#xff09;下载通道①百度网盘丨64位下载链接&#xff1a;https://pan.bai…...

494. 目标和

494. 目标和 原题链接&#xff1a;完成情况&#xff1a;解题思路&#xff1a;数组回溯法动态规划 参考代码&#xff1a;数组回溯法__494目标和__动态规划 经验吸取 原题链接&#xff1a; 494. 目标和 https://leetcode.cn/problems/target-sum/description/ 完成情况&#…...

C++学习笔记总结练习:C++编译过程详解

编译和链接的过程 0 概述 程序要运行起来&#xff0c;必须要经过四个步骤&#xff1a;预处理、编译、汇编和链接。接下来通过几个简单的例子来详细讲解一下这些过程。 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-EFwSfKYp-1692237034055)(imag…...

嵌入式设备应用开发(qt界面开发)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】 linux界面开发有很多的方案可以选。比如说lvgl、minigui、ftk之类的。但是,这么多年来,一直屹立不倒的还是qt。相比较其他几种方案,qt支持多个平台,这里面就包括了linux平台。此…...

pytest结合Excel实现接口自动化

前言 我们先来回顾下之前篇章“pytest通过parametrize方法实现数据驱动实战”&#xff0c;主要是通过yaml文件来读取测试用例。而我们用Excel文件存放测试用例又有什么区别呢&#xff1f; 毫无疑问&#xff0c;Pytest自动化测试框架也能读取Excel文件实现数据驱动。 还记得之…...

【LLM数据篇】预训练数据集+指令生成sft数据集

note 在《Aligning Large Language Models with Human: A Survey》综述中对LLM数据分类为典型的人工标注数据、self-instruct数据集等优秀的开源sft数据集&#xff1a;alpaca_data、belle、千言数据集、firefly、moss-003-sft-data多轮对话数据集等 文章目录 note构造指令实例…...

WebDAV之π-Disk派盘 + 一羽记帐

一羽记帐是一款真正让你体验3S极速记账的轻量级APP。针对个人记账,没有花哨冗余的功能。界面美丽、无广告、极速启动、功能全面。一羽记帐功能涵括广,基本可以满足90%人的记账需求。完全无侵入、百分百无广告,无需担心数据安全,所有的操作都不经过任何第三方。 π-Disk派盘…...

ChatGPT:记一次超复杂的KVM桌面系统连接问答记录

​ KVM切换器可以使多台电脑共用键盘&#xff0c;显示器&#xff0c;鼠标&#xff0c;当电脑很多&#xff0c;显示器也是分为主从&#xff0c;需要共用键盘鼠标和音响设备&#xff0c;而买KVM切换器只有2个通道4进2出不满足需求时&#xff0c;就要组合多个KVM使用&#xff0c;大…...

python-docx把dataframe表格添加到word文件中

python-docx把dataframe表格添加到word文件中思路较为简单&#xff1a; 先把dataframe格式转变为table新建一个段落&#xff1a;document.add_paragraph()把table添加到这个段落下方 效果图 示例代码 from docx import Document, oxml import pandas as pd import numpy as …...

Web AP—BOM 浏览器对象模型

代码下载 BOM BOM&#xff08;Browser Object Model&#xff09;即浏览器对象模型&#xff0c;它提供了独立于内容而与浏览器窗口进行交互的对象&#xff0c;其核心对象是 window。 BOM 由一系列相关的对象构成&#xff0c;并且每个对象都提供了很多方法与属性。 BOM 缺乏标…...

Flink分流,合流,状态,checkpoint和精准一次笔记

第8章 分流 1.使用侧输出流 2.合流 2.1 union &#xff1a;使用 ProcessFunction 处理合流后的数据 2.2 Connect &#xff1a; 两条流的格式可以不一样&#xff0c; map操作使用CoMapFunction&#xff0c;process 传入&#xff1a;CoProcessFunction 2.2 BroadcastConnectedSt…...

c# 实现sql查询DataTable数据集 对接SqlSugar ORM

有时候对于已经查询到的数据集&#xff0c;想要进行二次筛选或者查询&#xff0c;还得再查一遍数据库 或者其他的一些逻辑处理不太方便&#xff0c;就想着为什么不能直接使用sql来查询DataTable呢&#xff1f; 搜索全网没找到可用方案&#xff0c;所以自己实现了一个。 主要…...

记一次布尔盲注漏洞的挖掘与分析

在上篇文章记一次由于整型参数错误导致的任意文件上传的漏洞成因的分析过程中&#xff0c;发现menu_id貌似是存在注入的。 public function upload() {$menu_id $this->post(menu_id);if ($id) {$where "id {$id}";if ($menu_id) {$where . " and menu_id…...

C++11 新特性 ---- noexcept

1. 异常 异常通常用于处理逻辑上可能发生的错误 在C98中&#xff0c;提供了一套完善的异常处理机制&#xff0c;直接在程序中将各种类型的异常抛出&#xff0c;从而强制终止程序的运行。 1.1 基本语法 当函数抛出异常时&#xff0c;程序会停止执行&#xff0c;并显示异常信息…...

《Linux运维总结:Centos7.6之OpenSSH7.4p1升级版本至9.4p1》

Centos通过yum升级OpenSSH 在官方支持更新的CentOS版本&#xff0c;如果出现漏洞&#xff0c;都会通过更新版本来修复漏洞。这时候直接使用yum update就可以升级版本。 yum -y update openssh 但是&#xff0c;CentOS更新需要有一段时间&#xff0c;不能在漏洞刚出来的时候就有…...