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中,可以使用where方法来添加查询条件,但是每次添加where条件时,都会在查询构造器中持久化这些条件,直到你手动重置它们。所以,如果你想在下一次查询中清除上次查询的where条件,有以下几种选择&…...
C++根据如下使用类MyDate的程序,写出类MyDate的定义,MyDate中有三个数据成员:年year,月month,日day完成以下要求
题目: 根据如下使用类MyDate的程序,写出类MyDate的定义,MyDate中有三个数据成员: 年year,月month,日day int year,month,day; void main() { MyDate d1, d2; d1.set(2015, 12, 31); d2.set(d1); d1.…...
微盟集团中报增长稳健 重点发力智慧零售AI赛道
零售数字化进程已从渠道构建走向了用户的深度运营。粗放式用户运营体系无法适应“基于用户增长所需配套的精细化运营能力”,所以需要有个体、群体、个性化、自动化运营——即在对的时候、以对的方式、把对的内容推给用户。 出品|产业家 2023年已经过半,经济复苏成为…...
设计模式(7)模板方法模式
一、定义: 定义一个操作中的算法骨架,而将算法的一些步骤延迟到子类中,使得子类可以不改变该算法结构的情况下重定义该算法的某些特定步骤。它是一种类行为型模式。 //模板方法抽象类 public abstract class AbstractClass {//模板方法publ…...
2308C++协程流程9
参考 #include <协程> #include "简异中.cpp" //用来中文定义的.元<类 T>构 P;元<类 T>构 任务{用 承诺型P<T>;任务()默认;动 符号 协待()常 无异{构 等待器{极 直接协()常 无异{中 p.是准备好();}协柄 挂起协(协柄<>o)常 无异{p.连续…...
基于学习交流社区的自动化测试实现
一 项目介绍 项目名称 项目名称: 学习交流社区 项目介绍 项目介绍: 学习交流社区是一个基于Spring的前后端分离的在线论坛系统。使用了MySQL数据库来存储相关信息,项目完成后使用Xshell将其部署到云服务器上。 前端页面: 前端共由…...
2023-08-21力扣每日一题
链接: 2337. 移动片段得到字符串 题意: L可以和左边的_交换,R可以和右边的_交换,求判断A是否能通过交换(不限次数)变成B 解: 观察可知,如果存在RL,一定不能交换出LR,…...
对象存储服务-MinIO基本集成
是什么 MinIO 是一个高性能的分布式对象存储服务,适合存储非结构化数据,如图片,音频,视频,日志等。对象文件最大可以达到5TB。 安装启动 mkdir -p /usr/local/minio cd /usr/local/minio# 下载安装包 wget https:/…...
Yarn介绍及快速安装 - Debian/Ubuntu Linux
1.Yarn介绍 Yarn 是一个用于管理 JavaScript 包的快速、可靠和安全的包管理器。它是由 Facebook、Google、Exponent 和 Tilde 团队共同开发的,旨在提供比 npm 更快速、可靠的包管理体验。 以下是 Yarn 的一些主要特点和优势: 快速安装:Yarn…...
【新日语(2)】第10課 中国の生活に慣れるかどうか少し心配です
第10課 中国の生活に慣れるかどうか少し心配です 注释: ~かどうか:“是否”。 练习A 一、例句 田中さんは鈴木さんに、30分ぐらい遅れると言いました。 田中先生告诉铃木先生,他会迟到大约30分钟。 注释: &…...
Python 网页解析初级篇:BeautifulSoup库的入门使用
在Python的网络爬虫中,网页解析是一项重要的技术。而在众多的网页解析库中,BeautifulSoup库凭借其简单易用而广受欢迎。在本篇文章中,我们将学习BeautifulSoup库的基本用法。 一、BeautifulSoup的安装与基本使用 首先,我们需要使…...
Spring Schedular 定时任务
大家好 , 我是苏麟 , 今天带来定时任务的实现 . Spring网站 : 入门 |计划任务 (spring.io) 什么是定时任务 通过时间表达式来进行调度和执行的一类任务被称为定时任务 定时任务实现 1.Spring Schedule (Spring boot 默认整合了) 2.Quartz(独立于Spring 存在的定时任务框架…...
营业额统计
营业额统计 # 题目描述 Tiger 最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况。 Tiger 拿出了公司的账本,账本上记录了公司成立以来每天的营业额。分析营业情况是一项相当复杂的工作。由于节假日&…...
使用lodash的throttle函数会触发两次
当使用lodash的throttle函数时会触发两次,分别在最开始和最后。 严格来说不算是bug,因为官方文档写的很清楚。throttle函数其实有三个参数: _.throttle(func, [wait0], [options]) func: 要节流的函数 wait: 等待时间 options: 选项 op…...
如何使用CSS实现一个瀑布流布局?
聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 使用CSS实现瀑布流布局⭐ 写在最后 ⭐ 专栏简介 前端入门之旅:探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带你启航前端之旅 欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚…...
dfs之有重复字符串的排列组合
https://leetcode.cn/problems/permutation-ii-lcci/description/ ■ 题目描述 考古问题,假设以前的石碑被打碎成了很多块,每块上面都有一个或若干个字符,请你写个程序来把之前石碑上文字可能的组合全部写出来,按升序进行排列。…...
Java之抽象类
Java之抽象类 抽象类概念抽象类如何使用抽象类的特性 作者简介: zoro-1,目前大一,正在学习Java,数据结构等 作者主页:zoro-1的主页 欢迎大家点赞 👍 收藏 ⭐ 加关注哦!💖Ὁ…...
“无Internet连接但是可以上网” 解决全流程
先说我的最后解决方法: 修改注册表下\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\NlaSvc\Parameters\Internet下 的 EnableActiveProbing 项:将 1 改成 0 为什么要解决“无Internet连接但是可以上网”这个问题? 因为虽然可以上百…...
VS2022 CMake报错解决小结
目录 一、问题背景 二、问题分析 三、问题解决 一、问题背景 VS2022中能够跨平台的工程类型就是CMake项目,一套代码能跨windows/Linux/Mac多种操作系统。而实际使用时,发现相关资料比较少,需要摸索一下。 碰到的问题简述: 1、C…...
java之webservice_aegis.xml学习
开门见山,直奔主题,让我们先来看一个接口: public interface UserInfo {public Collection findRoleInfosByUserID(String userUniqueID);public User findUserInfosByUserID(String userUniqueID);public String test();} 观察此接口,首先我们看findRoleInfosByUserID方法…...
wan2.1-vae开源可部署:支持国产操作系统(麒麟/UOS)的适配方案
wan2.1-vae开源可部署:支持国产操作系统(麒麟/UOS)的适配方案 1. 平台介绍 muse/wan2.1-vae 文生图是基于 Qwen-Image-2512 模型的AI图像生成平台,支持中英文提示词,可生成高质量、高分辨率的图像。该平台特别针对国…...
Java面试如何突击?核心知识点有哪些?该如何准备拿下offer?
一、Java 面试核心知识点(按考察优先级排序)1. Java 基础面向对象:封装、继承、多态(重载与重写)、抽象类与接口的区别。String 系列:String 不可变性、StringBuilder 与 StringBuffer 的区别、常量池。集合…...
Linux 内核模块编程入门
Linux 内核模块编程入门 内核模块的重要性 作为科技创业者,我深刻理解内核模块在系统开发中的灵活性和强大功能。内核模块允许我们在不重新编译整个内核的情况下,动态地添加或移除功能。这种机制不仅加快了开发迭代速度,还为产品定制化提供了…...
基于python视频弹幕情感分析 视频可视化 短视频推荐系统 协同过滤推荐算法
1、项目介绍 技术栈: Python语言、Flask框架、 requests爬虫、协同过滤推荐算法、sqlite数据库、bilibili数据、前台后台 B站数据采集分析、推荐与可视化分析系统是一个强大的工具,它利用Python语言、Flask框架、requests爬虫技术、协同过滤推荐算法以及…...
ChatClient 全家桶保姆级博客讲解
最近 Spring AI 迭代很快,从原来的 ChatModel 转向了更易用的 ChatClient API。如果你看到这串名词:ChatClient、default、Options、Functions、Tools、System&User、Advisors,肯定会说好多名词啊。不急,慢慢来。一、先搞懂&a…...
保姆级教程:手把手教你将若依(RuoYi)项目从Java 8迁移到Java 17(含Spring Boot 3升级)
保姆级教程:手把手教你将若依(RuoYi)项目从Java 8迁移到Java 17(含Spring Boot 3升级) 最近几年Java生态发生了翻天覆地的变化,从Java 8到Java 17不仅仅是版本号的跳跃,更是一次技术栈的全面革新。作为国内广泛使用的…...
如何快速掌握终端数字雨效果:完整跨平台配置指南
如何快速掌握终端数字雨效果:完整跨平台配置指南 【免费下载链接】cmatrix Terminal based "The Matrix" like implementation 项目地址: https://gitcode.com/gh_mirrors/cm/cmatrix 想在终端中重现《黑客帝国》电影里的经典数字雨场景吗…...
GitHub Desktop中文汉化工具:让Git操作变得像聊天一样简单
GitHub Desktop中文汉化工具:让Git操作变得像聊天一样简单 【免费下载链接】GitHubDesktop2Chinese GithubDesktop语言本地化(汉化)工具 项目地址: https://gitcode.com/gh_mirrors/gi/GitHubDesktop2Chinese 还在为GitHub Desktop满屏的英文而头疼吗&#x…...
FPGA状态机实战:用Verilog实现自动售卖机(附三段式完整代码)
FPGA状态机实战:用Verilog实现自动售卖机(附三段式完整代码) 在数字电路设计中,状态机是最核心的设计思想之一。它能够将复杂的控制逻辑分解为有限的状态和状态之间的转换,使得设计更加清晰、可维护。自动售卖机作为一…...
5个高效实用的英雄联盟工具集使用指南
5个高效实用的英雄联盟工具集使用指南 【免费下载链接】League-Toolkit 兴趣使然的、简单易用的英雄联盟工具集。支持战绩查询、自动秒选等功能。基于 LCU API。 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit League-Toolkit是一款基于LCU API开发的开源…...
