CI中的数据库操作以及AR连贯操作
要使用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的官方手册中查阅;
当有资源需要操作多个数据库时,可以在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 ' ]这个表前缀,如图所示;

AR连贯操作;
select id,name from tableName where id>=3 order by id desc limit 2,3;//这里limit是跳过两条查第三条数据;
上面是一条SQL查询语句,用CI中的AR连贯操作是这样写的;
$res = $this -> db -> select( ' id,name ' )
->from( ‘ user ’ )
->where(‘id >=’ , 3) //这里id >=,id与符号之间一定要有空格;
->limit( 3 , 2 ) //跳过第二条查第三条,在CI中limit是反过来的,应该写成3,2而不是2,3;
->get();
$res -> result(); //最后是用result函数调用;
echo $this -> db -> last_query(); //查询最后一次sql语句,最后echo出来会发现和传统的sql语句是一样的;
如果对安全性有需求,可以使用以下操作进行数据查询;如果安全需求更高的话就使用上面我们提到的使用db里面的query方法问号绑定查询;

CI中的数据库操作以及AR连贯操作的更多相关文章
- CI中的数据库操作
转载于:http://blog.sina.com.cn/s/blog_76e7bdba01016p2p.html CI中第一次连接数据库,在控制器或模型的构造函数里输入以下语句 $this->l ...
- ***CI中的数据库操作(insert_id新增后返回记录ID)
在system/application/config 文件夹和里面的config文件里已经配置了参数 $active_group = "default";$db['default' ...
- 十四、CI框架之数据库以参数形式插入操作
一.代码如下: 二.使用浏览器打开 三.我们查看数据库,被成功插入数据 不忘初心,如果您认为这篇文章有价值,认同作者的付出,可以微信二维码打赏任意金额给作者(微信号:382477247)哦,谢谢.
- TP5.1:数据库的增删改查操作(基于面向对象操作)
我们现实中对数据库的增删改查操作,都是使用模型类进行操作的(表名::),也就是面向对象操作,只有底层的代码用的是数据库操作(Db::table('表名')) 下面我将贴出模型类进行的增删改查操作,通过 ...
- 十二、CI框架之数据库查询
一.在database文件中写明数据库相关信息 二.我们数据库中的表如图所示 三.在CI中查询数据库内容 四.在浏览器输出 不忘初心,如果您认为这篇文章有价值,认同作者的付出,可以微信二维码打赏任意金 ...
- CodeIgniter学习笔记二:CI中的query_builder(AR)、连贯操作
一.开启query_builder 在application\config\database.php中添加如下代码(默认已开启): $query_builder = TRUE; 二.查询数据 //ge ...
- Laravel框架中的数据库CURD操作、连贯操作、链式操作的用法
Laravel是一套简洁.优雅的PHP Web开发框架(PHP Web Framework).它可以让你从面条一样杂乱的代码中解脱出来:它可以帮你构建一个完美的网络APP,而且每行代码都可以简洁.富于 ...
- ci连贯操作的limit两个参数和sql是相反的
ci连贯操作的limit两个参数和sql是相反的 db->where("name =",'mary')->ge() name后面要有个空格否则报错当为一个字段 -> ...
- Laravel框架数据库CURD操作、连贯操作
这篇文章主要介绍了Laravel框架数据库CURD操作.连贯操作.链式操作总结,本文包含大量数据库操作常用方法,需要的朋友可以参考下 一.Selects 检索表中的所有行 $users = DB::t ...
随机推荐
- fiddler抓包 IOS11以上系统
想要使用fiddler对iphone X进行抓包,按照以前的配置方法,走一遍.还是抓不成,原来是因为IOS11操作系统中,安装完证书之后,还需要再手动信任证书才能正常抓包. 以下内容来自:https: ...
- IDEA中使用Database管理工具
以下内容来自我的知乎回答IntelliJ IDEA中有什么让你相见恨晚的技巧? 说个冷门的,用IDEA操作数据库. 可能大部分不知道,IDEA是自带数据库管理工具的,类似于一个小型Navicat. 具 ...
- 下拉框处理(select)
在UI自动化测试过程中,经常会遇到一些下拉框,我们有三种可选方式来操作下拉框. 第一种方法 基于webdriver的两次click,很容易出现问题,不建议使用.(由于部分下拉框在点击一次后,失去焦点再 ...
- eas之排序接口
KDTable目前本身并不支持排序功能,但提供了排序的接口,用户通过实现该接口(ISortManager)即可实现排序的功能.同时KDTable提供了一个简单实现KDTSortManager,这个类完 ...
- eas之设定table选择模式
tblMain.getSelectManager().setSelectMode(0);--不能选择 tblMain.getSelectManager().setSelectMode(1);--选择 ...
- LA 4327
Panagola, The Lord of city F likes to parade very much. He always inspects his city in his car and e ...
- css实现多行文字限制显示&编译失效解决方案
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name ...
- Vue CLI 3.x 简单体验
文档 中文文档 补充于02月10日 vue脚手架的3.x版本已经在开发中,现在还处于alpha版本.我们来看看有哪些变化. 使用 npm install -g @vue/cli 命名方式已经改为npm ...
- [vuejs短文]使用vue-transition制作小小轮播图
提示 本文是个人的一点小笔记,用来记录开发中遇到的轮播图问题和vue-transition问题. 会不断学习各种轮播图添加到本文当中 也有可能会上线,方便看效果 开始制作 超简易呼吸轮播 简单粗暴的使 ...
- 02017_String类方法使用练习
1.获取指定字符串中,大写字母.小写字母.数字的个数. public static void method(String str){ int bigCount = 0; //大写字母的个数 int s ...