Home  >  Article  >  Backend Development  >  Database addition, deletion, modification and query operations implemented by CI framework (CodeIgniter)

Database addition, deletion, modification and query operations implemented by CI framework (CodeIgniter)

jacklove
jackloveOriginal
2018-06-22 16:14:283345browse

This article mainly introduces the database addition, deletion, modification and query operations implemented by the CI framework (CodeIgniter). It summarizes and analyzes the CI framework's model, controller and view related definitions and usage skills for the mysql database addition, deletion, modification and query operations in the form of examples. Friends in need can refer to the following

The example in this article describes the database addition, deletion, modification and query operations implemented by the CI framework (CodeIgniter). Share it with everyone for your reference, the details are as follows:

cquery.php file under controllers

<?php
class CQuery extends Controller {
  //构造函数
  function CQuery() {
    parent::Controller();
//   $this->load->database();
  }
  function index() {
    //调用model 其中train为外层文件夹  MQuery为model名称 queryList为重命名
    $this->load->model(&#39;train/MQuery&#39;,&#39;queryList&#39;);
    //获得返回的结果集  这里确定调用model中的哪个方法
    $result = $this->queryList->queryList();
    //将结果集赋给res
    $this->smarty->assign(&#39;res&#39;,$result);
    //跳转到显示页面
    $this->smarty->view(&#39;train/vquery.tpl&#39;);
  }
  //进入新增页面
  function addPage() {
    $this->smarty->view(&#39;train/addPage.tpl&#39;);
  }
  //新增
  function add() {
    //获得前台数据
    //用户名
    $memberName = $this->input->post(&#39;memberName&#39;);
    //密码
    $password = $this->input->post(&#39;password&#39;);
    //真实姓名
    $userRealName = $this->input->post(&#39;userRealName&#39;);
    //性别
    $sex = $this->input->post(&#39;sex&#39;);
    //出生日期
    $bornDay = $this->input->post(&#39;bornDay&#39;);
    //e_mail
    $eMail = $this->input->post(&#39;eMail&#39;);
    //密码问题
    $question = $this->input->post(&#39;question&#39;);
    //密码答案
    $answer = $this->input->post(&#39;answer&#39;);
    //调用model
    $this->load->model(&#39;train/MQuery&#39;,&#39;addRecord&#39;);
    //向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(&#39;train/MQuery&#39;,&#39;delRecord&#39;);
    //将值传入到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(&#39;train/MQuery&#39;,&#39;changeRecord&#39;);
    $result = $this->changeRecord->changeRecord($changeID);
    //将结果集赋给res
    $this->smarty->assign(&#39;res&#39;,$result);
    //跳转到显示页面
    $this->smarty->view(&#39;train/changePage.tpl&#39;);
  }
  //修改
  function change() {
    //获得前台数据
    //ID
    $ID = $this->input->post(&#39;id&#39;);
    //用户名
    $memberName = $this->input->post(&#39;memberName&#39;);
    //密码
    $password = $this->input->post(&#39;password&#39;);
    //真实姓名
    $userRealName = $this->input->post(&#39;userRealName&#39;);
    //性别
    $sex = $this->input->post(&#39;sex&#39;);
    //出生日期
    $bornDay = $this->input->post(&#39;bornDay&#39;);
    //e_mail
    $eMail = $this->input->post(&#39;eMail&#39;);
    //密码问题
    $question = $this->input->post(&#39;question&#39;);
    //密码答案
    $answer = $this->input->post(&#39;answer&#39;);
    //调用model
    $this->load->model(&#39;train/MQuery&#39;,&#39;change&#39;);
    //向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.";
    }
  }
}

mquery.php file in models

<?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 (&#39;$memberName&#39;,&#39;$password&#39;,&#39;$userRealName&#39;,&#39;$sex&#39;,&#39;$bornDay&#39;,&#39;$eMail&#39;,&#39;$question&#39;,&#39;$answer&#39;)";
    //执行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 = &#39;$memberName&#39;,password = &#39;$password&#39;, user_real_name = &#39;$userRealName&#39;," .
        "sex = &#39;$sex&#39;,born_day = &#39;$bornDay&#39;,e_mail = &#39;$eMail&#39;,question = &#39;$question&#39;,answer = &#39;$answer&#39;" .
        "where ID = $ID";
    //执行SQL
    $result = $this->db->query($sql);
    //关闭数据库
    $this->db->close();
    //返回值
    return $result;
  }
}

addPage.tpl file under views

<html>
  <head>
  </head>
  <body><form action="{{site_url url=&#39;train/cquery/add&#39;}}" method="post">
    <table border=&#39;1&#39;>
      <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 file

<html>
  <head>
  </head>
  <body><form action="{{site_url url=&#39;train/cquery/change&#39;}}" method="post">
    <table border=&#39;1&#39;><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 file

<html>
  <head>
    <title></title>
  </head>
  <body>
    <table border=&#39;1&#39;>
      <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=&#39;train/cquery/deletePage&#39;}}/{{$row->ID}}" rel="external nofollow" >删除</a><a href="{{site_url url=&#39;train/cquery/changePage&#39;}}/{{$row->ID}}" rel="external nofollow" >修改</a></td>
      </tr>
      {{/foreach}}
    </table>
    <a href="{{site_url url=&#39;train/cquery/addPage&#39;}}" rel="external nofollow" rel="external nofollow" mce_href="{{site_url url=&#39;train/cquery/addPage&#39;}}" rel="external nofollow" rel="external nofollow" >add</a>
  </body>
</html>

You may be interested Article:

Example of PHP implementation of one-dimensional array and two-dimensional array deduplication function

Import and export implemented by CI framework (CodeIgniter) Data operation example

MySQL database backup function example implemented by ThinkPHP framework

The above is the detailed content of Database addition, deletion, modification and query operations implemented by CI framework (CodeIgniter). For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn