因为很熟悉DJANGO,所以对TP,要慢慢适应。

1,SQL文件

/*
Navicat MySQL Data Transfer

Source Server         : localhost_3306
Source Server Version : 50505
Source Host           : localhost:3306
Source Database       : thinkphp_inaction

Target Server Type    : MYSQL
Target Server Version : 50505
File Encoding         : 65001

Date: 2019-06-23 20:03:30
*/

;

-- ----------------------------
-- Table structure for c5_post
-- ----------------------------
DROP TABLE IF EXISTS `c5_post`;
CREATE TABLE `c5_post` (
  `post_id` ) unsigned NOT NULL AUTO_INCREMENT,
  `title` ) NOT NULL,
  `content` text NOT NULL,
  `created_at` ) NOT NULL,
  `updated_at` ) NOT NULL,
  `) NOT NULL,
  PRIMARY KEY (`post_id`)
) ENGINE DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of c5_post
-- ----------------------------
');
');

-- ----------------------------
-- Table structure for c5_user
-- ----------------------------
DROP TABLE IF EXISTS `c5_user`;
CREATE TABLE `c5_user` (
  `id` ) NOT NULL AUTO_INCREMENT,
  `username` ) NOT NULL,
  `password` ) NOT NULL,
  `created_at` ) NOT NULL,
  `updated_at` ) NOT NULL,
  PRIMARY KEY (`id`),
  KEY `username` (`username`) USING BTREE
) ENGINE DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of c5_user
-- ----------------------------
');

-- ----------------------------
-- Table structure for c5_user_extra
-- ----------------------------
DROP TABLE IF EXISTS `c5_user_extra`;
CREATE TABLE `c5_user_extra` (
  `id` ) NOT NULL AUTO_INCREMENT,
  `email` ) NOT NULL,
  `qq` ) NOT NULL,
  `) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of c5_user_extra
-- ----------------------------
');

2,Application\Common\Conf\config.php

<?php
return array(
    //'配置项'=>'配置值'
    'DB_TYPE' => 'mysql',
    'DB_HOST' => 'localhost',
    'DB_PORT' => 3306,
    'DB_USER' => 'root',
    'DB_PWD' => 'xxxx',
    'DB_NAME' => 'thinkphp_inaction',
    'DB_PREFIX' => 'c5_'
);

3,Applicaton\Home\Model\UserModel.class.php

<?php
    namespace Home\Model;
    use Think\Model\RelationModel;

    class UserModel extends RelationModel {
        private $denyUserNames = array (
            'admin',
            'administraotr'
        );
        public $_validate = array(
            array('username', 'require', 'user is not empty'),
            array('password', 'require', 'password is not empty', 1, '', 1),
            array('username', '', 'user has existed.', 0, 'unique', 1),
            array('password', '6, 20', 'password length between 6~20', 0, 'length'),
            array('password', '/^\w{6,20}$/', 'password format is error'),
            array('password', 'repassword', 'confirm password is error', 0, 'confirm', 1),
            array('username', 'checkUsername', 'user name is illegal', 0, 'callback'),
        );

        public $_auto = array(
            array('password', 'md5', self::MODEL_BOTH, 'function'),
            array('created_at', 'time', self::MODEL_INSERT, 'function'),
            array('updated_at', 'time', self::MODEL_UPDATE, 'function')
        );

        public $_link = array(
            'extra' => array(
                'mapping_type' => self::HAS_ONE,
                'class_name' => 'UserExtra',
                'foreign_key' => 'user_id',
                'mapping_fields' => 'email, qq'
            ),
            'posts' => array(
                'mapping_type' => self::HAS_MANY,
                'class_name' => 'Post',
                'foreign_key' => 'user_id'
            )
        );

        public function checkUsername($username) {
            foreach ($this->denyUserNames as $u) {
                if (strpos($username, $u) !== false) {
                    return false;
                }
            }
            return true;
        }
    }
?>

4,Applicaton\Home\Model\PostModel.class.php

<?php
/**
 * Created by PhpStorm.
 * User: Sahara
 * Date: 2019/6/23
 * Time: 19:00
 */

namespace Home\Model;
use Think\Model\RelationModel;

class PostModel extends RelationModel {
    public $_link = array(
        'author' => array(
            'mapping_type' => self::BELONGS_TO,
            'class_name' => 'User',
            'foreign_key' => 'user_id',
        )
    );

}

5,Applicaton\Home\Model\PostViewModel.class.php

<?php
/**
 * Created by PhpStorm.
 * User: Sahara
 * Date: 2019/6/23
 * Time: 19:00
 */

namespace Home\Model;
use Think\Model\ViewModel;

class PostViewModel extends ViewModel {
    public $viewFields = array(
        'Post' => array(
            'post_id',
            'title',
            'content',
            'created_at',
            'updated_at'
        ),
        'User' => array(
            'username' => 'author',
            '_on' => 'Post.user_id=User.id'
        )
    );
}

6,Applicaton\Home\Controller\IndexController.class.php

<?php
namespace Home\Controller;
use Home\Model\PostModel;
use Home\Model\PostViewModel;
use Home\Model\UserModel;
use Think\Controller;
class IndexController extends Controller {
    public function index(){
        $user = new UserModel();
        $data = array(
            'username' => 'zhangsan',
            'password' => '111111',
            'repassword' => '111111'
        );
        if (!$user->create($data)) {
            echo $user->getError();
            exit;
        } else {
            $id = $user->add();
            print_r($user->find($id));
        }
        echo 'ok';
    }

    public function posts() {
        $m = new PostViewModel();
        $data = $m->select();
        print_r($data);
    }

    public function posts2() {
        $m = new UserModel();
        $data = $m->relation('extra')->find();
        print_r($data);
    }

    public function posts3() {
        $m = new PostModel();
        $data = $m->relation('author')->find();
        print_r($data);
    }

    public function posts4() {
        $m = new UserModel();
        $data = $m->relation('posts')->find();
        print_r($data);
    }
}

ThinkPHP模型中的HAS_ONE,BELONG_TO,HAS_MANY实践的更多相关文章

  1. thinkphp模型中的获取器和修改器(根据字段名自动调用模型中的方法)

    thinkphp模型中的获取器和修改器(根据字段名自动调用模型中的方法) 一.总结 记得看下面 1.获取器的作用是在获取数据的字段值后自动进行处理 2.修改器的作用是可以在数据赋值的时候自动进行转换处 ...

  2. thinkphp在模型中自动完成session赋值

    相信用过thinkphp的用户都知道thinkphp的模型可以完成很多辅助功能,比 如自动验证.自动完成等,今天在开发中遇到自动完成中需要获取session值 然后自动赋值的功能,具体看代码:clas ...

  3. thinkphp模型事件(钩子函数:模型中在增删改等操作前后自动执行的事件)

    thinkphp模型事件(钩子函数:模型中在增删改等操作前后自动执行的事件) 一.总结 1.通过模型事件(钩子函数),可以在插入更新删除等前后执行一些特定的功能 2.模型事件是写在模型里面的,控制器中 ...

  4. [Asp.net MVC]Asp.net MVC5系列——从控制器访问模型中的数据

    目录 概述 从控制器访问模型中的数据 强类型模型与@model关键字 总结 系列文章 [Asp.net MVC]Asp.net MVC5系列——第一个项目 [Asp.net MVC]Asp.net M ...

  5. 错误之thinkphp模型使用发生的错误

    刚接触thinkphp模型的创建,在创建model类时在这里边声明了类的对象.唉,这是不理解的错误啊.什么叫做实例化模型对象,在控制器里边使用才创建. 模型这里写各种用到的函数. 这里我也体会到了查询 ...

  6. thinkphp模型层Model、Logic、Service讲解

    thinkphp模型层Model.Logic.Service讲解 时间:2014-08-24 15:54:56   编辑:一切随缘   文章来源:php教程网 已阅读:771 次       js特效 ...

  7. ThinkPHP 模型(Model)命名规范

    一个小问题搞了好久:如果数据库的表名中有下划线,那么在用thinkphp做自动完成时注意Model类的命名要变成驼峰法,文件名和类名都要变.( 另外注意:只有使用create方法创建数据时才能调用到自 ...

  8. 浅析Thinkphp框架中运用phprpc扩展模式

    浅析Thinkphp框架中应用phprpc扩展模式 这次的项目舍弃了原来使用Axis2做web服务端的 方案,改用phprpc实现,其一是服务端的thinkphp已集成有该模式接口,其二是phprpc ...

  9. 关联模型中如果condition条件

    在练习中,有一个user表和地址表,一对多的关系. 我的想法是,通过这个关联模型找出这个用户下面默认值字段为1的地址 控制器中 public function index(){ $User = D(' ...

随机推荐

  1. C++ & OpenCV 零散学习总结

    OpenCV中Mat基本用法: Mat类 (Matrix的缩写) 是OpenCV用于处理图像而引入的一个封装类.从功能上讲,Mat类在IplImage结构的基础上进一步增强,并且,由于引入C++高级编 ...

  2. Nodejs接收图片base64格式保存为文件

    base64的形式为“data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0....”:当接收到上边的内容后,需要将data ...

  3. python安装 错误 “User installations are disabled via policy on the machine”

    解决方法一:  1.在运行里输入 gpedit.msc  2.计算机配置管理>>管理模板>>windows组件>>windows Installer>> ...

  4. CSP2019初赛游记

    没想到居然ak了,就纪念一下吧. 这次的联赛,只能说是高三生活的一缕杂音了吧. 这次,我的心态可以说是非常平稳了.毕竟不再会有竞赛生涯的压力,也不会有患得患失的惶恐.不过也许我开考前的放声唱歌惊扰了一 ...

  5. (CSDN迁移)JAVA多线程实现-单线程化线程池newSingleThreadExecutor

    JAVA通过Executors提供了四种线程池,单线程化线程池(newSingleThreadExecutor).可控最大并发数线程池(newFixedThreadPool).可回收缓存线程池(new ...

  6. 【jquery】【jqGrid】设置不能多选

    onSelectAll:function(rowids,statue){ layui.layer.msg("请选择单条记录"); $("#jqGrid").jq ...

  7. 常见GC算法,CMS以及G1的垃圾回收过程,CMS的各个阶段哪两个是Stop the world的,CMS会不会产生碎片,G1的优势。

    常见GC算法 在C/C++中是由程序员自己去申请.管理和释放内存的,因此没有GC的概念.而在Java中,专门有一个用于垃圾回收的后台线程来进行监控.扫描,自动将一些无用的内存进行释放.下面介绍几种常见 ...

  8. 029 SSM综合练习05--数据后台管理系统--订单分页查询

    1.PageHelper介绍 PageHelper是国内非常优秀的一款开源的mybatis分页插件,它支持基本主流与常用的数据库,例如mysql.oracle.mariaDB.DB2.SQLite.H ...

  9. spring Boot 学习(三、Spring Boot与检索)

    一.检索我们的应用经常需要添加检索功能,开源的 ElasticSearch 是目前全文搜索引擎的 首选.他可以快速的存储.搜索和分析海量数据.Spring Boot通过整合Spring Data El ...

  10. C语言 - 可变参数再stm32中的应用

    参考 C 可变参数 | 菜鸟教程 void func(const char* str,...) { ... } func的最后一个参数写成 ... ,表示可变参数, C语言的printf就是类似这种声 ...