=================数据库操作======================
1.数据库配置:
config/database.php 用户名 密码 数据库

2 加载数据库类:$this->load->database();
也可以自动加载:在$autoload['libraries']中添加值"database"

3 使用:$this->db->...

* 连接多个数据库:
1)在database.php中配置多个数据库连接信息:
$db["default"] = array();
$db["database2"] = array();...

2) 在连接数据库时传入索引("default"或"database2")
3) $obj = $this->load->database("default",true) ,注意第二个参数在操作多个库时必须写,返回为连接的标示
4)使用数据库操作时,使用$obj->....进行操作

* 如果数据库表中指定了数据库表前缀,那么可以通过$this->db->dbprefix("表名")得到完整的表名
如:$sql = "select * from ci_user" --> "select * from ".$this->db->dbprefix("user");

4.执行语句:$this->db->query("语句");
如果用占位符方式,则query("语句",参数);*多个参数的时候需要使用数组
--查询绑定
* $sql = "select * from user where uid =? and pwd=?";
$this->db->query($sql,array("lily",123));

* $sql = "select * from user where uid in ? and XXX=?";
$this->db->query($sql,array(array(1,3,4),1));

select:返回一个查询结果集
insert/delete/update:返回true/false

查询:方法:query()//返回对象
二维数组:$res->result()
二维数组:$res->result_array()
返回一行数据:$res->row()/$res->row(行索引)
返回一行数据:$res->row_array()

5.常用辅助函数:
* $this->db->insert_id();返回自增序列的id
* $this->db->affected_rows();返回受影响的行数
* $this->db->last_query();返回最后一次执行的sql语句
* $this->db->count_all(table);返回表中有多少条数据
* $this->db->insert_string("表名",data);将data插入到表中 -- 生成sql语句
* $this->db->update_string("表名",data,condition);根据condition修改表中的data数据 -- 生成sql语句

=============查询构造器==================
一、 查询:
1.$this->db->get(表名,限定行数,起始值)
查询数据表中的数据,返回查询结果集,等同于$this->db->query("sql");

2.$this->db->get_where(表名,where,limit,offset)
根据指定条件进行查询

3.$this->db->select(fiels);
指定要查询出哪些字段,多个字段之间用,分隔,第二个参数设置是否保护字段名,默认为true

4.连贯操作:
$this->db
->select("字段") //用","隔开
->from("表名")
->where("查询条件")
1)可以字符串,
2)也可以使用数组array("字段1"=>1,"字段2"=>'zx')-and相连的条件
3)where("字段名",$id)//字段名=$id.如果需要不等于:where("字段名<>",$id)
->or_where("查询条件")//使用同where,当传递数组时用or连接
->order_by("排序")
->group_by("分组")
->having("分组后的查询条件")
->limit(n,m)//n m和数据库中的limit是相反的:"limit m,n"
->join("要连接的表名","连接的条件(on....=...)","可选参数:连接方式-left right,默认内连接")
->get(); //执行
* get以上的方法都是不需要顺序,建议大家按sql的语句
* 复杂的语句建议使用query()的方法

----------------------------------

二、 添加:
页面显示----添加表单
$this->load->view("insert");
添加的操作
模型:$this->db->insert("user",$arr);//表名,添加的数据(数组:字段=>值)
返回值:影响行?true/false
控制器:
看表单传递的数据:$this->input->post()
调用模型层中的方法

批量插入:
$this->db->insert_batch(tableName,data) -- data可以为二维数组,表示多条数据
返回受影响的行数

----------------------------------

三、修改:
/*
从列表跳转到修改页面
页面显示:当前数据的内容(表单)
模型:查询当前这条数据(需要给定参数id)
控制器: 1)加载模型
2)获取参数:$this->uri->segment(数字)//参数从index.php之后开始数1,以此类推
例:http://localhost/ci/index.php/user/update/id/1
//希望取到id后的1 ,$this->uri->segment(4)
3)调用模型层中的方法->显示
不存在数据的时候:提示,跳转地址:site_url("控制器/方法")
*/

$this->db->update(tableName,data,where); -- data为一个数组,where可以是一个字符串
$this->db->replace(tableName,data); -- data中必须包含主键或唯一索引,而且数据表中的所有数据都必须出现在data中

----------------------------------

四、 删除:
$this->db->delete(tableName,where);//表名,where条件(可以数组,也可以字符串)
$this->db->empty_table(tableName);//删除表中的所有数据,id不会重置,等同于delete
$this->db->truncate(tableName);//清空表,并重置id

----------------------------------

五、set()
$this->db->set("key","value") 或 $this->db->set(["key"=>"value"])

例:$this->db->set("name","lily")->where()->update(tableName);
* insert/update/delete都可以使用

CI数据库操作_查询构造器类的更多相关文章

  1. ThinkPhp框架的数据库操作(查询)

    TP框架有一套自己的数据库操作的代码,包括数据库的增.删.改.查.本文主要讲解TP框架的数据库查询操作. 找到入口文件的控制器: 我这里的入口文件是Show文件夹下的控制器. 打开Login控制器. ...

  2. Oracle基础:数据库操作_数据库事务_表的锁定

    数据库操作语句: INSERT INTO 表名[(字段列表)] VALUES ( 表达式列表); 例子:INSERT INTO emp(empno,ename,job,hiredate) VALUES ...

  3. ci框架 查询构造器类

    $this->db->get() 该方法执行 SELECT 语句并返回查询结果,可以得到一个表的所有数据: $query = $this->db->get('mytable') ...

  4. ThinkPHP 数据库操作(三) : 查询方法、查询语法、链式操作

    查询方法 条件查询方法 where 方法 可以使用 where 方法进行 AND 条件查询: Db::table('think_user') ->where('name','like','%th ...

  5. 仿照hibernate封装的一个对数据库操作的jdbc工具类

    package project02_Order_management.util; import java.io.IOException; import java.lang.reflect.Field; ...

  6. spring boot: spring-data-jpa (Repository/CrudRepository) 数据库操作, @Entity实体类持久化

    SpringBoot实现的JPA封装了JPA的特性, Repository是封装了jpa的特性(我是这么理解的) 1在pom.xml引入mysql, spring-data-jpa依赖 2.在src/ ...

  7. ThinkPHP 数据库操作(六) : 查询事件、事务操作、监听SQL

    查询事件 查询事件(V5.0.4+) 从 5.0.4+ 版本开始,增加了数据库的CURD操作事件支持,包括: 查询事件仅支持 find . select . insert . update 和 del ...

  8. mysql 单表下的字段操作_查询

    查询的规律 查询语句限定条件越多,查询范围越小: 1.整个表 Select * From 库名.表名 2.整个表的某字段内 Select id From 库名.表名 3.整个表某字段的范围内 Sele ...

  9. CI 数据库操作总结

    最简单示例 $query = $this->db->query("YOUR QUERY"); foreach ($query->result() as $row) ...

随机推荐

  1. leetcode算法: Find All Duplicates in an Array

    Given an array of integers, 1 ≤ a[i] ≤ n (n = size of array), some elements appear twice and others ...

  2. redis数据库各种数据类型的增删改查命令

    redis的常用数据操作: redis是key-value的数据结构,每条数据都是一个键值对. 键的类型是字符串并且键不能重复. redis最基本数据类型是string 所以下面的操作可以省略引号&q ...

  3. Lua编写wireshark插件初探——解析Websocket上的MQTT协议

    一.背景 最近在做物联网流量分析时发现, App在使用MQTT协议时往往通过SSL+WebSocket+MQTT这种方式与服务器通信,在使用SSL中间人截获数据后,Wireshark不能自动解析出MQ ...

  4. scrapy爬取极客学院全部课程

    # -*- coding: utf-8 -*- # scrapy爬取极客学院全部课程 import scrapy from pyquery import PyQuery as pq from jike ...

  5. win7安装JDK6

    注:虽然9已经出来了,但是今天刚好业务需要要装JDK6,所以以JDK 6作为演示,同样适用于JDK 7.8的安装. 安装 基本上一直点下一步就可以. 此处可修改安装路径. 我将JDK的安装路径设置成了 ...

  6. C#之FTP上传下载(一)

    搭建FTP服务器 最近要实现这样一个功能:FTP服务器的上传和下载,搜集了一些资料,在c播客上看到昵称为"傻丫头和科技"的作者写的一篇文章写得挺好,有的地方个人觉得不是很详细,自己 ...

  7. [LeetCode] Redundant Connection II 冗余的连接之二

    In this problem, a rooted tree is a directed graph such that, there is exactly one node (the root) f ...

  8. 页面中引入mui 地址选择,点击页面中其他input时页面回到顶部

    问题:在页面中引入mui地址选择时,点击页面中的input页面会滚到顶部(谷歌浏览器中出现的bug),在手机上点击input会出现跳动.开始的时候是想修改mui.min.js里的滚动事件,但是后来找到 ...

  9. 想进大厂,想收获高薪offer,资深猎头告诉你怎么做......

    其实吧,面试官面试的时候主要就看三个方面:现在能力如何,未来潜力如何,人品如何. 第一个因素是最重要的,因为后面两个因素有太多的人为判断因素,无法量化.所谓的面试准备,"现在能力如何&quo ...

  10. [SDOI2008]Sue的小球

    题目描述 Sue和Sandy最近迷上了一个电脑游戏,这个游戏的故事发在美丽神秘并且充满刺激的大海上,Sue有一支轻便小巧的小船.然而,Sue的目标并不是当一个海盗,而是要收集空中漂浮的彩蛋,Sue有一 ...