首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SQL语句中 where 和 on 的区别

最近面试时候碰到一道题,关于数据库左连接和内连接中and和where的区别,网上看了看资料,加深一下印象,大家也可以看看。...先说结论: 在使用left join左连接时,on and和on where条件的区别如下: 1、on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。...2、where条件是在临时表生成好后,再对临时表进行过滤的条件。...在使用inner join内连接时,不管是对左表还是右表进行筛选,on and和on where都会对生成的临时表进行过滤。...where的过滤作用就出来了,右连接的原理是一样的。到这里就真相大白了:inner join中on和where没区别,右连接和左连接就不一样了。 本文转载自: SQL语句中where和 on的区别?

3.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    3分钟短文:Laravel模型作用域,为你“节省”更多代码

    events WHERE `published` = 1; 如果条件 published = 1 在默认的情况下需要开启,我们可以使用laravel模型的 全局作用域 方式为所有查询追加上这个条件。...而声明一个本地作用域,只要遵循laravel的语法规定即可,如下示例: public function scopePublished($query) { return $query->where('published...', 1); } 只需要声明一个以 scope 为首的小驼峰命名的函数方法即可,并返回一个 QueryBuilder 对象实例。...既然本地作用域返回的是 QueryBuilder 实例,那么自然就可以链式调用本地作用域的方法,和 QueryBuilder 的方法。...* FROM events WHERE zip = '43016' and max_attendees = '2'; 写在最后 本期我们又旧事重提,把laravel模型的作用域设计方法拿出来温习了一下

    1.4K22

    通过 Laravel 查询构建器实现简单的增删改查操作

    Laravel 数据库功能的核心就是提供流式接口与数据库进行交互的查询构建器(Query Builder),支持 MySQL、Postgres、SQLite 和 SQL Server 等常见的数据库管理系统..., [$name]); 我们还可以对绑定参数进行命名以便更加明确绑定了哪个参数: $users = DB::select('select * from `users` where `name` = :...友情提示:更新语句和删除语句一定要谨慎注意 where 条件,否则很容器由于疏忽更新了所有数据或删除了所有数据,后果不堪设想!...('id', '>', $id)->update(['name' => str_random(8)]); 同样,该方法返回的也是受影响行数,具体逻辑和原生更新语句一样,不再赘述,我们可以通过 where...(); 同样,我们通过 where 方法指定删除 id >= 11 的记录,delete 方法返回受影响行数,具体逻辑和原生删除语句也是一样的。

    4.2K20

    ThinkPHP5框架与ThinkPHP3.2的对比区别

    应该庆幸没选择其他框架,什么 CI、YII、Laravel 之类的,Laravel 了解过一些,但是没深入过,还是 TP 系列使用的顺手一些。...D 方法,查询find和select用的最多 ---- 命名规范 目录和文件名采用小写+下划线,并且以小写字母开头 类库、函数文件统一以.php为后缀 类的文件名均以命名空间定义,并且命名空间的路径和类库文件所在路径一致...(包括大小写) 类名和类文件名保持一致,并统一采用驼峰法命名(首字母大写) 对于命名规范,在学 PHP 以后一直做得挺规范的,哈哈 函数 系统已经不依赖任何函数,只是对常用的操作封装提供了助手函数...(['name'=>'thinkphp'])->find(); 5.0 版本 db('User')->where('name','thinkphp')->find(); 新版的模型查询增加了静态方法,例如...版本相对于之前版本对系统变化进行了大量的废弃,用户如果有相关需求可以自行定义 下面是一些废除的常量,部分常量可以在Request里面进行获取 REQUEST_METHOD、IS_GET、IS_POST、IS_PUT、IS_DELETE、IS_AJAX

    3.9K20

    3分钟短文:Laravel 使用DB门面操作原生SQL

    引言 我们推荐使用laravel的eloquent orm 模型操作数据库表, 因为特性更为丰富,组装更为灵活,在编程层面操作数据的来来去去非常直观。...比如删除users表: DB::statement('drop table users'); 带参数绑定的SQL查询语句: DB::select('select * from contacts where...扩展一下,带有查询条件的SQL原生语句, 为了防止SQL注入,使用参数绑定的方式: $usersOfType = DB::select('select * from users where type =..., [1, $id]); 当然了,删除语句仅仅需要where子句的条件参数绑定,其他与查询select无异: $countDeleted = DB::delete('delete from contacts..., [1]); 写在最后 本文通过对laravel DB门面的增删改查用法,向大家展示了基本的参数绑定的用法。

    2.3K20

    牛哇,PHP这个开发框架真的好香!

    Laravel框架相当于Java的Spring,生态or文档 是很完善的。 之前写Java的mybatis各种sql的和字段的处理,试过php开发之后,确实很快啊。...RouteServiceProvider.php 中的路由服务 protected $namespace = 'App\\Http\\Controllers'; 创建基础控制器(可以复制, 但一定要注意默认的命名空间...) php artisan make:controller UserController # 默认的控制器命名空间: namespace App\Http\Controllers; // 默认是这个命名空间...方法(and)之后继续调用 where 方法-> where() -> where()-> where()..-> where() -> orWhere() -> orWhere()......下面重点细讲解数据库models 下面演示一下开发中常用的编写sql语句 新建sql CREATE TABLE `laravel_users` ( `id` mediumint(8) unsigned

    26920

    【Laravel系列4.1】连接数据库与原生查询

    Laravel 框架中的 DB 和 ORM 是两个不同的组件,关于 ORM 的概念,我们也将在相关的学习中了解到,但是现在我们先从简单的普通查询学起。...这样,线上、测试和本地环境,就不会互相冲突,也不需要我们在各个环境中进行各种 hosts 修改。 原生查询 接下来,我们就学习怎么使用原生 SQL 语句进行数据库操作。...在代码中,我们通过 DB 这个门面类的 insert() 方法,就可以实现原生语句的增加操作。对于路由来说,其实我们不用写完全限定命名空间的类名,直接写个 DB 也是可以的。...看这个 insert() 函数的参数写法,是不是和 PDO 的预处理语句的写法很像?语句里面使用占位符,后面一个数组里面传递参数。...其实,这也正是 Laravel 优雅的由来。为了更好地区分度和代码的清晰。

    3.2K50

    PHP面试题,面试必看!

    ==新版变化== 命名规范 目录和文件名采用‘小写+下划线’,并且以小写字母开头; 类库、函数文件统一以.php为后缀; 类的文件名均以命名空间定义,并且命名空间的路径和类库文件所在路径一致(包括大小写...); 类名和类文件名保持一致,并统一采用驼峰法命名(首字母大写) 函数 系统已经不依赖任何函数,只是对常用的操作封装提供了助手函数; 单字母函数废弃,默认系统加载助手函数,具体参考上一个章节‘助手函数...控制器 控制器的命名空间有所调整,并且可以无需继承任何的控制器类。...适合用于中小项目的开发 ==thinkPHP缺点==: 1.对Ajax的支持不是很好; 2.目录结构混乱,需要花时间整理; 3.上手容易,但是深入学习较难。...例如,即使require放在计算结果为假的if语句中,依然会包含指定文件。 介绍下GET和POST? 答: 1. get是从服务器上获取数据,post是向服务器传送数据。

    2K20

    【Laravel系列4.2】查询构造器

    并且,最主要的是,它可以让我们以链式调用的形式来操作数据库,从而避免去写繁杂混乱的 SQL 语句。先卖个关子,想想这和哪个设计模式有关?...也就是说,查询构造器是介于 模型 和 原始语句 操作中间的一层。 不过相对来说,模型需要每个表都建立,而且表间关系复杂的话 Model 类也会比较复杂,而查询构造器会更简单而且更方便使用。...查询语句相对来说会复杂一些,我们在测试代码中增加了 where() 、orderBy() 和分页相关的组织函数。最后,通过一个 get() 函数就可以获得列表的信息。...注意看我注释掉的第二种多条件的写法,在这里面我使用了 orOn() 和 where() ,大家可以打开测试一下,结果是如下的 SQL 语句。...order by `id` desc limit 10 offset 0 另外还有就是我们在 SQL 语句中只看得到原始语句,也就是 name 这个 where 条件是使用 ?

    16.8K10

    3分钟短文|Laravel 使用like匹配字符串的用法示例

    引言 本文接着laravel的功能讲解,说一说在模型中查询条件内,使用like这样的SQL关键字 进行子字符串匹配。并通过几个示例,和不同的实现方法,为大家展示laravel的灵活性。...现在根据传入的参数,要筛选出某个电子邮件关联的所有订阅记录, 或者根据用户姓名关键字关联的所有订阅记录,代码如下: BookingDates::where('email', Input::get('email...如果实在不行,在可读性上,我们可以尝试一下laravel提供的本地作用域功能, 在模型内,或者全局内创建一个查询方法。...public function scopeWhereLike($query, $column, $value) { return $query->where($column, 'like', '...$value.'%'); } 这个是组成and SQL语句的方式,当然还有or SQL语句。

    2.1K10
    领券