1. Go to this page and download the library: Download nueip/codeigniter-model library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
nueip / codeigniter-model example snippets
$this->load->model('Posts_model');
// Create an Active Record
$post = new Posts_model;
$post->title = 'CI3'; // Equivalent to `$post['title'] = 'CI3';`
$post->save();
// Update the Active Record found by primary key
$post = $this->Posts_model->findOne(1);
if ($post) {
$oldTitle = $post->title; // Equivalent to `$oldTitle = $post['title'];`
$post->title = 'New CI3';
$post->save();
}
$result = $this->Posts_model->insert(['title' => 'Codeigniter Model']);
// Find out the record which just be inserted
$record = $this->Posts_model->find()
->order_by('id', 'DESC')
->get()
->row_array();
// Update the record
$result = $this->Posts_model->update(['title' => 'CI3 Model'], $record['id']);
// Delete the record
$result = $this->Posts_model->delete($record['id']);
$config['composer_autoload'] = TRUE;
class Post_model extends nueip\Model {}
class My_model extends nueip\Model
{
protected $primaryKey = 'sn';
const CREATED_AT = 'created_time';
const UPDATED_AT = 'updated_time';
// Customized Configurations for your app...
}
class Post_model extends My_model
{
protected $table = "post_table";
}
// Without any scopes & conditions for this query
$records = $this->Model->find(true)
->where('is_deleted', '1')
->get()
->result_array();
// This is equal to find(true) method
$this->Model->withAll()->find();
$this->load->model('Posts_model');
// Set attributes
$post = new Posts_model;
$post->title = 'CI3';
$post['subtitle'] = 'PHP';
$post->save();
// Get attributes
$post = $this->Posts_model->findOne(1);
$title = $post->title;
$subtitle = $post['subtitle'];
public object findOne(array $condition=[])
// Find a single active record whose primary key value is 10
$activeRecord = $this->Model->findOne(10);
// Find the first active record whose type is 'A' and whose status is 1
$activeRecord = $this->Model->findOne(['type' => 'A', 'status' => 1]);
// Query builder ORM usage
$this->Model->find()->where('id', 10);
$this->Model->findOne();
public array findAll(array $condition=[])
// Find the active records whose primary key value is 10, 11 or 12.
$activeRecords = $this->Model->findAll([10, 11, 12]);
// Find the active recordd whose type is 'A' and whose status is 1
$activeRecord = $this->Model->findAll(['type' => 'A', 'status' => 1]);
// Query builder ORM usage
$this->Model->find()->where_in('id', [10, 11, 12]);
$this->Model->findAll();
public boolean save($runValidation=true)
public array toArray()
class My_model extends nueip\Model
{
const SOFT_DELETED = 'is_deleted';
}
class My_model extends nueip\Model
{
const SOFT_DELETED = 'is_deleted';
// The actived value for SOFT_DELETED
protected $softDeletedFalseValue = '0';
// The deleted value for SOFT_DELETED
protected $softDeletedTrueValue = '1';
const DELETED_AT = 'deleted_at';
}
// class My_model extends nueip\Model
class Log_model extends My_model
{
const SOFT_DELETED = false;
}
class My_model extends nueip\Model
{
protected $userAttribute = 'uid';
/**
* Override _globalScopes with User validation
*/
protected function _globalScopes()
{
$this->db->where(
$this->_field($this->userAttribute),
$this->config->item('user_id')
);
return parent::_globalScopes();
}
public self withoutGlobalScopes()
$this->Model->withoutGlobalScopes()->find();
public self withAll()
$this->Model->withAll()->find();
public boolean validate($data=[], $returnData=false)
$this->load->model('PostsModel');
if ($this->PostsModel->validate($inputData)) {
// all inputs are valid
} else {
// validation failed: $errors is an array containing error messages
$errors = $this->PostsModel->getErrors();
}
$this->load->model('PostsModel');
$post = new PostsModel;
$post->title = '';
// ORM assigned or modified attributes will be validated by calling `validate()` without parameters
if ($post->validate()) {
// Already performing `validate()` so that turn false for $runValidation
$result = $post->save(false);
} else {
// validation failed: $errors is an array containing error messages
$errors = post->getErrors();
}
public array getErrors()
public array rules()
class PostsModel extends nueip\Model
{
protected $table = "posts";
/**
* Override rules function with validation rules setting
*/
public function rules()
{
return [
[
'field' => 'title',
'rules' => '
public function rules()
{
/**
* Set CodeIgniter language
* @see https://www.codeigniter.com/userguide3/libraries/language.html
*/
$this->lang->load('error_messages', 'en-US');
return [
[
'field' => 'title',
'rules' => '
$lang[''min_length'] = '`%s`
public array filters()
public function filters()
{
return [
[['title', 'name'], 'trim'], // Perform `trim()` for title & name input data
[['title'], 'static::method'], // Perform `public static function method($value)` in this model
[['name'], function($value) { // Perform defined anonymous function. 'value' => '[Filtered]value'
return "[Filtered]" . $value;
}],
];
}
class My_model extends nueip\Model
{
function __construct()
{
$this->database = $this->db;
$this->databaseRead = $this->dbr;
parent::__construct();
}
}