CI中的数据库操作

  要使用CI中的数据库操作,首先我们应该在CI的 application/config/databass.php 文件中配置数据库信息,通常就是配置主机名,用户名,密码,数据库名,表前缀(dbprefix);

  CI提供了一个database的类,但是并不默认装载,需要手动加载;$this -> load ->database() ;也可以在application/config/autoload.php中的 $autoload['libraries'] = array( 'database' ) 配置数据库的自动加载,配置完之后就不需要每次使用db类都加载batabase;

  装载成功后会放入到超级对象的属性中;使用$this -> db 对象操作数据库;

  关于数据的查询;

    $sql = "select * from 表名";先创建一条SQL语句;

    $res = $this -> db -> query( $sql ); CI当中使用数据库默认返回的是一个对象,而不是资源;等价于mysql_fetch_object();

    $user = $res -> result();使用对象中的result方法取出资源;可以在任意页面使用$res -> result();命令返回资源,返回的资源是以数组的形式返回的,数组里面是一个一个的对象;

    也可以将返回的数组保存在一个变量中 $data[ ' user_list ' ] = $users  通过 $this -> load -> view( ' xxx/xxx.php ',$data ) 来将数据传输;

    $user = $res -> resut_array() ;如果不希望返回的是对象,这条命令是将资源以二维数组(里面是关联数组)的形式返回;

    $res -> row();以对象的形式返回第一条数据;(做用户登陆查询判定时可用);

  具体的参数可以在CI的官方手册中查阅;

扫描二维码关注公众号,回复: 26906 查看本文章

  当有资源需要操作多个数据库时,可以在CI的 application/config/databass.php 文件中拷贝一份 { defualt } 参数配置数据库并修改这个参数,之后在$this -> load -> database( 参数名 ) 装载数据库时带上修改后的参数;

  

  关于数据的添加/删除/修改(例子写的是添加,删除和修改只需要更换sql语句即可);

    首先需要加载数据库类 $this -> load ->database;

    $sql = " insert into 表名 (字段,字段) value (‘ 值 ’,‘ 值 ’) " ;创建一条SQL语句;

    $this -> db -> query($sql);和mysql操作相似,不管什么查询都是用query建立;

    if($bool){      //通常我们插入参数之后会打印出一个受影响行数和自增ID;

      echo $this -> db -> affected rows();  //这条语句打印出受影响行数;等价于mysql_affected_rows();

      echo $this -> db -> insert_id();    //这条语句打印出自增ID;等价于mysql_insert_id();

    }

  关于提交数据来操作数据库安全性的问题;

    通常我们从表单得到一个字段并连接数据库查询时(大部分使用查询时使用,增删改会调用AR操作来解决安全性的问题),可以通过以下方式增加安全性;

    $data=array(

      $data = $this -> input -> post("xxx");

      $data = $this -> input -> post("xxx");

    );

    $sql = " select * from 表名 where 字段= ? , 字段 = ? ";

    $this -> db -> query( $sql , $data );

  关于表前缀的问题;

    在CI中处理表前缀的问题还是比较简单的,在application/config/databass.php 文件中有一个[ ' swap_pre ' ] 参数,只需要在里面写死一个表前缀,所有的SQL语句的表前缀都写死成[ ‘ swap_pre ’ ]这个参数,这个参数会自动的将自身替换成[ ' dbprefix ' ]的参数,当更换了数据库或表时,我们则不需要在sql语句中一条条修改表前缀,只需要在配置文件中修改[ ' dbprefix ' ]这个表前缀,如图所示;

    

  

    

    

猜你喜欢

转载自www.cnblogs.com/privateWa/p/8858877.html