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方法…...
SpringBoot-17-MyBatis动态SQL标签之常用标签
文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…...
【磁盘】每天掌握一个Linux命令 - iostat
目录 【磁盘】每天掌握一个Linux命令 - iostat工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景 注意事项 【磁盘】每天掌握一个Linux命令 - iostat 工具概述 iostat(I/O Statistics)是Linux系统下用于监视系统输入输出设备和CPU使…...
springboot整合VUE之在线教育管理系统简介
可以学习到的技能 学会常用技术栈的使用 独立开发项目 学会前端的开发流程 学会后端的开发流程 学会数据库的设计 学会前后端接口调用方式 学会多模块之间的关联 学会数据的处理 适用人群 在校学生,小白用户,想学习知识的 有点基础,想要通过项…...
Java数值运算常见陷阱与规避方法
整数除法中的舍入问题 问题现象 当开发者预期进行浮点除法却误用整数除法时,会出现小数部分被截断的情况。典型错误模式如下: void process(int value) {double half = value / 2; // 整数除法导致截断// 使用half变量 }此时...
LLMs 系列实操科普(1)
写在前面: 本期内容我们继续 Andrej Karpathy 的《How I use LLMs》讲座内容,原视频时长 ~130 分钟,以实操演示主流的一些 LLMs 的使用,由于涉及到实操,实际上并不适合以文字整理,但还是决定尽量整理一份笔…...
站群服务器的应用场景都有哪些?
站群服务器主要是为了多个网站的托管和管理所设计的,可以通过集中管理和高效资源的分配,来支持多个独立的网站同时运行,让每一个网站都可以分配到独立的IP地址,避免出现IP关联的风险,用户还可以通过控制面板进行管理功…...
MySQL 部分重点知识篇
一、数据库对象 1. 主键 定义 :主键是用于唯一标识表中每一行记录的字段或字段组合。它具有唯一性和非空性特点。 作用 :确保数据的完整性,便于数据的查询和管理。 示例 :在学生信息表中,学号可以作为主键ÿ…...
DeepSeek源码深度解析 × 华为仓颉语言编程精粹——从MoE架构到全场景开发生态
前言 在人工智能技术飞速发展的今天,深度学习与大模型技术已成为推动行业变革的核心驱动力,而高效、灵活的开发工具与编程语言则为技术创新提供了重要支撑。本书以两大前沿技术领域为核心,系统性地呈现了两部深度技术著作的精华:…...
【Linux】Linux安装并配置RabbitMQ
目录 1. 安装 Erlang 2. 安装 RabbitMQ 2.1.添加 RabbitMQ 仓库 2.2.安装 RabbitMQ 3.配置 3.1.启动和管理服务 4. 访问管理界面 5.安装问题 6.修改密码 7.修改端口 7.1.找到文件 7.2.修改文件 1. 安装 Erlang 由于 RabbitMQ 是用 Erlang 编写的,需要先安…...
Linux安全加固:从攻防视角构建系统免疫
Linux安全加固:从攻防视角构建系统免疫 构建坚不可摧的数字堡垒 引言:攻防对抗的新纪元 在日益复杂的网络威胁环境中,Linux系统安全已从被动防御转向主动免疫。2023年全球网络安全报告显示,高级持续性威胁(APT)攻击同比增长65%,平均入侵停留时间缩短至48小时。本章将从…...
