CodeIgniter框架數據庫基本操作示例
本文實例講述了CodeIgniter框架數據庫基本操作。分享給大家供大家參考,具體如下:
現在開始,首先現在CI框架到自己的服務器目錄下并配置config/config.php
$config['base_url'] = 'http://localhost:90/CI/';
接著下來配置數據庫在config/databases.php我做練習配置如下
$db['default']['hostname'] = 'localhost'; $db['default']['username'] = 'root'; $db['default']['password'] = 'root'; $db['default']['database'] = 'demo'; $db['default']['dbdriver'] = 'mysql';
別的現在新手用不到緊接著創(chuàng)建一個數據庫和一個user表,這個在我的源碼包里面有你可以直接導入就好了,但是前提你要創(chuàng)建一個demo的數據庫
reg類代碼如下
<?php
/***************************************
* 用戶注冊模塊和數據庫的基本操作實踐
* 17:44 2013.2.18
* @Author sdeep wang
***************************************/
class Reg extends CI_Controller{
function __construct(){//此函數每次必須寫是繼承父類的方法
parent::__construct();
$this->load->database();//這個是連接數據庫的方法,放到這里的好處只要調用該方法就會連接數據庫
}
function index(){
$this->load->view('reg_view');//這個是使用哪個視圖來顯示相當于Smarty中的display
}
function reg_insert(){
$data['name'] = $this->input->post('name');//這個是指取得POST數組的值然后賦值一個心的數組
$data['sex'] = $this->input->post('sex');
$data['age'] = $this->input->post('age');
$data['pwd'] = md5($this->input->post('pwd'));//這里用了一個md5加密只是為了演示
$data['email'] = $this->input->post('email');
$this->db->insert('user',$data);//這個是數據庫操作插入操作
redirect('/reg/reg_select/', 'refresh');//這個是跳轉函數是url輔助函數里面的一個方法
}
function reg_select(){//這個查詢數據庫的方法
$this->db->select('id,name,sex,age,email');//這里是查詢要顯示的字段,可不能像我第一次這樣寫啊$this->db->select('id','name','sex','age','email');
$data['query'] = $this->db->get('user');//這個是取得數據(如果你上面寫的和我第一次一樣的話只能取的一個字段)
$this->load->view('select_view',$data);//這里是調用哪個視圖并分配數據給指定視圖顯示
}
function reg_delete(){//刪除數據的操作
$id = $this->input->get('id');//這里是取得get傳過來的值
$this->db->where('id',$id);//這里是做where條件這個相當重要,如果沒有這個你有可能把這個表數據都清空了
$this->db->delete('user');//刪除指定id數據
redirect('/reg/reg_select/', 'refresh');//同上跳轉
}
function reg_update(){//跟新數據的操作
$data['id'] = $this->input->get('id');//同上取的get傳值過來的ID
$this->load->view('update_view',$data);//同上調用視圖分配數據
}
function reg_com_update(){//這個是真正的跟新數據操作方法
$id = $this->input->post('id');//同上取得post中的id值
$data = array(//把post數組的值封裝到新的數組中為了下面跟新操作用
'name'=>$this->input->post('name'),
'pwd'=>md5($this->input->post('pwd')),
'email'=>$this->input->post('email' )
);
if(!empty($id) && (count($data) > 1)){//判斷id值是否傳過來并且判斷封裝的數組是否有元素存在
$this->db->where('id',$id);//同上準備where條件
$this->db->update('user',$data);//跟新操作
}
redirect('/reg/reg_select/', 'refresh');//同上跳轉
}
}
?>
視圖代碼如下
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>用戶注冊</title>
</head>
<body>
<form action="<?php echo site_url('reg/reg_insert/'); ?>" method="post">
<table>
<tr>
<td>
姓名:<input type="text" name="name" />
</td>
</tr>
<tr>
<td>
姓別:<input type="radio" name="sex" value="1" />男
<input type="radio" name="sex" />女
</td>
</tr>
<tr>
<td>
年齡:<input type="text" name="age" />
</td>
</tr>
<tr>
<td>
密碼:<input type="password" name="pwd" />
</td>
</tr>
<tr>
<td>
郵件:<input type="text" name="email" />
</td>
</tr>
<tr>
<td>
<input type="submit" value="注冊" />
<input type="reset" value="重置" />
</td>
</tr>
</table>
</form>
</body>
</html>
第二個視圖代碼如下
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>顯示數據庫中的所有注冊用戶</title>
<style>
*{
margin:0 auto;
}
table {
border:1px solid gray;
border-collapse: collapse;
width:500px;
text-align:center;
}
th,td {
border:1px solid gray;
}
</style>
</head>
<body>
<table>
<caption><h3>注冊用戶的顯示</h3></caption>
<tr>
<th>ID</th>
<th>Name</th>
<th>Sex</th>
<th>Age</th>
<th>Email</th>
<th>Operate</th>
</tr>
<?php foreach($query->result() as $item):?>
<tr>
<td><?php echo $item->id; ?></td>
<td><?php echo $item->name; ?></td>
<td><?php echo $item->sex; ?></td>
<td><?php echo $item->age; ?></td>
<td><?php echo $item->email; ?></td>
<td>
<a href="<?php echo site_url('reg/reg_delete');?>?id=<?php echo $item->id;?>" rel="external nofollow" >刪除</a> |
<a href="<?php echo site_url('reg/reg_update');?>?id=<?php echo $item->id;?>" rel="external nofollow" >修改</a>
</td>
</tr>
<?php endforeach; ?>
</table>
</body>
</html>
第三個視圖如下
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>修改用戶注冊信息</title>
</head>
<body>
<form action="<?php echo site_url('reg/reg_com_update');?>" method="post">
<table>
<tr>
<td>姓名:<input type="text" name="name" /></td>
</tr>
<tr>
<td>密碼:<input type="password" name="pwd" /></td>
</tr>
<tr>
<td>郵件:<input type="text" name="email" /></td>
</tr>
<tr>
<td>
<input type="submit" value="修改" />
<input type="hidden" name="id" value="<?php echo $id; ?>" />
</td>
</tr>
</table>
</form>
</body>
</html>
效果圖如下

就這樣其中里面什么驗證啊,校對之類的都沒有做只是練習數據庫的基本操作。
更多關于CodeIgniter相關內容感興趣的讀者可查看本站專題:《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《php優(yōu)秀開發(fā)框架總結》、《ThinkPHP入門教程》、《ThinkPHP常用方法總結》、《Zend FrameWork框架入門教程》、《php面向對象程序設計入門教程》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家基于CodeIgniter框架的PHP程序設計有所幫助。
相關文章
Yii2創(chuàng)建控制器(createController)方法詳解
這篇文章主要介紹了Yii2創(chuàng)建控制器(createController)的方法,結合實例形式分析了Yii創(chuàng)建控制器所使用到的方法、操作步驟與相關技巧,需要的朋友可以參考下2016-07-07
PHPStorm 2020.1 調試 Nodejs的多種方法詳解
這篇文章主要介紹了PHPSTORM 2020.1 調試 Nodejs的多種方法詳解,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09

