ホームページ >バックエンド開発 >PHPチュートリアル >CI フレームワーク (CodeIgniter) によって実装されたデータベースの追加、削除、変更、クエリ操作

CI フレームワーク (CodeIgniter) によって実装されたデータベースの追加、削除、変更、クエリ操作

jacklove
jackloveオリジナル
2018-06-22 16:14:283405ブラウズ

この記事では、CI フレームワーク (CodeIgniter) で実装されるデータベースの追加、削除、変更、クエリ操作を中心に、mysql データベースの追加、削除に関する CI フレームワークのモデル、コントローラー、ビュー関連の定義と使用スキルをまとめて分析します。 、例の形式での変更およびクエリ操作については、以下を参照してください。

この記事の例では、CI フレームワーク (CodeIgniter) によって実装されるデータベースの追加、削除、変更、およびクエリ操作について説明します。参照用に全員と共有します。詳細は次のとおりです。 コントローラの下の

cquery.php ファイル

#

<?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 ファイルモデル

<?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ファイル

<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ファイル

<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 ファイル

<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>

あなたはそうかもしれません興味のある記事:

1次元配列と2次元配列の重複排除機能のPHP実装例

CIフレームワークによるインポートとエクスポートの実装(CodeIgniter) データ操作例

ThinkPHPフレームワークで実装したMySQLデータベースバックアップ機能例

#

以上がCI フレームワーク (CodeIgniter) によって実装されたデータベースの追加、削除、変更、クエリ操作の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。