谁一开始就是大神?

PHP 第74页

PHP

输出数据库查询出的数组值[2.0]

GraceLion阅读(70)

echo "<pre>";
var_dump($provider1);

输出结果:

array(3) {
    [0] =>
        array(1) {
            'model' =>string(10) "887227-R01"
        }
    [1] =>
        array(1) {
            'model' =>string(10) "882863-R01"
        }
    [2] =>
        array(1) {
            'model' =>string(10) "882863-R04"
        }
}

怎么写输出语句使结果只循环值,如:887227-R01;882863-R01;882863-R04;

dump输出不是这样是哪样?
要改输出样式用foreach+echo,
还有不明白的,去google。
这样搞:
用这个方法ArrayHelper::getColumn就能得到你想要的结果。

请问怎样自义验证码样式?谢谢[2.0]

Lielephant阅读(75)

<?= $form->field($model,’captcha’)->widget(

                     yii\captcha\Captcha::className(),
                     [
                        'template'=>'{input}{image}',
                        'captchaAction'=>'site/captcha',
                        'imageOptions'=>['title'=>'点击换图','alt'=>'点击图',
                                         'style'=>'cursor:pointer']
                     ]); 

?>

怎样设置{input}的样式inputOptions不行了,怎么办!

‘imageOptions’=>[‘title’=>’点击换图’,’alt’=>’点击图’,
这段设置的是图片的样式,
设置验证码输入框样式请用下面:
‘options’ => [
回答的很好 支持下
不错,刚开始一直认为是inputOptions,原来是’options’ => [

插入数据怎么使用replaceinto[2.0]

Bravequeen阅读(78)

求大神指教 我现在操作数据库都是继承ActiveRecord

class UserWeibo extends ActiveRecord
{
	
	public static function tableName()
    {
    	return '{{%user_weibo}}';
    }

    /**
     * 添加
     */
    public function add($data) 
    {
        $this->setAttributes($data, false);

        if(self::find()->where(['id'=>$data['id']])->count() > 0) { //重复关注
            return $this->edit(['id'=>$data['id']], $data);
        }
        return $this->save();
    }
}

现在每次插入前都先判断下是否存在 我想改成用mysql的 replace into 求教应该怎么写

MySQL replace into 有三种形式:
第一种形式类似于insert into的用法,
第二种replace select的用法也类似于insert select,这种用法并不一定要求列名匹配,事实上,MYSQL甚至不关心select返回的列名,它需要的是列的位置。例如,replace into tb1( name, title, mood) select rname, rtitle, rmood from tb2;?这个例子使用replace into从?tb2中将所有数据导入tb1中。
第三种replace set用法类似于update set用法,使用一个例如“SET col_name = col_name + 1”的赋值,则对位于右侧的列名称的引用会被作为DEFAULT(col_name)处理。因此,该赋值相当于SET col_name = DEFAULT(col_name) + 1。
yii2 不支持吗?

model中怎么弄可以表连接

Neoyak阅读(69)

同一页面中由于要用到其他表的字段 跪求在model中表之间连接的方法
以下是报错原因:
The SQL being executed was: SELECT COUNT(*) FROM oc_order_product_return_record INNER JOIN oc_order_part_product ON oc_order_product_return_record.order_part_product_id = oc_order_part_product.order_part_product_id INNER JOIN oc_order_part_product ON oc_order_product_return_record.order_id = oc_order_part_product.order_id

你PO的並不是報錯…. 你PO的是 你執行的 sql語句
你可以在你的 資料庫 sql 把這段貼上去看看就知道跑錯甚麼了
一个表一个Model呗,你Model连了两个表,那还能叫ORM么……

继承ActiveRecord的模型类怎么添加自义属性[2.0]

Slyfrog阅读(78)

用gii自动生成的模型类中的属性都是根据关联的数据表来生成的,例如user表中有三个字段,id,username,password,那么模型类user中会有这三个字段,那现在想自定义一个数据表中没有的属性,比如添加email,那怎么去做呢

Defining Attributes :
http://www.yiiframework.com/doc-2.0/guide-structure-models.html#defining-attributes
复制一个user,改成email ?
做新属性,你参考它现有的格式就行。
具体还得看你想实现什么功能。
private $email;即可啊

同一時間新增資料無法當下抓到新增的筆數

dmEagle阅读(78)

想請問 我用 ab.exe 我的API
API 功能描述 : 這項活動只能新增10筆訂單
於是我使用 sql 抓取活動範圍並 count($order::find()->where(‘xxx’)->all())
看是幾筆

if(count($active) >= 10){
    exit;
    當活動次數達10筆時,停止操作
}

$order = new Order();
$order->xxxx = 'xxx';
$order->save();

我單次單次執行 API 是可行的當執行10次時 因為新增10筆就會停止動作
但是我用 ab 時 一次傳送20筆 他就會跳過~我所限定的新增次數範圍
因為是同一時間傳送了20筆 資料庫無法抓到比數

是有看過 PHP synchronized 同步的範例 但資訊真的很少完全沒有頭緒
想請問大家有甚麼辦法能解決此類的問題
能否 PO 點 example 讓我參考或學習….快吐血了

这样子可能轻松生成上千订单
依赖 mysql count订单量, 在并发情况下 是不可靠的.
除非你加锁, 针对你这种情况, 需要加表级别锁, 还得是WRITE LOCK, 将会引起性能上的极大隐患, 不推荐.
一个简单易行 比较讨巧的办法 是做一个原子性的自增计数, 来帮你控制10个订单的量.
你可以用mysql的自增id特性完成, 他内部维护有轻量的自增锁.
具体做法是: 新建一张表A, 只要一个自增主键即可; 每次请求 都先插入表A一条空数据, 拿到一个自增id, 判断是否大于10即可;
针对你这个情况, 应该足以应付了.
当然 如果使用内存db, 比如redis memcache等, 来实现一个自增计数, 或者一个队列, 就更高效了
http://www.yiichina.com/tutorial/563
这页的教程,yii2 by example这本书很好,你可以过去下载。

namespaceuse作用域问题。[2.0]

Bravequeen阅读(76)

假如说:a.php,定义 namespace yii\a. b.php 里面定义namespace yii\b.我在b.php里面可以使用use yii\a吗?

如果可以的话,那use 的作用域有多广。

再比如说:在同一个服务器上有A站和B站两个网站,A站目录下有上面的a.php ,B站目录下有上面的b.php ,还可以在b.php里面使用use yii\a吗?

一, 第一个问题, 需不需要把文件导入进来?
答案是 : 需要!
但是在各种框架内, 你不会直观的感受到这一点, 因为都实现自动加载了.
早期__autoload 后来 又增强版spl_autoload
现代框架都是遵循composer自动载入标准完成
composer的自动加载标准又和namespace结合了起来, 这个后面补充.
二. 第二个问题, use的作用域是什么, 有多广?
比如 : 同一个服务器上有A站和B站,A站下A\a ,B站有B\b ,还可以在B\b.php里面use A\a吗?`
答案是 : 不知道怎么回答了 = =! 只能说和几个站毫无关系…
在当前请求周期内, 只要先加载到了A\a, 那么随后你都可以use A\a;
这和几个项目没关系, 和文件摆放位置没关系
!!! 只和 当前请求内, 你use的时候 有没有事先声明并include进来有关系;
如果非要说出作用域? 只能看每次请求的实际情况了…
三. 补充
在各种现代框架内(遵循了composer标准的)
一般 只要你use A\a; 就能自动加载进A\a (当然 你确实有声明);
并不用小心翼翼的担心 我use A\a时候, 有没有include进来呀
因为composer就是按照namespace来自动加载类的.
当然并不绝对(未遵循该标准的, composer也提供有自动加载方式)
具体的标准去查一下资料吧 这里就不说了 已经很啰嗦了
了解一下php的语法吧,”use的作用域”这个概念有点”新” :http://php.net/manual/zh/language.namespaces.php

nginx能作为php的生产服务器环境,还能作为哪些语言的?

Kimlove阅读(73)

nginx能作为php的生产服务器环境,还能作为哪些语言的?

只要能实现cgi就行.
所以 理论上讲, 任何一门图灵完备的语言都可以
nginx能作软负载或反向代理,所以理论上后端是什么语言都可以
还可以简单的防护DDOS,WAF防火墙……

登录

找回密码

注册