鍍金池/ 問答/ PHP問答
萢萢糖 回答

連接

node-sass經(jīng)常有出現(xiàn)安裝的問題,鏈接是之前遇到的一種現(xiàn)象,可以參考

心癌 回答

你chunkFilename那里寫死了呀,你可以手動設(shè)置chunkFilename的hash值

output: {
    ...
    chunkFilename: 'js/[name].chunk.js?id=[chunkhash:20]'
}
未命名 回答

DELETE FROM MyTable WHERE ID IN (1,2);

若相惜 回答

你可以select md5(id) as id查出來就是id了

孤巷 回答

tp是thinkphp的簡寫,你如果覺得安裝php麻煩,去下載集成包,如wamp,xampp,phpstudy等。

陌離殤 回答

說下個人目前在用的分布

Controller:接受Web請求,分發(fā)調(diào)用不同的邏輯或服務(wù)完成一項事情,返回數(shù)據(jù)
service:做些服務(wù)Api接口相關(guān)的代碼
dao:和數(shù)據(jù)庫打交道(對表進行增刪改查)
logic:自己的業(yè)務(wù)邏輯相關(guān)

現(xiàn)在有個PC注冊賬號的功能
  1:初始階段,controller收到請求,直接在controler里面寫數(shù)據(jù)庫連接,進行增刪改查,沒毛病,可以運行。
  2:慢慢發(fā)展,功能多了,Controller多起來了,contoller到處都是sql和數(shù)據(jù)庫打交道的代碼,雖然不影響運行,但是有時候發(fā)現(xiàn),如果我要修改一個數(shù)據(jù)表的字段或其他東西,得到好幾個Controller里面去找相同的一個代碼并修改,太麻煩了,干脆都放到一個里面,全部對增刪改查從同一個地方多好,這時候出現(xiàn)了dao層。
  3:繼續(xù)發(fā)展,進軍移動端,有了手機注冊的功能,簡單,寫唄,寫著寫著發(fā)現(xiàn),我去,怎么和PC注冊功能這么像?都要校驗用戶信息->判斷數(shù)據(jù)庫有無重復(fù)->插入數(shù)據(jù)庫(重復(fù)的業(yè)務(wù)功能在幾個控制器都要被重復(fù)使用),有了第二步的經(jīng)驗,把這些相同的業(yè)務(wù)操作抽離放到一起唄,出現(xiàn)了logic層(logic層負(fù)責(zé)做些處理并調(diào)用dao層完成數(shù)據(jù)的入庫等和數(shù)據(jù)庫打交道的事情),RegisterLogic,規(guī)定所有的注冊功能都走這一個邏輯了,維護更加方便了,以后即使增加一百種注冊方式,只要 new RegisterLogic()->register();就行了。
  4:繼續(xù)發(fā)展下去,公司有聲有色的,老板說,網(wǎng)站太無聊了,加點天氣預(yù)報,隨機推送笑話的附屬功能吧,這行功能不屬于自己的系統(tǒng)的業(yè)務(wù)邏輯,更具第二步和第三步的經(jīng)驗,應(yīng)該單獨放一個地方,沒準(zhǔn)以后其他的地方會用到,這時候service層就出現(xiàn)了。
  
檸檬藍 回答
func (d *scanner)ChunksAsCPUNumber()  {
    var divided [][]string
    counts := d.Count()
    CPUNum := runtime.NumCPU()
    size := (counts + CPUNum - 1) / CPUNum

    for i := 0; i < counts; i += size {
        end := i + size

        if end > counts {
            end = counts
        }

        divided = append(divided, d.Files[i:end])
    }

    fmt.Printf("%#v\n", divided)
}
任她鬧 回答

首先說明一下你的標(biāo)題和函數(shù)功能不符,應(yīng)該是:

如何高效把order.user.name解析為$data['order']['user']['name']


下面的代碼較為惡心,看看就好,謹(jǐn)慎使用,謹(jǐn)慎使用,謹(jǐn)慎使用

/**
 * @param $str
 * @param $data
 * @return null|mixed
 * @throws Exception
 */
function parse($str, &$data)
{
    $str = trim($str);
    if (empty($str)) {
        throw new \Exception("str is empty");
    }
    $fields= explode('.', $str);
    switch (count($fields)) {
        case 1:
            return $data[$fields[0]] ?? null;
        case 2:
            return $data[$fields[0]][$fields[1]] ?? null;
        case 3:
            return $data[$fields[0]][$fields[1]][$fields[2]] ?? null;
        case 4:
            return $data[$fields[0]][$fields[1]][$fields[2]][$fields[3]] ?? null;
        case 5:
            return $data[$fields[0]][$fields[1]][$fields[2]][$fields[3]][$fields[4]] ?? null;
        case 6:
            return $data[$fields[0]][$fields[1]][$fields[2]][$fields[3]][$fields[4]][$fields[5]] ?? null;
        default;
            // 大仙你的數(shù)組超過6級了,是不是考慮優(yōu)化一下代碼 ^_^
            throw new \Exception("str key too long");
    }
}
陪她鬧 回答

建議全部轉(zhuǎn)為utf8mb4編碼。

ALTER TABLE <table_name> CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
孤巷 回答

配置中把dsn設(shè)為空試一下

笨笨噠 回答

看看php.ini 是不是安裝opcache了

蝶戀花 回答

先理清表之間的關(guān)系,及各字段的含義,然后再進行操作
建議將表結(jié)構(gòu)及個字段含義,目標(biāo)結(jié)果貼下

深記你 回答

那就改權(quán)限唄
sudo chmod -R 755 /public/download/

心癌 回答

那是連接查詢的的連接條件啊,怎么能去掉呢?除非你不用連接查詢

怣痛 回答

建議分3個:

用戶關(guān)鍵信息表:姓名、學(xué)號、登錄名、密碼、班級、系、學(xué)院、專業(yè)、登陸時間、登陸ip...等登陸及需要查詢的信息
用戶基本信息表:出生日期、學(xué)生圖片、培養(yǎng)方向、專業(yè)方向等基本信息
用戶拓展信息表:準(zhǔn)考證號、銀行卡、原畢業(yè)學(xué)校、等不是很重要的信息

真難過 回答

使用下面的 python 腳本,你可以輕松實現(xiàn)多開

# -*- coding: utf-8 -*-
'''
同時運行多個進程,用法:
    python3 xx.py <進程數(shù)量> <進程啟動參數(shù)>


@author: 李毅
'''
import asyncio
from argparse import ArgumentParser, ArgumentDefaultsHelpFormatter, REMAINDER


async def single(wid, cmd):
    p = await asyncio.create_subprocess_exec(*cmd)
    print('#{} pid={} 已經(jīng)啟動'.format(wid, p.pid))
    await p.communicate()
    print('#{} pid={}, 代碼={} 已經(jīng)結(jié)束'.format(wid, p.pid, p.returncode))


async def main(loop, args):
    if not args.worker or not len(args.cmd):
        return
    ps = [single(i, args.cmd) for i in range(args.worker)]
    return await asyncio.gather(*ps)


if __name__ == '__main__':
    parser = ArgumentParser(formatter_class=ArgumentDefaultsHelpFormatter)
    parser.add_argument('worker', type=int, help='進程數(shù)')
    parser.add_argument('cmd', nargs=REMAINDER, help='命令參數(shù),例如: "sleep 30"')
    loop = asyncio.get_event_loop()
    loop.run_until_complete(main(loop, parser.parse_args()))

舉例:同時開啟 10 個 ping -c4 baidu.com 進程

python3 a.py 3 ping -c4 baidu.com

輸出如下

PING baidu.com (123.125.115.110) 56(84) bytes of data.
#1 pid=137 已經(jīng)啟動
#2 pid=138 已經(jīng)啟動
#0 pid=139 已經(jīng)啟動
PING baidu.com (220.181.57.216) 56(84) bytes of data.
PING baidu.com (123.125.115.110) 56(84) bytes of data.
64 bytes from 123.125.115.110 (123.125.115.110): icmp_seq=1 ttl=52 time=38.0 ms
64 bytes from 220.181.57.216 (220.181.57.216): icmp_seq=1 ttl=55 time=36.3 ms
64 bytes from 123.125.115.110 (123.125.115.110): icmp_seq=1 ttl=52 time=38.0 ms
64 bytes from 123.125.115.110 (123.125.115.110): icmp_seq=2 ttl=52 time=37.9 ms
64 bytes from 220.181.57.216 (220.181.57.216): icmp_seq=2 ttl=55 time=36.2 ms
64 bytes from 123.125.115.110 (123.125.115.110): icmp_seq=2 ttl=52 time=37.6 ms
64 bytes from 123.125.115.110 (123.125.115.110): icmp_seq=3 ttl=52 time=37.9 ms
64 bytes from 220.181.57.216 (220.181.57.216): icmp_seq=3 ttl=55 time=36.1 ms
64 bytes from 123.125.115.110 (123.125.115.110): icmp_seq=3 ttl=52 time=37.8 ms
64 bytes from 123.125.115.110 (123.125.115.110): icmp_seq=4 ttl=52 time=37.9 ms

--- baidu.com ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3002ms
rtt min/avg/max/mdev = 37.916/37.955/38.024/0.199 ms
64 bytes from 220.181.57.216 (220.181.57.216): icmp_seq=4 ttl=55 time=36.1 ms

--- baidu.com ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3004ms
rtt min/avg/max/mdev = 36.113/36.218/36.374/0.254 ms
#1 pid=137, 代碼=0 已經(jīng)結(jié)束
#2 pid=138, 代碼=0 已經(jīng)結(jié)束
64 bytes from 123.125.115.110 (123.125.115.110): icmp_seq=4 ttl=52 time=37.7 ms

--- baidu.com ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3004ms
rtt min/avg/max/mdev = 37.647/37.818/38.060/0.249 ms
#0 pid=139, 代碼=0 已經(jīng)結(jié)束
任她鬧 回答

一般等一會就好了,這是網(wǎng)站在部署新主題。
如果等十幾分鐘還進不去,進服務(wù)器重置一下主題就好了

傻叼 回答

一樓說的情況針對同一個庫里面可以這樣搞,二樓說的我想應(yīng)該可以滿足你的需求。通過數(shù)據(jù)庫中間件來實現(xiàn)