2017-08-29 56 views
0

我正在开展我的unilevel多层次营销。Codeigniter获取推荐用户并给予奖励

现在我可以成功介绍的用户,向他们展示如下:

我的水平

1级由我称之为=成员 2级=成员通过我的1级用户 3级简称=构件通过我的2级用户 LEVE 4 =构件通过我的3级用户称为称为

我的问题是,如果“第4级”的任何的用户的下称为新会员

它看起来像这样。

::Level 1:: ::Level 2:: ::Level 3:: ::Level 4:: 
- user_1  - user_2 - user_3  - user_4 

如果 “user_4” 下的第4级提到一个新成员..

我需要给100名奖励奖金user_3,user_2和USER_1。

注:将收到奖励的唯一用户是用户 谁提到用户从4级到2级

USER_1简称user_2,user_2简称user_3和user_3简称 user_4

所以user_3下来USER_1将收到奖励......

+1

向我们显示您的代码。堆栈溢出不是代码写入服务。 –

回答

0

你可以存储上线水平,你的用户表了。在注册期间,您可以获取上线,然后上线等,以便稍后在查询用户表时获取它们。

我这样做6级深,所以它是6个更多的查询,但我真的不在乎,注册不会发生一天一百万次。

enter image description here

这里是从我的流量交换我的用户表...希望它帮助。正如你所看到的,我还使用upline_val列来存储冲浪积分,稍后可以通过他们的上线声明一个按钮“从推介中索取积分”。

和注册模型代码来创建成员:

$data = array(
     'username' => $username, 
     'password' => password_hash($password, PASSWORD_DEFAULT), 
     'email' => $email, 
     'first_name' => $first_name, 
     'last_name' => $last_name, 
     'active' => $active, 
     'referred_by_id' => $referred_by_id, 
     'referral_url' => $this->session->userdata('referral_url'), 
     'next_subscription_update' => $now->format("Y-m-d H:i:s"), 
     'email_newsletter' => $newsletter, 
     'autoassign_pct' => Settings_model::$db_config['autoassign_value'] 
); 
    // select upline ids 
    $this->db->select('referred_by_id')->from(DB_PREFIX .'user')->where('user_id', $data['referred_by_id']); // $data['referred_by_id'] is passed in the url e.g. http://example.com/register/1867 
      $q = $this->db->get(); 

     if ($q->num_rows() == 1) { 
      $data['upline_lvl2'] = $q->row()->referred_by_id; 
      $this->db->select('referred_by_id')->from(DB_PREFIX .'user')->where('user_id', $data['upline_lvl2']); 
      $q = $this->db->get(); 

      if ($q->num_rows() == 1) { 
       $data['upline_lvl3'] = $q->row()->referred_by_id; 
       $this->db->select('referred_by_id')->from(DB_PREFIX .'user')->where('user_id', $data['upline_lvl3']); 
       $q = $this->db->get(); 

       if ($q->num_rows() == 1) { 
        $data['upline_lvl4'] = $q->row()->referred_by_id; 
        $this->db->select('referred_by_id')->from(DB_PREFIX .'user')->where('user_id', $data['upline_lvl4']); 
        $q = $this->db->get(); 

        if ($q->num_rows() == 1) { 
         $data['upline_lvl5'] = $q->row()->referred_by_id; 
         $this->db->select('referred_by_id')->from(DB_PREFIX .'user')->where('user_id', $data['upline_lvl5']); 
         $q = $this->db->get(); 

         if ($q->num_rows() == 1) { 
          $data['upline_lvl6'] = $q->row()->referred_by_id; 
         } 
        } 
       } 
      } 
     } 

// ...etc... 

$this->db->insert(DB_PREFIX .'user', $data); // $data is inserted here 

这是对所有我能做的,我猜。