这篇文章主要介绍了CI框架(CodeIgniter)实现的数据库增删改查操作,结合实例形式总结分析了CI框架针对mysql数据库增删改查操作的模型、控制器及视图相关定义与使用技巧,需要的朋友可以参考下
本文实例讲述了CI框架(CodeIgniter)实现的数据库增删改查操作。分享给大家供大家参考,具体如下:
controllers下的 cquery.php文件
<?php class CQuery extends Controller { //构造函数 function CQuery() { parent::Controller(); // $this->load->database(); } function index() { //调用model 其中train为外层文件夹 MQuery为model名称 queryList为重命名 $this->load->model('train/MQuery','queryList'); //获得返回的结果集 这里确定调用model中的哪个方法 $result = $this->queryList->queryList(); //将结果集赋给res $this->smarty->assign('res',$result); //跳转到显示页面 $this->smarty->view('train/vquery.tpl'); } //进入新增页面 function addPage() { $this->smarty->view('train/addPage.tpl'); } //新增 function add() { //获得前台数据 //用户名 $memberName = $this->input->post('memberName'); //密码 $password = $this->input->post('password'); //真实姓名 $userRealName = $this->input->post('userRealName'); //性别 $sex = $this->input->post('sex'); //出生日期 $bornDay = $this->input->post('bornDay'); //e_mail $eMail = $this->input->post('eMail'); //密码问题 $question = $this->input->post('question'); //密码答案 $answer = $this->input->post('answer'); //调用model $this->load->model('train/MQuery','addRecord'); //向model中的addRecord传值 $result = $this->addRecord->addRecord($memberName,$password,$userRealName,$sex,$bornDay,$eMail,$question,$answer); //判断返回的结果,如果返回true,则调用本页的index方法,不要写 $result == false 因为返回的值未必是false 也有可能是"" if ($result) { $this->index(); } else { echo "add failed."; } } //删除 function deletePage() { //获得ID $deleteID = $this->uri->segment(4); //调用model $this->load->model('train/MQuery','delRecord'); //将值传入到model的delRecord方法中 $result = $this->delRecord->delRecord($deleteID); //判断返回值 if ($result) { $this->index(); } else { echo "delect failed."; } } //修改先查询 function changePage() { $changeID = $this->uri->segment(4); $this->load->model('train/MQuery','changeRecord'); $result = $this->changeRecord->changeRecord($changeID); //将结果集赋给res $this->smarty->assign('res',$result); //跳转到显示页面 $this->smarty->view('train/changePage.tpl'); } //修改 function change() { //获得前台数据 //ID $ID = $this->input->post('id'); //用户名 $memberName = $this->input->post('memberName'); //密码 $password = $this->input->post('password'); //真实姓名 $userRealName = $this->input->post('userRealName'); //性别 $sex = $this->input->post('sex'); //出生日期 $bornDay = $this->input->post('bornDay'); //e_mail $eMail = $this->input->post('eMail'); //密码问题 $question = $this->input->post('question'); //密码答案 $answer = $this->input->post('answer'); //调用model $this->load->model('train/MQuery','change'); //向model中的change传值 $result = $this->change->change($ID,$memberName,$password,$userRealName,$sex,$bornDay,$eMail,$question,$answer); //判断返回的结果,如果返回true,则调用本页的index方法,不要写 $result == false 因为返回的值未必是false 也有可能是"" if ($result) { $this->index(); } else { echo "change failed."; } } }
models中的 mquery.php 文件
<?php class MQuery extends Model { //构造函数 function MQuery() { parent::Model(); //连接数据库 $this->load->database(); } //查询列表 function queryList() { //防止select出的数据存在乱码问题 //mysql_query("SET NAMES GBK"); //SQL语句 $sql = "SELECT ID,member_name,sex,e_mail FROM user_info_t"; //执行SQL $rs = $this->db->query($sql); //将查询结果放入到结果集中 $result = $rs->result(); //关闭数据库 $this->db->close(); //将结果集返回 return $result; } //新增 function addRecord($memberName,$password,$userRealName,$sex,$bornDay,$eMail,$question,$answer) { //防止select出的数据存在乱码问题 //mysql_query("SET NAMES GBK"); //SQL语句 $sql = "INSERT INTO user_info_t (member_name,password,user_real_name,sex,born_day,e_mail,question,answer) " . "VALUES ('$memberName','$password','$userRealName','$sex','$bornDay','$eMail','$question','$answer')"; //执行SQL $result = $this->db->query($sql); //关闭数据库 $this->db->close(); //返回值 return $result; } //删除 function delRecord($deleteID) { //防止select出的数据存在乱码问题 //mysql_query("SET NAMES GBK"); $sql = "DELETE FROM user_info_t WHERE ID = $deleteID"; $result = $this->db->query($sql); $this->db->close(); return $result; } //修改前查询 function changeRecord($changeID) { //防止select出的数据存在乱码问题 //mysql_query("SET NAMES GBK"); $sql = "SELECT ID,member_name,password,user_real_name,sex,born_day,e_mail,question,answer FROM user_info_t WHERE ID = $changeID"; //执行SQL $rs = $this->db->query($sql); $result = $rs->row();//$result = $rs[0] //关闭数据库 $this->db->close(); //将结果集返回 return $result; } //修改 function change($ID,$memberName,$password,$userRealName,$sex,$bornDay,$eMail,$question,$answer) { //防止select出的数据存在乱码问题 //mysql_query("SET NAMES GBK"); //SQL语句 $sql = "update user_info_t set member_name = '$memberName',password = '$password', user_real_name = '$userRealName'," . "sex = '$sex',born_day = '$bornDay',e_mail = '$eMail',question = '$question',answer = '$answer'" . "where ID = $ID"; //执行SQL $result = $this->db->query($sql); //关闭数据库 $this->db->close(); //返回值 return $result; } }
views 下的 addPage.tpl文件
<html> <head> </head> <body><form action="{{site_url url='train/cquery/add'}}" method="post"> <table border='1'> <tr> <td>用户名</td> <td><input type="text" class="text" name="memberName" id="memberName"/></td> </tr> <tr> <td>密码</td> <td><input type="text" class="text" name="password" id="password"/></td> </tr> <tr> <td>真实姓名</td> <td><input type="text" class="text" name="userRealName" id="userRealName"/></td> </tr> <tr> <td>性别</td> <td><input type="text" class="text" name="sex" id="sex"/></td> </tr> <tr> <td>出生日期</td> <td><input type="text" class="text" name="bornDay" id="bornDay"/></td> </tr> <tr> <td>e_mail</td> <td><input type="text" class="text" name="eMail" id="eMail"/></td> </tr> <tr> <td>密码问题</td> <td><input type="text" class="text" name="question" id="question"/></td> </tr> <tr> <td>密码答案</td> <td><input type="text" class="text" name="answer" id="answer"/></td> </tr> </table> <table> <tr> <td><input type="submit" class="button" name="OK" value="提交" /> </td> </tr> </table></form> </body> </html>
changePage.tpl 文件
<html> <head> </head> <body><form action="{{site_url url='train/cquery/change'}}" method="post"> <table border='1'><input type="hidden" name="id" value="{{$res->ID}}" /> <tr> <td>用户名</td> <td><input type="text" class="text" name="memberName" id="memberName" value="{{$res->member_name}}" /></td> </tr> <tr> <td>密码</td> <td><input type="text" class="text" name="password" id="password" value="{{$res->password}}" /></td> </tr> <tr> <td>真实姓名</td> <td><input type="text" class="text" name="userRealName" id="userRealName" value="{{$res->user_real_name}}"/></td> </tr> <tr> <td>性别</td> <td><input type="text" class="text" name="sex" id="sex" value="{{$res->sex}}"/></td> </tr> <tr> <td>出生日期</td> <td><input type="text" class="text" name="bornDay" id="bornDay" value="{{$res->born_day}}"/></td> </tr> <tr> <td>e_mail</td> <td><input type="text" class="text" name="eMail" id="eMail" value="{{$res->e_mail}}"/></td> </tr> <tr> <td>密码问题</td> <td><input type="text" class="text" name="question" id="question" value="{{$res->question}}"/></td> </tr> <tr> <td>密码答案</td> <td><input type="text" class="text" name="answer" id="answer" value="{{$res->answer}}"/></td> </tr> </table> <table> <tr> <td><input type="submit" class="button" name="OK" value="提交" /> </td> </tr> </table></form> </body> </html>
vquery.tpl 文件
<html> <head> <title></title> </head> <body> <table border='1'> <tr> <td>用户名</td> <td>性别</td> <td>e_mail</td> <td>操作</td> </tr> {{foreach from=$res item=row}} <tr> <input type="hidden" value={{$row->ID}}> <td>{{$row->member_name}}</td> <td>{{$row->sex}}</td> <td>{{$row->e_mail}}</td> <td><a href="{{site_url url='train/cquery/deletePage'}}/{{$row->ID}}" rel="external nofollow" >删除</a><a href="{{site_url url='train/cquery/changePage'}}/{{$row->ID}}" rel="external nofollow" >修改</a></td> </tr> {{/foreach}} </table> <a href="{{site_url url='train/cquery/addPage'}}" rel="external nofollow" rel="external nofollow" mce_href="{{site_url url='train/cquery/addPage'}}" rel="external nofollow" rel="external nofollow" >add</a> </body> </html>
您可能感兴趣的文章:
CI框架(CodeIgniter)实现的导入、导出数据操作示例
以上是CI框架(CodeIgniter)实现的数据库增删改查操作的详细内容。更多信息请关注PHP中文网其他相关文章!

PHPSession失效的原因包括配置错误、Cookie问题和Session过期。1.配置错误:检查并设置正确的session.save_path。2.Cookie问题:确保Cookie设置正确。3.Session过期:调整session.gc_maxlifetime值以延长会话时间。

在PHP中调试会话问题的方法包括:1.检查会话是否正确启动;2.验证会话ID的传递;3.检查会话数据的存储和读取;4.查看服务器配置。通过输出会话ID和数据、查看会话文件内容等方法,可以有效诊断和解决会话相关的问题。

多次调用session_start()会导致警告信息和可能的数据覆盖。1)PHP会发出警告,提示session已启动。2)可能导致session数据意外覆盖。3)使用session_status()检查session状态,避免重复调用。

在PHP中配置会话生命周期可以通过设置session.gc_maxlifetime和session.cookie_lifetime来实现。1)session.gc_maxlifetime控制服务器端会话数据的存活时间,2)session.cookie_lifetime控制客户端cookie的生命周期,设置为0时cookie在浏览器关闭时过期。

使用数据库存储会话的主要优势包括持久性、可扩展性和安全性。1.持久性:即使服务器重启,会话数据也能保持不变。2.可扩展性:适用于分布式系统,确保会话数据在多服务器间同步。3.安全性:数据库提供加密存储,保护敏感信息。

在PHP中实现自定义会话处理可以通过实现SessionHandlerInterface接口来完成。具体步骤包括:1)创建实现SessionHandlerInterface的类,如CustomSessionHandler;2)重写接口中的方法(如open,close,read,write,destroy,gc)来定义会话数据的生命周期和存储方式;3)在PHP脚本中注册自定义会话处理器并启动会话。这样可以将数据存储在MySQL、Redis等介质中,提升性能、安全性和可扩展性。

SessionID是网络应用程序中用来跟踪用户会话状态的机制。1.它是一个随机生成的字符串,用于在用户与服务器之间的多次交互中保持用户的身份信息。2.服务器生成并通过cookie或URL参数发送给客户端,帮助在用户的多次请求中识别和关联这些请求。3.生成通常使用随机算法保证唯一性和不可预测性。4.在实际开发中,可以使用内存数据库如Redis来存储session数据,提升性能和安全性。

在无状态环境如API中管理会话可以通过使用JWT或cookies来实现。1.JWT适合无状态和可扩展性,但大数据时体积大。2.Cookies更传统且易实现,但需谨慎配置以确保安全性。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

Dreamweaver Mac版
视觉化网页开发工具

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

Dreamweaver CS6
视觉化网页开发工具