thinkphp 3.2 model怎么写sql
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了thinkphp 3.2 model怎么写sql相关的知识,希望对你有一定的参考价值。
参考技术A /*** 保存数据
* @access public
* @param mixed $data 数据
* @param array $options 表达式
* @return boolean
*/
public function save($data='',$options=array())
if(empty($data))
// 没有传递数据,获取当前数据对象的值
if(!empty($this->data))
$data = $this->data;
// 重置数据
$this->data = array();
else
$this->error = L('_DATA_TYPE_INVALID_');
return false;
// 数据处理
$data = $this->_facade($data);
if(empty($data))
// 没有数据则不执行
$this->error = L('_DATA_TYPE_INVALID_');
return false;
// 分析表达式
$options = $this->_parseOptions($options);
$pk = $this->getPk();
if(!isset($options['where']) )
// 如果存在主键数据 则自动作为更新条件
if (is_string($pk))
if(isset($data[$pk]))
$where[$pk] = $data[$pk];
elseif (is_array($pk))
// 增加复合主键支持
foreach ($pk as $field)
if(isset($data[$pk]))
$where[$field] = $data[$field];
else
// 如果缺少复合主键数据则不执行
$this->error = L('_OPERATION_WRONG_');
return false;
$options['where'] = $where;
unset($data[$pk]);
else
// 如果没有任何更新条件则不执行
$this->error = L('_OPERATION_WRONG_');
return false;
if(is_array($options['where']) && isset($options['where'][$pk]))
$pkValue = $options['where'][$pk];
if(false === $this->_before_update($data,$options))
return false;
$result = $this->db->update($data,$options);
if(false !== $result && is_numeric($result))
if(isset($pkValue)) $data[$pk] = $pkValue;
$this->_after_update($data,$options);
return $result;
复制代码
复制代码
上面这段代码来自TP的原生代码,注意观察
$options = $this->_parseOptions($options);
if(!isset($options['where']) )
// 如果存在主键数据 则自动作为更新条件
....
else
$this->error = L('_DATA_TYPE_INVALID_');
return false;
复制代码
复制代码
如查用户自行传入Where规则,则会失效!也就是说save只允许使用主键来更新。
我的建议
/**
* 保存数据
* @access public
* @param mixed $data 数据
* @param array $options 表达式
* @return boolean
*/
public function save($data = '', $options = array())
if (empty($data))
// 没有传递数据,获取当前数据对象的值
if (!empty($this->data))
$data = $this->data;
// 重置数据
$this->data = array();
else
$this->error = L('_DATA_TYPE_INVALID_');
return false;
// 数据处理
$data = $this->_facade($data);
if (empty($data))
// 没有数据则不执行
$this->error = L('_DATA_TYPE_INVALID_');
return false;
// 分析表达式
$options = $this->_parseOptions($options);
$pk = $this->getPk();
if (!isset($options['where']))
// 如果存在主键数据 则自动作为更新条件
if (is_string($pk))
if (isset($data[$pk]))
$where[$pk] = $data[$pk];
elseif (is_array($pk))
// 增加复合主键支持
foreach ($pk as $field)
if (isset($data[$pk]))
$where[$field] = $data[$field];
else
// 如果缺少复合主键数据则不执行
$this->error = L('_OPERATION_WRONG_');
return false;
$options['where'] = $where;
unset($data[$pk]);
if (!isset($options['where']))
// 如果没有任何更新条件则不执行
$this->error = L('_OPERATION_WRONG_');
return false;
if (is_array($options['where']) && isset($options['where'][$pk]))
$pkValue = $options['where'][$pk];
if (false === $this->_before_update($data, $options))
return false;
$result = $this->db->update($data, $options);
if (false !== $result && is_numeric($result))
if (isset($pkValue))
$data[$pk] = $pkValue;
$this->_after_update($data, $options);
return $result;
本回答被提问者和网友采纳
thinkphp怎么连接数据库
thinkphp连接数据库的方法:ThinkPHP内置了抽象数据库访问层,把不同的数据库操作封装起来,只需要使用公共的Db类进行操作,而无需针对不同的数据库写不同的代码和底层实现,Db类会自动调用相应的数据库驱动来处理。目前的数据库包括Mysql、SqlServer、PgSQL、Sqlite、Oracle、Ibase、Mongo,也包括对PDO的支持,如果应用需要使用数据库,必须配置数据库连接信息,数据库的配置文件有多种定义方式。
常用的配置方式是在项目配置文件中添加下面的参数:
<?php
//项目配置文件
return array(
//数据库配置信息
'DB_TYPE' => 'mysql', // 数据库类型
'DB_HOST' => 'localhost', // 服务器地址
'DB_NAME' => 'thinkphp', // 数据库名
'DB_USER' => 'root', // 用户名
'DB_PWD' => '', // 密码
'DB_PORT' => 3306, // 端口
'DB_PREFIX' => 'think_', // 数据库表前缀
//其他项目配置参数
// ...
);
需要注意的是,ThinkPHP的数据库连接的惰性的,所以并不是在实例化的时候就连接数据库,而是在有实际的数据操作的时候才会去连接数据库(额外的情况是,在系统第一次实例化模型的时候,会自动连接数据库获取相关模型类对应的数据表的字段信息)。 参考技术A 连接数据库
ThinkPHP内置了抽象数据库访问层,把不同的数据库操作封装起来,我们只需要使用公共的Db类进行操作,而无需针对不同的数据库写不同的代码和底层实现,Db类会自动调用相应的数据库适配器来处理。目前的数据库包括Mysql、MsSQL、PgSQL、Sqlite、Oracle、Ibase以及PDO的支持,如果应用需要使用数据库,必须配置数据库连接信息,数据库的配置文件有多种定义方式:
第一种 在项目配置文件里面定义
return array(
'DB_TYPE'=> 'mysql',
'DB_HOST'=> 'localhost',
'DB_NAME'=>'thinkphp',
'DB_USER'=>'root',
'DB_PWD'=>'',
'DB_PORT'=>'3306',
'DB_PREFIX'=>'think_',
// 其他项目配置参数………
);
系统推荐使用该种方式,因为一般一个项目的数据库访问配置是相同的。该方法系统在连接数据库的时候会自动获取,无需手动连接。
可以对每个项目定义不同的数据库连接信息,还可以在调试配置文件(Conf/debug.php)里面定义调试数据库的配置信息,如果在项目配置文件和调试模式配置文件里面同时定义了数据库连接信息,那么在调试模式下面后者生效,部署模式下面前者生效。
第二种 使用DSN方式在初始化Db类的时候传参数
$db_dsn = “mysql://username:passwd@localhost:3306/DbName”;
$db = new Db($db_dsn);
该方式主要用于在控制器里面自己手动连接数据库的情况,或者用于创建多个数据库连接。
第三种 使用数组传参数
$DSN = array(
'dbms' => 'mysql',
'username' => 'username',
'password' => 'password',
'hostname' => 'localhost',
'hostport' => '3306',
'database' => 'dbname'
);
$db = new Db($DSN);
该方式也是用于手动连接数据库的情况,或者用于创建多个数据库连接。
第四种 在模型类里面定义
protected $connection = array(
'dbms' => 'mysql',
'username' => 'username',
'password' => 'password',
'hostname' => 'localhost',
'hostport' => '3306',
'database' => 'dbname'
);
// 或者使用下面的定义
protected $connection = ”mysql://username:passwd@localhost:3306/DbName”;
如果在某个模型类里面定义了connection属性,则在实例化模型对象的时候,会使用该数据库连接信息进行数据库连接。通常用于某些数据表位于当前数据库连接之外的其它数据库。
ThinkPHP并不是在一开始就会连接数据库,而是在有数据查询操作的时候才会去连接数据库。额外的情况是,在系统第一次操作模型的时候,框架会自动连接数据库获取相关模型类的数据字段信息,并缓存下来。
(字段缓存目录:Runtime/Data/_fields)
ThinkPHP支持PDO方式,如果要使用PDO方式连接数据库,可以参考下面的设置。
我们以项目配置文件定义为例来说明:
return array(
'DB_TYPE'=> 'pdo',
// 注意DSN的配置针对不同的数据库有所区别 请参考PHP手册PDO类库部分
'DB_DSN'=> 'mysql:host=localhost;dbname=think',
'DB_USER'=>'root',
'DB_PWD'=>'',
'DB_PREFIX'=>'think_',
// 其他项目配置参数………
);
使用PDO方式的时候,要注意检查是否开启相关的PDO模块。DB_DSN参数仅对PDO方式连接才有效。本回答被提问者采纳 参考技术B 全局配置定义
常用的配置方式是在应用配置文件或者模块配置文件中添加下面的配置参数:
//数据库配置信息
'DB_TYPE' => 'mysql', // 数据库类型
'DB_HOST' => 'localhost', // 服务器地址
'DB_NAME' => 'thinkphp', // 数据库名
'DB_USER' => 'root', // 用户名
'DB_PWD' => '123456', // 密码
'DB_PORT' => 3306, // 端口
'DB_PREFIX' => 'think_', // 数据库表前缀
'DB_CHARSET'=> 'utf8', // 字符集
'DB_DEBUG' => TRUE, // 数据库调试模式 开启后可以记录SQL日志 3.2.3新增
2.模型类定义
如果在某个模型类里面定义了connection属性的话,则实例化该自定义模型的时候会采用定义的数据库连接信息,而不是配置文件中设置的默认连接信息,通常用于某些数据表位于当前数据库连接之外的其它数据库,例如:
//在模型里单独设置数据库连接信息
namespace Home\Model;
use Think\Model;
class UserModel extends Model
protected $connection = array(
'db_type' => 'mysql',
'db_user' => 'root',
'db_pwd' => '1234',
'db_host' => 'localhost',
'db_port' => '3306',
'db_name' => 'thinkphp',
'db_charset' => 'utf8',
);
3.实例化定义
除了在模型定义的时候指定数据库连接信息外,我们还可以在实例化的时候指定数据库连接信息,例如: 如果采用的是M方法实例化模型的话,也可以支持传入不同的数据库连接信息,例如:
$User = M('User','other_','mysql://root:1234@localhost/demo#utf8');
以上是关于thinkphp 3.2 model怎么写sql的主要内容,如果未能解决你的问题,请参考以下文章