php laravel curl

Laravel PHP Web开发框架

Laravel是一套简洁、优雅的PHP Web开发框架(PHP Web Framework)。它可以让你从面条一样杂乱的代码中解脱出来;它可以帮你构建一个完美的网络APP,而且每行代码都可以简洁、富于表达力。

本文为大家讲解了Laravel框架中的数据库CURD操作、连贯操作、链式操作的用法,包含大量数据库操作常用方法,感兴趣的同学参考下.

Laravel是一套简洁、优雅的PHP Web开发框架(PHP Web Framework)。它可以让你从面条一样杂乱的代码中解脱出来;它可以帮你构建一个完美的网络APP,而且每行代码都可以简洁、富于表达力。

一、Selects

检索表中的所有行

代码如下:

$users = DB::table(‘users‘)->get();
foreach ($users as $user)
{
var_dump($user->name);
}

从表检索单个行

代码如下:

$user = DB::table(‘users‘)->where(‘name‘, ‘John‘)->first();
var_dump($user->name);

检索单个列的行

代码如下:

$name = DB::table(‘users‘)->where(‘name‘, ‘John‘)->pluck(‘name‘);

检索一个列值列表

代码如下:

$roles = DB::table(‘roles‘)->lists(‘title‘);

该方法将返回一个数组标题的作用。你也可以指定一个自定义的键列返回的数组

代码如下:

$roles = DB::table(‘roles‘)->lists(‘title‘, ‘name‘);

指定一个Select子句

代码如下:

$users = DB::table(‘users‘)->select(‘name‘, ‘email‘)->get();
 $users = DB::table(‘users‘)->distinct()->get();
 $users = DB::table(‘users‘)->select(‘name as user_name‘)->get();

Select子句添加到一个现有的查询$query = DB::table(‘users‘)->select(‘name‘);

代码如下:

$users = $query->addSelect(‘age‘)->get();

where

代码如下:

$users = DB::table(‘users‘)->where(‘votes‘, ‘>‘, 100)->get();

OR

代码如下:

$users = DB::table(‘users‘)->where(‘votes‘, ‘>‘, 100)->orWhere(‘name‘, ‘John‘)->get();

Where Between

代码如下:

$users = DB::table(‘users‘)->whereBetween(‘votes‘, array(1, 100))->get();

Where Not Between

代码如下:

$users = DB::table(‘users‘)->whereNotBetween(‘votes‘, array(1, 100))->get();

Where In With An Array

代码如下:

$users = DB::table(‘users‘)->whereIn(‘id‘, array(1, 2, 3))->get();
$users = DB::table(‘users‘)->whereNotIn(‘id‘, array(1, 2, 3))->get();

Using Where Null To Find Records With Unset Values

代码如下:

$users = DB::table(‘users‘)->whereNull(‘updated_at‘)->get();

Order By, Group By, And Having

代码如下:

$users = DB::table(‘users‘)->orderBy(‘name‘, ‘desc‘)->groupBy(‘count‘)->having(‘count‘, ‘>‘, 100)->get();

Offset & Limit

代码如下:

$users = DB::table(‘users‘)->skip(10)->take(5)->get();

二、连接

Joins

查询构建器也可以用来编写连接语句。看看下面的例子:

Basic Join Statement

代码如下:

DB::table(‘users‘)
  ->join(‘contacts‘, ‘users.id‘, ‘=‘, ‘contacts.user_id‘)
  ->join(‘orders‘, ‘users.id‘, ‘=‘, ‘orders.user_id‘)
  ->select(‘users.id‘, ‘contacts.phone‘, ‘orders.price‘)
  ->get();

左连接语句

代码如下:

DB::table(‘users‘)
  ->leftJoin(‘posts‘, ‘users.id‘, ‘=‘, ‘posts.user_id‘)
  ->get();
  DB::table(‘users‘)
  ->join(‘contacts‘, function($join)
  {
  $join->on(‘users.id‘, ‘=‘, ‘contacts.user_id‘)->orOn(...);
  })
  ->get();
  DB::table(‘users‘)
  ->join(‘contacts‘, function($join)
  {
  $join->on(‘users.id‘, ‘=‘, ‘contacts.user_id‘)
  ->where(‘contacts.user_id‘, ‘>‘, 5);
  })
  ->get();

三、分组

  有时候,您可能需要创建更高级的where子句,如“存在”或嵌套参数分组。Laravel query builder可以处理这些:

代码如下:

DB::table(‘users‘)
->where(‘name‘, ‘=‘, ‘John‘)
->orWhere(function($query)
{
$query->where(‘votes‘, ‘>‘, 100)
->where(‘title‘, ‘<>‘, ‘Admin‘);
})
->get();

  上面的查询将产生以下SQL:

代码如下:

  select * from users where name = ‘John‘ or (votes > 100 and title
<> ‘Admin‘)
  Exists Statements
  DB::table(‘users‘)
  ->whereExists(function($query)
  {
  $query->select(DB::raw(1))
  ->from(‘orders‘)
  ->whereRaw(‘orders.user_id = users.id‘);
  })
  ->get();

上面的查询将产生以下SQL:

代码如下:

select * from userswhere exists (
select 1 from orders where orders.user_id = users.id
)

四、聚合

查询构建器还提供了各种聚合方法,如统计,马克斯,min,avg和总和。

Using Aggregate Methods

代码如下:

$users = DB::table(‘users‘)->count();
$price = DB::table(‘orders‘)->max(‘price‘);
$price = DB::table(‘orders‘)->min(‘price‘);
$price = DB::table(‘orders‘)->avg(‘price‘);
$total = DB::table(‘users‘)->sum(‘votes‘);

Raw Expressions

有时您可能需要使用一个原始表达式的查询。这些表达式将注入的查询字符串,所以小心不要创建任何SQL注入点!创建一个原始表达式,可以使用DB:rawmethod:

Using A Raw Expression

代码如下:

$users = DB::table(‘users‘)
->select(DB::raw(‘count(*) as user_count, status‘))
->where(‘status‘, ‘<>‘, 1)
->groupBy(‘status‘)
->get();

递增或递减一个列的值

代码如下:

DB::table(‘users‘)->increment(‘votes‘);
DB::table(‘users‘)->increment(‘votes‘, 5);
DB::table(‘users‘)->decrement(‘votes‘);
DB::table(‘users‘)->decrement(‘votes‘, 5);

您还可以指定额外的列更新:

代码如下:

  DB::table(‘users‘)->increment(‘votes‘, 1, array(‘name‘ => ‘John‘));

Inserts

将记录插入表

代码如下:

DB::table(‘users‘)->insert(
array(‘email‘ => ‘[email protected]‘, ‘votes‘ => 0)
);

将记录插入表自动增加的ID

如果表,有一个自动递增的id字段使用insertGetId插入一个记录和检索id:

代码如下:

$id = DB::table(‘users‘)->insertGetId(
array(‘email‘ => ‘[email protected]‘, ‘votes‘ => 0)
);

注意:当使用PostgreSQL insertGetId方法预计,自增列被命名为“id”。

多个记录插入到表中

代码如下:

DB::table(‘users‘)->insert(array(
array(‘email‘ => ‘[email protected]‘, ‘votes‘ => 0),
array(‘email‘ => ‘[email protected]‘, ‘votes‘ => 0),
));

四、Updates

更新一个表中的记录

代码如下:

DB::table(‘users‘)
->where(‘id‘, 1)
->update(array(‘votes‘ => 1));

五、 Deletes

删除表中的记录

代码如下:

DB::table(‘users‘)->where(‘votes‘, ‘<‘, 100)->delete();

删除表中的所有记录

代码如下:

DB::table(‘users‘)->delete();

删除一个表

代码如下:

DB::table(‘users‘)->truncate();

六、Unions

查询构建器还提供了一种快速的方法来“联盟”两个查询:

代码如下:

  $first = DB::table(‘users‘)->whereNull(‘first_name‘);
  $users =
DB::table(‘users‘)->whereNull(‘last_name‘)->union($first)->get();

  unionAll方法也可以,有相同的方法签名。

  Pessimistic Locking

  查询构建器包括一些“悲观锁定”功能来帮助你做你的SELECT语句。  运行SELECT语句“共享锁”,你可以使用sharedLock方法查询:

代码如下:

DB::table(‘users‘)->where(‘votes‘, ‘>‘,
100)->sharedLock()->get();

更新“锁”在一个SELECT语句,您可以使用lockForUpdate方法查询:

代码如下:

 DB::table(‘users‘)->where(‘votes‘, ‘>‘, 100)->lockForUpdate()->get();

七、缓存查询

  你可以轻松地缓存查询的结果使用记忆法:

代码如下:

$users = DB::table(‘users‘)->remember(10)->get();

  在本例中,查询的结果将为十分钟被缓存。查询结果缓存时,不会对数据库运行,结果将从默认的缓存加载驱动程序指定您的应用程序。  如果您使用的是支持缓存的司机,还可以添加标签来缓存:

代码如下:

$users = DB::table(‘users‘)->cacheTags(array(‘people‘, ‘authors‘))->remember(10)->get();

时间: 2024-11-05 13:41:34

php laravel curl的相关文章

window 10 用composer安装 基于 Laravel 5.3 的 Coaster CMS Curl错误77解决

安装教程来自 http://laravelacademy.org/post/6547.html 1.系统环境windows 10 nodejs3.9.2 composer1.2.4(国内镜像) Cmder(ConEmu 161206) 2.打开终端输入 composer create-project web-feet/coastercms project1 安装到当前目录下的project1文件夹中 3.安装最后出现 cURL error 77: error setting certificat

Laravel 的微信插件 EasyWechat 出现 curl 60错误

1.下载cacert.pem放到服务器 2.php.ini 中 curl.cainfo = D:\web\cert\cacert.pem 注: (1).pem文件路径根据实际情况修改 (2).路径为绝对路径:如: D:\web\cert\cacert.pem ,否则会报错 原文地址:https://www.cnblogs.com/kinber/p/8304852.html

Linux nginx部署laravel

Composer Composer 是 php 的一个依赖管理工具.它允许你申明项目所依赖的代码库,它会在你的项目中为你安装他们.运行 Composer 需要 PHP 5.3.2+ 以上版本.一些敏感的 PHP 设置和编译标志也是必须的,但对于任何不兼容项安装程序都会抛出警告. 安装  Composer curl -sS https://getcomposer.org/installer | php mv composer.phar /usr/local/bin/composer 通过 Comp

ubuntu16.04 安装composer和 laravel

一.安装composer $ sudo apt-get update $ sudo apt-get install wget 下载composer.phar $ wget https://getcomposer.org/composer.phar 或者 $ curl -O https://getcomposer.org/composer.phar 重命名文件composer.phar 为 composer $ mv composer.phar composer $ chmod +x compos

利用Laravel自带的Mail类发邮件

由于项目在运行过程中经常用到邮件检测报警的功能,而在之前我都是用shell脚本发送邮件.shell脚本的优点是可以直接处理服务器指令,但是其缺点就是处理数据的能力效率太低,取数据库的许多数据要先把数据写入文件里,然后每行读文件并且分割来取出你想要的数据,相对来说麻烦太多.所以本人就准备直接利用Laravel框架封装好的Mail类直接发邮件,而且php语言相对shell来说数据处理能力简直强太多,所以果断弃坑了. 首先新建一个Laravel项目,在其.env文件里找到MAIL相关值,配好邮件发送账

Windows上使用Vagrant打造Laravel Homestead可协同跨平台开发环境

1.简介 Laravel 致力于让整个 PHP 开发过程变得让人愉悦,包括本地开发环境,为此官方为我们提供了一整套本地开发环境 —— Laravel Homestead. Laravel Homestead 是一个打包好各种 Laravel 开发所需要的工具及环境的 Vagrant 盒子(Vagrant 提供了一个便捷的方式来管理和设置虚拟机),该盒子为我们提供了优秀的开发环境,有了它,我们不再需要在本地环境安装 PHP.HHVM.Web服务器以及其它工具软件,我们也完全不用再担心误操作搞乱操作

Linux laravel安装

第一步:安装php套件 目前为止laravel是5.1版本,需要对php有要求,要php5.59以上 The Laravel framework has a few system requirements. Of course, all of these requirements are satisfied by the Laravel Homestead virtual machine: * PHP >= 5.5.9 * OpenSSL PHP Extension * PDO PHP Exte

php后台开发(二)Laravel框架

php后台开发(二)Laravel框架 为了提高后台的开发效率,往往需要选择一套适合自己的开发框架,因此,选择了功能比较完善的Laravel框架,仔细学来,感觉和Python语言的框架Django非常类似. Laravel框架 Laravel是一套web应用开发框架,它具有富于表达性且简洁的语法,并提供了验证(authentication).路由(routing).session和缓存(caching)等开发过程中经常用到的工具或功能. 框架安装 安装composer http://docs.p

PHP 基于laravel框架获取微博数据之一 模拟新浪微博登录

参考资料:http://www.csuldw.com/2016/11/10/2016-11-10-simulate-sina-login/http://blog.csdn.net/fly_leopard/article/details/51148904http://www.tuicool.com/articles/uIJzYff http://blog.csdn.net/u010029983/article/details/46364113等 模拟新浪微博登录是抓取新浪数据的基础,网上的参考资料