PHP-Phalcon框架中的数据库操作
作者:网络转载 发布时间:[ 2016/5/5 11:43:04 ] 推荐标签:PHP 数据库
> 本文描述了PHP-Phalcon框架中数据库操作方法,主要讨论Phalcon框架的Model组件中的操作方法。更详细的Model介绍请参考:官方文档
1. 连接数据库
在Phalcon框架中,通过在DI中注入db参数来实现数据库的连接和配置,基本的配置方法如下:
use PhalconDbAdapterPdoMysql as DbAdapter;
$di->set('db', function () {
return new DbAdapter(array(
"host" => "localhost",
"username" => "root",
"password" => "",
"dbname" => "test"
));
});
通过在$di中设置'db'的连接属性,包括host,username,password,dbname等属性来获取数据库参数,配置好db之后可以利用Phalcon中的ORM框架了。
另一种通过配置文件的方法如下:
1.首先需要将数据信息写入配置文件,在Phalcon中支持ini, php, json等三种配置文件形式,以下为ini形式的配置文件。
[database]
adapter = Mysql
host = localhost
username = root
password =
dbname = test
2.利用配置文件将数据库信息写入DI
$di->set('db', function () use ($config) {
$config = $config->get('database')->toArray();
$dbClass = 'PhalconDbAdapterPdo\' . $config['adapter'];
unset($config['adapter']);
return new $dbClass($config);
});
2. 建立数据库表
在MySQL中建立数据库表,如下所示:
CREATE TABLE `customer` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(255) DEFAULT NULL,
`password` varchar(32) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
以上语句建立了一个customer表,包括主键id,以及username和password两个字段。
3. 创建模型
根据上述数据库表,创建Customer.php模型类,需要注意的是模型类必须继承PhalconMVCModel类,并且采用与数据库表名一致的驼峰命名法。因此建立如下的Customer类:
class Customer extends PhalconMvcModel
{
//采用默认的对应规则会自动映射数据库表的字段,可以不写
/**
*
* @var integer
*/
public $id;
/**
*
* @var string
*/
public $username;
/**
*
* @var string
*/
public $password;
/**
* Returns table name mapped in the model.
*
* @return string
*/
public function getSource()
{
return 'customer';
}
}
其实只要满足了对应的命名规则,模型类中的属性是不需要定义的,这里定义的目的是方便开发过程中查看,并且可以提高性能;此外,如果没有采用数据库表名对应的类名进行命名的话,需要在初始化函数中通过setSource方法进行配置,配置代码:
public function initialize()
{
$this->setSource("tablename");
}
从这里可以看出,在现代的Web开发框架中,都遵循约定大于配置(CoC)的基本原则。只要遵循约定,可以很方便的进行Web开发。
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11