方法:
~~~
M()
->table("user")
->alias('数据表别名')
->distinct(true)
->field($field,false) #指定查询字段 第二个参数为true是排除的字段排除
->where($where,$parse='null 预处理参数')
->join('LEFT JOIN wy_userinfo ON wy_userinfo.uid = wy_user.id','INNER')
->order('id asc,status')
->limit($offset,$length=null)
->page('页数','每页数量')
->group()
->having()
->union('SELECT name FROM think_user_1',false) #true为union all
->union('SELECT name FROM think_user_2',false)
->lock(true) #排他锁 FOR UPDATE当一个事务的操作未完成时,其他事务可以读取但是不能写入或更新.
->cache('cache_name',60,'File') #查询缓存 对于及时性要求不高的数据查询 最简单cache(true)
#第一个参数默认true如果指定了key的话,则可以在外部通过S方法直接获取内容,例如:
# = S('cache_name');
->fetchSql(true) #获取执行的SQL语句
->comment('查询注释')
->strict(true) # true时当出现不合法字段时直接报错,而不是默认的剔除
->index('user') # 强制索引
->using($using) # USING支持 用于多表删除
->auto() # 一般和create连用
->validate() # 一般和create连用
->token() # 一般和create连用
#连贯操作(可多次调用?)完!
->filter() #???
->result()
->force()
->scope($scope='',$args=NULL) #调用命名范围
->setProperty($name,$value) #设置模型的属性值
->bind($key,$value=false) #手动参数绑定 自动绑定:'DB_BIND_PARAM' => true
->flush(); #获取字段信息并缓存
->add($data='',$options=array(),$replace=false);
->addAlladdAll($dataList,$options=array(),$replace=false);
->selectAdd($fields='',$table='',$options=array()); #通过Select方式添加记录
->save();
->delete();
->select();
->find();
->buildSql(); #等于>fetchSql(true)->select() 生成查询SQL 可用于子查询
->parseFieldsMap(); #手动处理字段映射('READ_DATA_MAP'=>false 的情况下)
->setInc('age',1); #自增
->setDec('age',1); #自减
->setField('email','a@qq.com'); #设置一条记录的某个字段值
->getField('email'); #获取一条记录的某个字段值
->autoCheckToken($data); #动表单令牌验证
->regex($value,$rule); #内置正则规则验证数据
->check($value,$rule,'regex'); #验证数据支持 in between equal length regex expire ip_allow ip_deny
->db($linkNum,$config,false) #切换当前的数据库连接
->execute($sql,$parse=false); #执行SQL语句
->query($sql,$parse=false); #SQL查询
->procedure($sql,$parse=false); #存储过程返回多数据集
->parseSql($sql,$parse); #解析SQL语句
->getLastInsID(); #返回最后插入的ID
->_sql(); #getLastSql
->getDbFields(); #获取数据表字段信息
->getPk(); #获取主键名称
->getTableName(); #得到完整的数据表名
->getModelName(); #得到当前的数据对象名称
->startTrans();
->commit(); #提交事务
->rollback();
->getError(); #返回模型的错误信息
->getDbError(); #返回数据库的错误信息
create:
~~~
field() #用于定义合法的字段
\->token(false) #create 一起 临时关闭token验证
\->auto() #用于数据自动完成
\->validate($data) #用于数据自动验证
\->create();
属性
~~~
/ 操作状态
const MODEL_INSERT = 1; // 插入模型数据
const MODEL_UPDATE = 2; // 更新模型数据
const MODEL_BOTH = 3; // 包含上面两种方式
const MUST_VALIDATE = 1; // 必须验证
const EXISTS_VALIDATE = 0; // 表单存在字段则验证
const VALUE_VALIDATE = 2; // 表单值不为空则验证
// 当前数据库操作对象
protected $db = null;
// 数据库对象池
private $_db = array();
// 主键名称
protected $pk = 'id';
// 主键是否自动增长
protected $autoinc = false;
// 数据表前缀
protected $tablePrefix = null;
// 模型名称
protected $name = '';
// 数据库名称
protected $dbName = '';
//数据库配置
protected $connection = '';
// 数据表名(不包含表前缀)
protected $tableName = '';
// 实际数据表名(包含表前缀)
protected $trueTableName = '';
// 最近错误信息
protected $error = '';
// 字段信息
protected $fields = array();
// 数据信息
protected $data = array();
// 查询表达式参数
protected $options = array();
protected $_validate = array(); // 自动验证定义
protected $_auto = array(); // 自动完成定义
protected $_map = array(); // 字段映射定义
protected $_scope = array(); // 命名范围定义
// 是否自动检测数据表字段信息
protected $autoCheckFields = true;
// 是否批处理验证
protected $patchValidate = false;
// 链操作方法列表
protected $methods = array('strict','order','alias','having','group','lock','distinct','auto','filter','validate','result','token','index','force');
~~~
- 目录结构与基础
- 修改数据后页面无变化
- 防跨目录设置
- input
- 系统目录
- 自动生成的文件以及目录
- 类自动加载
- url生成
- 数据增删改查
- 增加数据
- 数据更新
- 数据删除
- 数据查询
- 架构
- 生命周期
- 入口文件
- URL访问规则
- 配置
- 默认惯例配置配置
- 初始应用配置
- 路由
- 域名路由
- URL生成
- 数据库操作
- 方法列表
- 连接数据库
- 分布式数据库
- 查询构造器
- 查询数据
- 添加数据
- 更新数据
- 删除数据
- 查询语法
- 聚合查询(统计)
- 时间查询
- 高级查询
- 视图查询
- 子查询
- 辅助查询之链式操作
- where
- table
- alias
- field
- order
- limit
- page
- group
- having
- join
- union
- distinct
- lock
- cache
- comment
- fetchSql
- force
- bind
- partition
- strict
- failException
- sequence(pgsql专用)
- 查询事件
- 事务操作
- 监听SQL
- 存储过程
- 数据集
- 控制器
- 跳转和重定向
- 空控制器和空操作
- 分层控制器
- Rest控制器
- 资源控制器
- 自动定位控制器
- tp3的增删改查
- 方法注入
- 模型
- 属性方法一览
- 类方法详解
- Model
- 调用model不存在的属性
- 调用model中不存在的方法
- 调用model中不存在的静态方法
- hasOne
- belongsTo
- hasMany {Relation}
- belongsToMany
- hasManyThrough
- morphMany
- morphOne
- morphTo
- ::hasWhere {Query}
- ::has
- relationCount
- data 【model】
- setInc {integer|true}
- setDec {integer|true}
- save {integer | false}
- saveAll {array}
- delete {integer}
- ::get 查询单条数据 {Model}
- ::all 查询多条数据{Model [ ]}
- ::create 新增单条数据 {Model}
- ::update 更新单条数据 {Model}
- ::destroy {integer}
- ::scope {Query}
- getAttr {mixed}
- xxx
- append
- appendRelationAttr
- hidden
- visible
- except
- readonly
- auto
- together
- allowField
- isUpdate
- validate
- toCollection
- toJson
- toArray
- 定义
- 新增
- 更新
- 查询
- 删除
- 聚合
- 获取器
- 修改器
- 时间戳
- 只读字段
- 软删除
- 类型转换
- 数据完成
- 查询范围
- 模型分层
- 数组访问和转换
- JSON序列化
- 事件
- 关联
- 一对一关联
- 主表一对一关联
- 从表一对一关联(相对关联)
- 一对多关联
- 主表定义一对多关联
- 从表定义一对多关联
- 远程一对多
- 多对多关联
- 多态关联
- 动态属性
- 关联预载入with()
- 关联统计
- N+1查询
- 聚合模型
- Model方法集合
- 表单验证
- 验证器
- 验证规则
- 错误信息
- 验证场景
- 控制器验证
- 模型验证
- 内置规则
- 静态调用
- 表单令牌
- Token身份令牌
- 视图
- 模版
- 变量输出
- 函数输出
- Request请求参数
- 模板注释及原样输出
- 三元运算
- 内置标签
- 模板继承
- 模板布局
- 日志
- 日志初始化
- 日志驱动
- 日志写入
- 独立日志
- 日志清空
- 写入授权
- 自定义日志
- 错误和调试
- 异常
- php系统异常及thinkphp5异常机制
- 异常处理
- 抛出异常
- 异常封装
- resful
- 404页面
- 调试模式
- Trace调试
- SQL调试
- 变量调试
- 性能调试
- 远程调试
- 安全
- 输入安全
- 数据库安全
- 上传安全
- 其它安全建议
- xss过滤
- 扩展
- 函数
- 类库
- 行为
- 驱动
- Composer包
- Time
- 数据库迁移工具
- Workerman
- MongoDb
- htmlpurifier XSS过滤
- 新浪SAE
- oauth2.0
- 命令行及生成文件
- 系统现成命令
- 创建类库文件
- 生成类库映射文件
- 生成路由缓存
- 清除缓存文件
- 生成配置缓存文件
- 生成数据表字段缓存
- 自定义命令行
- 开始
- 调用命令
- 杂项
- 助手函数
- URL重写
- 缓存
- 缓存总结
- Session
- Cookie
- 多语言
- 分页
- 上传
- 验证码
- 图像处理
- 文件处理
- 单元测试
- 自定义表单令牌