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

此篇文章基于

  • laravel版本:5.5

laravel基于DB的原生查询可以使用 DB facade 运行查询。DB facade 为每种类型的查询提供了方法:selectupdateinsertdeletestatement。以下是知识点:

(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 *, 
                        day(WN_DATE) WN_DAYOFMONTH,
                        month(WN_DATE) WN_MONTH,
                        year(WN_DATE) WN_YEAR
                 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 *, day(WN_DATE) WN_DAYOFMONTH, month(WN_DATE) WN_MONTH, year(WN_DATE) WN_YEAR from mytable where year(WN_DATE) like ? order by WN_DATE DESC";

$param = '%'.$_SESSION['filterOn'].'%';

$result = DB::select($query , array($param));
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值