laravel原生sql操作以及like模糊查询的坑点

本文介绍了laravel 5.5中使用DB facade进行原生SQL操作的方法,包括select、insert、update、delete和statement,并强调了在进行LIKE模糊查询时的正确用法,指出了错误示例并提供了修正方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

此篇文章  基于laravel版本:5.5
laravel基于DB的原生查询可以使用 DB facade 运行查询。DB facade 为每种类型的查询提供了方法:select、update、insert、delete 和 statement。

以下是知识点:

(1)运行查询语句

$users = DB::select('select * from users where active = ?', [1]);
(2)运行插入语句可以在 DB facade 上使用 insert 方法来执行 insert 语句。与 select 一样,该方法将原生 SQL 查询作为其第一个参数,并将其绑定的数据作为第二个参数:

    DB::insert('insert into users (id, name) values (?, ?)', [1, 'Dayle']);
(3)运行更新语句

   update 方法用于更新数据库中的现有记录。该方法会返回受该语句影响的行数:

   $affected = DB::update('update users set votes = 100 where name = ?', ['John']);
(4)运行删除语句

   delete 方法用于删除数据库中记录。与 update 一样,会返回受该语句影响的行数:

  $deleted = DB::delete('delete from users');
(5)运行普通语句有些数据库语句不会返回任何值。对于这些语句,可以在 DB facade 上使用 statement 方法来操作:

   DB::statement('drop table users');
(6)使用命名绑定

  除了使用 ? 来表示参数绑定外,你也可以使用命名绑定来执行一个查询:

   $results = DB::select('select * from users where id = :id', ['id' => 1]);
 在实际的使用中使用模糊查询,发现:

(1)此写法查询错误

$a = DB::select('select *
                 from mytable
                 where year(WN_DATE)
                 like %?%
                 order by WN_DATE DESC',
                array($_SESSION['filterOn']));


(2)此查询错误

$a = DB::select('select *,
                        day(WN_DATE) WN_DAYOFMONTH,
                        month(WN_DATE) WN_MONTH,
                        year(WN_DATE) WN_YEAR
                 from mytable
                 where year(WN_DATE)
                 like %:filterOn%
                 order by WN_DATE DESC',
                array('filterOn'=>$_SESSION['filterOn']));


正确的使用模糊查找方法:

$query = "select  *  from mytable where year(WN_DATE) like ?  order by WN_DATE DESC";
$param = '%'.$_SESSION['filterOn'].'%';
$result = DB::select($query , array($param));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值