AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / user-18764592

vbulash's questions

Martin Hope
vbulash
Asked: 2025-04-08 21:18:59 +0800 CST

Redigo:XADD 的错误论点

  • 7

我喜欢 Redis 流,因为它可以充当物联网数据库。向流中添加数据的主要 Redis 命令是 XADD:

XADD log * name Some_name_to_write text Some_text_to_write

它运行良好。

然后我尝试使用Redigo执行相同的操作:

type LogEntry struct {
    Name string `json:"name"`
    Text string `json:"text"`
}

func (l *LogEntry) Push() error {
    var args []string // XADD arguments

    log.Printf("Log Entry: %+v\n", l)
    args = make([]string, 6)
    args = append(args, "log") // Stream key
    args = append(args, "*")   // Auto-generated stream ID
    args = append(args, "name", l.Name)
    args = append(args, "text", l.Text)
    log.Printf("Args for XADD: %+v\n", args)

    new := make([]any, len(args))
    for index, value := range args {
        new[index] = value
    }

    _, err := connection.Do("XADD", new...)
    if err != nil {
        log.Println("XADD error", err)
        return err
    }

    return nil
}

connection这里是redis.Conn。

此代码产生以下输出:

2025-04-08 16:03:08 2025/04/08 13:03:08 Log Entry: &{Name:Some_name_to_write Text:Some_text_to_write}
2025-04-08 16:03:08 2025/04/08 13:03:08 Args for XADD: [      log * name Some_name_to_write text Some_text_to_write]
2025-04-08 16:03:08 2025/04/08 13:03:08 XADD error ERR Invalid stream ID specified as stream command argument

因此,我看到的参数与conn.Do我之前在 CLI 中使用的完全相同。

这里出了什么问题?

go
  • 1 个回答
  • 20 Views
Martin Hope
vbulash
Asked: 2025-04-08 01:02:15 +0800 CST

Makefile 条件 `ifeq` - 哪里出错了

  • 5

我的 makefile 是:

LOGGER=Mongo
# Mongo logger
LOGGER_MONGO_BINARY=loggerMongoApp
LOGGER_MONGO_FOLDER=logger-service-mongo
# Redis logger
LOGGER_REDIS_BINARY=loggerRedisApp
LOGGER_REDIS_FOLDER=logger-service-redis

build_logger:
    ifeq ("${LOGGER}", "Mongo")
    LOGGER_BINARY=${LOGGER_MONGO_BINARY}
    LOGGER_FOLDER=${LOGGER_MONGO_FOLDER}
    else ifeq ("${LOGGER}", "Redis")
    LOGGER_BINARY=${LOGGER_REDIS_BINARY}
    LOGGER_FOLDER=${LOGGER_REDIS_FOLDER}
    endif

    @echo Building logger binary (${LOGGER}-based)...
    chdir ..\${LOGGER_FOLDER} \
        && set GOOS=linux \
        && set GOARCH=amd64 \
        && set CGO_ENABLED=0 \
        && go build -o ${LOGGER_BINARY} ./cmd/api
    @echo Done!

在 makefile 中我想要获得条件逻辑。

make build_logger结尾为:

ifeq ("Mongo", "Mongo")
process_begin: CreateProcess(NULL, ifeq (Mongo, Mongo), ...) failed.
make (e=2): ═х єфрхЄё  эрщЄш єърчрээ√щ Їрщы.
make: *** [Makefile:43: build_logger] Error 2

里面的短信内容是“找不到指定的文件”。怎么回事?

makefile
  • 1 个回答
  • 30 Views
Martin Hope
vbulash
Asked: 2025-04-02 14:09:34 +0800 CST

Laravel 查询生成器:通过 from / where 连接表

  • 5

在查询生成器中连接多个表非常简单:

DB::table('projects')
->select('tasks.*')
->join('tasks', 'tasks.project_id', 'projects.id')

但现在客户要求我避免join使用:

SELECT tasks.*
FROM projects, tasks
WHERE tasks.project_id = projects.id

如何做?

使用 Builder 的方法from是个坏主意:

  • from仅接受一个字符串(一个表名),而不是数组
  • from杀死table并from写过

PS 请不要浪费时间描述 Eloquent 的工作原理 - 我只需要知道如何使用 Laravel Query Builder 来实现。当然,如果可以使用 LQB 来实现的话

laravel
  • 2 个回答
  • 59 Views
Martin Hope
vbulash
Asked: 2025-03-29 16:54:18 +0800 CST

Laravel Eloquent:表格聚合

  • 7

我的表格(和 Laravel 模型关系): projects -> tasks -> commands

计算任务数量:

$body = Project->withCount('tasks')->get();

美好的。

然后我想计算所有任务的命令数。 SQL 等效代码为:

select 
    count(commands.*)
from projects
inner join tasks on tasks.project_id = projects.id
inner join commands on commands.task_id = tasks.id

如何通过 Eloquent 获取?由于某些原因,查询生成器不可接受。

不幸的是,witchCount它不够灵活with,我不能使用withCount('tasks.commands')

laravel
  • 1 个回答
  • 29 Views
Martin Hope
vbulash
Asked: 2025-03-28 18:09:14 +0800 CST

Laravel 查询生成器中的参数化查询

  • 5

我在 Laravel 中使用参数化查询:

$objectsSQL = <<<'EOS'
SELECT
    o.id AS oid,
    o.name AS name,
    o.fields AS fields
FROM projects p
JOIN tasks AS t ON t.project_id = p.id
LEFT JOIN commands AS c ON c.task_id = t.id
LEFT JOIN objects AS o ON o.id = c.object_id
WHERE p.id = :pid
GROUP BY o.id, o.name
ORDER BY o.name
EOS;

然后我在循环中使用它$objects = DB::select($objectsSQL, ['pid' => $row->pid]);

现在我想避免使用原始 SQL 并用查询生成器替换它:

$objects = DB::table('projects', 'p')
    ->select(
        'o.id AS oid',
        'o.name AS name',
        'o.fields AS fields'
    )
    ->join('tasks as t', 't.project_id', '=', 'p.id')
    ->leftJoin('commands as c', 'c.task_id', '=', 't.id')
    ->leftJoin('objects as o', 'o.id', '=', 'c.object_id')

    **what to do here to use `:pid`? (WHERE p.id = :pid)**

    ->gropupBy(['o.id', 'o.name'])
    ->orderBy('o.name')

然后如何绑定:pid?

laravel
  • 2 个回答
  • 35 Views
Martin Hope
vbulash
Asked: 2025-01-07 21:13:49 +0800 CST

初始化控制时忽略 Select2 数据

  • 5

我的 HTML 代码是:

<select id="block-permissions" name="permissions" multiple="multiple">
    {{-- <option value="0">Topic 0</option> When uncomment works fine! --}}
</select>

我的 JS 代码是:

    $(function() {
            // const permissions = @json($permissions)
            //
            const permissions = {
                results: [{
                    text: "Group 1",
                    children: [{
                            id: 1,
                            text: "Topic 1",
                            selected: true
                        },
                        {
                            id: 2,
                            text: "Topic 2",
                            selected: true
                        },
                        {
                            id: 3,
                            text: "Topic 3",
                            selected: false
                        }
                    ]
                }]
            }

            $('#block-permissions').select2({
                data: permissions,
            })
        })

Select2 控件仅适用于主题 0(预定义 HTML 数据),但完全忽略 JS 数据。

怎么了?

jquery
  • 1 个回答
  • 23 Views
Martin Hope
vbulash
Asked: 2024-10-12 20:21:27 +0800 CST

Laravel 单例 - 如何只有一个实例

  • 6

尝试获取真正的 Laravel 单例:

  • 服务等级:
<?php

namespace App\Services;

use Illuminate\Support\Facades\Log;

class SingleTest
{
    public function __construct(
        public string $var
    ) {
        Log::info('init instance');
    }
}
  • 将此服务注册为单例:
<?php

namespace App\Providers;

use App\Services\SingleTest;
use Illuminate\Support\ServiceProvider;

class AppServiceProvider extends ServiceProvider
{
    public function register(): void
    {
        $this->app->singleton(SingleTest::class, fn() => new SingleTest('test singleton'));
    }
}
  • 我的检查路线(web.php):
Route::get('/test1', fn() => app(SingleTest::class)->var);
Route::get('/test2', fn() => app(SingleTest::class)->var);

然后我 curl /test1 和 /test2 路由:

  • 卷曲打印test singleton两次 - 很好。
  • 根据日志,我期望构造函数仅被调用一次并init instance出现一次。不,我看到 2 条消息,这意味着也创建了 SingleTest 的第二个实例。它不是单例。
laravel
  • 1 个回答
  • 26 Views
Martin Hope
vbulash
Asked: 2024-09-13 03:59:22 +0800 CST

如何从 Dockerfile 引用另一个 Docker 服务[重复]

  • 4
此问题这里已有答案:
php artisan migration 命令放在哪里 (5 个答案)
10 小时前关闭。

我在 docker-compose.yml 中有 2 个服务(这里是摘录;文件大部分由 Laravel Sail 生成):

services:
    laravel.test:
        build:
            context: .
            dockerfile: ./docker/8.3/Dockerfile
            args:
                WWWGROUP: '${WWWGROUP}'
        image: 'sail-8.3/app'
        extra_hosts:
            - 'host.docker.internal:host-gateway'
        ports:
            - '800:80'
            - '${VITE_PORT:-5173}:${VITE_PORT:-5173}'
        environment:
            WWWUSER: '${WWWUSER}'
            LARAVEL_SAIL: 1
        volumes:
            - '.:/var/www/html'
        networks:
            - sail
        depends_on:
            - pgsql
    pgsql:
        image: 'postgres:15'
        ports:
            - '${FORWARD_DB_PORT:-5432}:5432'
        environment:
            ...
        volumes:
            - 'sail-pgsql:/var/lib/postgresql/data'
            - './docker/pgsql/create-testing-database.sql:/docker-entrypoint-initdb.d/10-create-testing-database.sql'
        networks:
            - sail
networks:
    sail:
        driver: bridge

此处引用的 Dockerfile 在结尾附近包含以下几行:

COPY --link . /var/www/html
WORKDIR /var/www/html
RUN php artisan migrate --seed

不幸的是,迁移以错误结束: SQLSTATE[08006] [7] could not translate host name "pgsql" to address: Name or service not known

服务laravel.test依赖于pgsql服务,因此它知道服务。但是 Dockerfilelaravel.test似乎有另一个范围并且看不到服务pgsql,对吗?

docker 中是否存在进行迁移的方法?

laravel
  • 1 个回答
  • 33 Views
Martin Hope
vbulash
Asked: 2024-08-25 01:29:22 +0800 CST

Laravel 抽象模型实现

  • 5

实现抽象基础模型以供以后实现:

abstract class AbstractNode extends Model
{
    use HasFactory;

    protected static function boot(): void
    {
        static::creating(static function (self $model) {
            //
        });
        static::deleting(static function (self $model) {
            //
        });
    }

    abstract public function getTitle(): string;
    abstract public function getAllowedChildren(): ?array;
}

然后实例化这个基础模型:

class Region extends AbstractNode
{
    protected $fillable = [
        'name', // Region name
    ];

    public function getTitle(): string
    {
        return 'Region';
    }

    public function getAllowedChildren(): ?array
    {
        return null;
    }
}

使用Regionclass as$region = new Region();会导致致命错误:

Undefined array key "App\Models\Region"

当我将 Region 编码为扩展 Model 而不是 AbstractNode 时,一切正常。

是否可以使用抽象模型类?

laravel
  • 1 个回答
  • 23 Views
Martin Hope
vbulash
Asked: 2024-05-12 01:35:02 +0800 CST

Laravel HTTP 客户端:真实的多部分示例

  • 5

不幸的是,Laravel 文档(此处)中的多部分示例仅包含具有一个字段(附加文件)的示例 - Http::attach('file', $file_content)。

它不是来自现实世界 - 在大多数情况下,多部分请求包含多个字段。

如何通过 HTTP 客户端创建具有多个字段的多部分请求,其中数组提供等效值?

laravel
  • 1 个回答
  • 24 Views
Martin Hope
vbulash
Asked: 2024-04-10 15:43:26 +0800 CST

Laravel 模型在仅附加属性时嵌入嵌套模型

  • 6

需要将计算属性附加到模型中:

class Field extends Model {
//...
    protected $appends = ['typename'];
//...
    public function getTypenameAttribute(): string {
        return $this->type->name;
    }
}

模型转储向我显示以下内容:

{
    "id": "9bc5b05b-46cf-470d-a848-cdb60aec2213",
    "name": "Показание термометра",
    "default": true,
    "twin_id": "9bc5b05b-3df3-4efd-8ce0-7a30be87af72",
    "type_id": "9bc3cea3-47e6-4ef2-a78f-347d51abbe3d",
    "created_at": "2024-04-10T07:21:36.000000Z",
    "updated_at": "2024-04-10T07:21:36.000000Z",
    "deleted_at": null,
    "origin": "thermo",
    "typename": "Целочисленное без знака",
    "type": {
      "id": "9bc3cea3-47e6-4ef2-a78f-347d51abbe3d",
      "name": "Целочисленное без знака",
      "influx_type": "uint",
      "created_at": "2024-04-09T08:54:37.000000Z",
      "updated_at": "2024-04-09T08:54:37.000000Z",
      "deleted_at": null
    }
  }

typename计算好了。但我不想包含嵌套type对象。我的模型类不包含任何$with,所以这个对象完全出乎意料。

如何从转储中排除这个嵌套对象?

laravel
  • 1 个回答
  • 15 Views
Martin Hope
vbulash
Asked: 2023-11-14 15:53:54 +0800 CST

React 切换状态仅触发一次

  • 5

沙箱中的根标签App如下所示:

import React from 'react'
import { useState, useCallback } from 'react'

export default function App() {
    let [dark, setDark] = useState(true)

    const toggleDark = useCallback(() => {
        setDark(!dark)
    }, []);

    return (
        <main>
            <p onClick={toggleDark}>{dark ? 'dark mode' : 'light mode'}</p>
        </main>
    )
}

初始页面内容-“深色模式”。

按下它,更改为“灯光模式”。

再次按“灯光模式”-没有任何变化。似乎应用程序的状态只改变了一次。

如何在每次单击 <p> 时强制更改状态?

您可以在Replit 沙盒中查看完整示例

javascript
  • 2 个回答
  • 32 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    重新格式化数字,在固定位置插入分隔符

    • 6 个回答
  • Marko Smith

    为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会?

    • 2 个回答
  • Marko Smith

    VScode 自动卸载扩展的问题(Material 主题)

    • 2 个回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Martin Hope
    Fantastic Mr Fox msvc std::vector 实现中仅不接受可复制类型 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant 使用 chrono 查找下一个工作日 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor 构造函数的成员初始化程序可以包含另一个成员的初始化吗? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský 为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul C++20 是否进行了更改,允许从已知绑定数组“type(&)[N]”转换为未知绑定数组“type(&)[]”? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann 为什么 {2,3,10} 和 {x,3,10} (x=2) 的顺序不同? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve