"My title", "name" => "My Name", "date" => "My date" ); $this->db->insert("mytabl" /> "My title", "name" => "My Name", "date" => "My date" ); $this->db->insert("mytabl" />
广告
返回顶部
首页 > 资讯 > 数据库 >CI查询构造器类(插入数据、更新数据、删除数据)
  • 857
分享到

CI查询构造器类(插入数据、更新数据、删除数据)

CI查询构造器类(插入数据更新数据删除数据) 2017-06-13 03:06:38 857人浏览 无得
摘要

$data = array( "title" => "My title", "name" => "My Name", "date" => "My date" ); $this->db->insert("mytabl

CI查询构造器类(插入数据、更新数据、删除数据)

$data = array(
    "title" => "My title",
    "name" => "My Name",
    "date" => "My date"
);

$this->db->insert("mytable", $data);
// Produces: INSERT INTO mytable (title, name, date) VALUES ("My title", "My name", "My date")

第一个参数为要插入的表名,第二个参数为要插入的数据,是个关联数组

下面是使用对象的例子:



$object = new Myclass;
$this->db->insert("mytable", $object);
// Produces: INSERT INTO mytable (title, content, date) VALUES ("My Title", "My Content", "My Date")

第一个参数为要插入的表名,第二个参数为要插入的数据,是个对象。

 

1.2  $this->db->get_compiled_insert()

该方法和 $this->db->insert() 方法一样根据你提供的数据生成一条 INSERT 语句,但是并不执行。

 

例如:

$data = array(
    "title" => "My title",
    "name"  => "My Name",
    "date"  => "My date"
);

$sql = $this->db->set($data)->get_compiled_insert("mytable");
echo $sql;

// Produces string: INSERT INTO mytable (`title`, `name`, `date`) VALUES ("My title", "My name", "My date")

第二个参数用于设置是否重置查询(默认情况下会重置,正如 $this->db->insert() 方法一样):

echo $this->db->set("title", "My Title")->get_compiled_insert("mytable", FALSE);

// Produces string: INSERT INTO mytable (`title`) VALUES ("My Title")

echo $this->db->set("content", "My Content")->get_compiled_insert();

// Produces string: INSERT INTO mytable (`title`, `content`) VALUES ("My Title", "My Content")

上面的例子中,最值得注意的是,第二个查询并没有用到 $this->db->from() 方法, 也没有为查询指定表名参数,但是它生成的 SQL 语句中有 INTO mytable 子句。 这是因为查询并没有被重置(使用 $this->db->insert() 方法会被执行并被重置, 使用 $this->db->reset_query() 方法直接重置)。

 

1.3  $this->db->insert_batch()

 

该方法根据你提供的数据生成一条 INSERT 语句并执行,它的参数是一个**数组** 或一个**对象**,下面是使用数组的例子:

$data = array(
    array(
        "title" => "My title",
        "name" => "My Name",
        "date" => "My date"
    ),
    array(
        "title" => "Another title",
        "name" => "Another Name",
        "date" => "Another date"
    )
);

$this->db->insert_batch("mytable", $data);
// Produces: INSERT INTO mytable (title, name, date) VALUES ("My title", "My name", "My date"),  ("Another title", "Another name", "Another date")

第一个参数为要插入的表名,第二个参数为要插入的数据,是个二维数组。

 

2. 更新数据

2.1  $this->db->replace()

该方法用于执行一条 REPLACE 语句,REPLACE 语句根据表的**主键**和**唯一索引** 来执行,类似于标准的 DELETE + INSERT 。 使用这个方法,你不用再手工去实现 select()update()delete() 以及 insert() 这些方法的不同组合,为你节约大量时间

例如:

$data = array(
    "title" => "My title",
    "name"  => "My Name",
    "date"  => "My date"
);

$this->db->replace("table", $data);

 

 

注解这个方法不支持批量插入。

 

您可能感兴趣的文档:

--结束END--

本文标题: CI查询构造器类(插入数据、更新数据、删除数据)

本文链接: https://www.lsjlt.com/news/3836.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作