SQL语句之-简单查询
SQL 语句的语法顺序是:
- SELECT[DISTINCT]
- FROM
- WHERE
- GROUP BY
- HAVING
- UNION
- ORDER BY
一、查询SELECT
1、查询全部列:SELECT * FROM products
2、查询选中的列:SELECT prod_name,prod_id FROM products; 列之间要用逗号隔开,一般而言除非需要所有的列才用通配符检索,否则最好不要用,这样会降低检索和应用程序的性能。
3、去掉重复出现的值:SELECT DISTINCT vend_id FROM products; DISTINCT关键字作用于所有的列,如果后面紧跟二个列,则结果会是显示所有数据。
4、限制显示结果:
SQLservice数据库:SELECT TOP 4 prod_name FROM products;
MySQL数据库:SELECT prod_name FROM products LIMIT 5
检索其中的几行:SELECT prod_name FROM products LIMIT 4 OFFSET 2 第一个数字是检索的行数显示四行,第二个数字从哪里开始,不包括启始的,相当于从第三行开始。
等价于==SELECT prod_name FROM products LIMIT 2,4 注意数字是和上面相反的
oracle数据库:SELECT prod_name FROM products LIMIT WHERE ROWNUM <=5
5、注释:#号
多行注释:/* */
二、排序数据 ORDER BY
1、单列排序:SELECT prod_name FROM products ORDER BY prod_name; ORDER BY保证是最后一条字句,不然会报错
2、多列排序:
SELECT prod_id,prod_price, prod_name FROM products
ORDER BY prod_price, prod_name;
4、按照列位置排序:--结果与上面一样
SELECT prod_id,prod_price, prod_name FROM products ORDER BY 2,3;
5、指定排序方向:
DESC--降序,默认是升序,如果想多列都排序,必须对没列指定DESC
SELECT prod_id,prod_price, prod_name FROM products ORDER BY prod_price DESC,prod_name;
三、过滤数据
1、使用where字句--行数
SELECT prod_id,prod_price, prod_name FROM products
WHERE prod_price=3.49
2、where字句操作符:大于>、小于<、不等于<> !=、>=、<=、
(1)检查单个值
SELECT prod_id,prod_price, prod_name FROM products WHERE prod_price >10;
(2)不匹配检查
SELECT prod_id,prod_price, prod_name FROM products WHERE prod_id !='DLL01';
(3)范围值检查
SELECT prod_id,prod_price, prod_name FROM products WHERE prod_price BETWEEN 5.99 AND 10 包括开始和结束的值
(4)空值检查
SELECT cust_name,cust_email FROM customers WHERE cust_email IS NULL
3、高级过滤AND-且的关系
SELECT prod_id,prod_price,prod_name,vend_id FROM products
WHERE vend_id='DLL01' AND prod_price<=4
4、高级过滤OR-或的关系
SELECT prod_id,prod_price,prod_name,vend_id FROM products
WHERE vend_id='DLL01' OR prod_price>4
ORDER BY prod_price DESC
5、高级过滤求值顺序
想要的是>10的数据,为什么得到小于10的呢?这是因为and的优先级高于OR,所以计算的顺序变成了
(vend_id='BRS01' AND prod_price>=10),应该修改为以下语句,括号的优先级高于其他二个
6、高级过滤IN--符合选择条件的
SELECT prod_id,prod_price,prod_name,vend_id FROM products
WHERE vend_id IN('DLL01','BRS01')
ORDER BY prod_price DESC
其实和OR是相同的功能,为什么用IN 呢?
- 语法更加清楚
- 求值顺序比OR AND容易管理
- 比OR执行速度更快,性能好
- 最大优点,可以包含其他的SELECT语句
7、高级过滤NOT——否定其后的条件
SELECT prod_id,prod_price,prod_name,vend_id FROM products
WHERE NOT vend_id ='DLL01'
ORDER BY prod_name
一般配合IN 、BETWEEN、EXISTS使用
四、更新
UPDATE Customers SET cust_email = 'kim@thetoystore.com'
WHERE cust_id = '';//没有WHERE子句,DBMS将会用这个电子邮件地址更新Customers表中的所有行 UPDATE Customers SET cust_contact = 'Sam Roberts',cust_email = 'sam@toyland.com' WHERE cust_id = '';//更新多个列 DELETE FROM Customers WHERE cust_id = '';//删除数据
五、子查询
假如需要列出订购物品RGAN01的所有顾客,应该怎样检索?下面列出具体的步骤。
1.检索包含物品RGAN01的所有订单的编号。
2.检索具有前一步骤列出的订单编号的所有顾客的ID。
3.检索前一步骤返回的所有顾客ID的顾客信息。
-- SELECT order_num,prod_id FROM orderitems WHERE prod_id='RGAN01'
-- SELECT cust_id FROM orders WHERE order_num IN(,)
SELECT cust_id FROM orders WHERE order_num IN (SELECT order_num FROM orderitems WHERE
prod_id = 'RGAN01');//结合二个语句
SELECT cust_name, cust_contact
FROM Customers
WHERE cust_id IN (SELECT cust_id
FROM Order
WHERE order_num IN (SELECT order_num
FROM OrderItems
WHERE prod_id = 'RGAN01'));
六、联结表
表结构
1、内联结查询
根据表中的共同列来查询的,是指主外键关系,二个表没有主次之分。
- 使用WHERE条件连接字句
- 在FROM字句中使用JOIN.......ON
-- 查看订单编号,购买数量,购买商品编号(订单表),用户姓名(用户表)
【WHERE】
2个表
3个表
【JOIN .........IN】
2、外链接查询
至少返回一个表中的所有记录,根据匹配条件有选择的返回另一个表中的记录,有主次之分
【左外连接】
LEFT JOIN 以左表为主,返回主表的所有记录,如果左表的一些行在右表没有匹配,用NULL
【右外连接】
右边的为主表
下面二个语法是等价的
-- SELECT vend_name,prod_name,prod_price FROM vendors,products
WHERE vendors.vend_id = products.vend_id;
-- SELECT vend_name,prod_name,prod_price
FROM vendors JOIN products ON vendors.vend_id=products.vend_id;//和上面等价
2、联结多个表
SELECT prod_name, vend_name, prod_price, quantity
FROM OrderItems, Products, Vendors
WHERE Products.vend_id = Vendors.vend_id
AND OrderItems.prod_id = Products.prod_id
AND order_num = ;
不要联结不必要的表。联结的表越多,性能下降越厉害。
使用别名
SELECT cust_name, cust_contact
FROM Customers AS C, Orders AS O, OrderItems AS OI
WHERE C.cust_id = O.cust_id
AND OI.order_num = O.order_num
AND prod_id = 'RGAN01';
//Oracle不支持AS关键字。要在Oracle中使用别名,可以不用AS,简单地指定列名即可(因此,应该是Customers C,而不是Customers AS C)
3、自联结
SQL语句之-简单查询的更多相关文章
- [转]在Excel中使用SQL语句实现精确查询
本文转自:http://blog.sina.com.cn/s/blog_5fc375650102e1g5.html 今天在微博上看到@数据分析精选 分享的一篇文章,是关于<在Excel中使用SQ ...
- 使用传入的总记录数实现一条sql语句完成分页查询
使用传入的总记录数实现一条sql语句完成分页查询 问题:在传统的分页查询的实现中不可避免的需要两条sql语句,一条用于查询数据一条用于查询总记录数.如下面的实际代码所示: Img1 当然如果使 ...
- mongodb 跟踪SQL语句及慢查询收集
有个需求:跟踪mongodb的SQL语句及慢查询收集 第一步:通过mongodb自带函数可以查看在一段时间内DML语句的运行次数. 在bin目录下面运行 ./mongostat -port 端口号 ...
- 在JDBC中实现SQL语句的模糊查询
在JDBC中实现SQL语句的模糊查询 在大多数情况下我们可以在JDBC中写入sql语句通过占位符的方式来直接查询,但是如果要进行模糊查询,需要转义字符才能够正常查询. sql语句: select * ...
- SQL语句技巧:查询时巧用OR实现逻辑判断
首先看以下SQL逻辑语句块: ) ) SET @fieldname='chassisno' --这里可传入chassisno,plateno,owner,contacttelno其中之一或不传 SET ...
- LINQ to Sql系列二 简单查询和联接查询
这一篇文章主要总结LINQ to sql的简单查询(单表查询)和联接查询(多表查询) 单表查询 需求是我们要输出TClass表中的结果.使用了from-in-select语句,代码如下: public ...
- SQL语句:子查询
一,子查询定义: 子查询就是嵌套在主查询中的查询. 子查询可以嵌套在主查询中所有位置,包括SELECT.FROM.WHERE.GROUP BY.HAVING.ORDER BY. 但并不是每个位置嵌套子 ...
- LINQ to SQL语句(1)Select查询的九种形式
目录 说明 简单形式 匿名类型形式 条件形式 指定类型形式 筛选形式 Shaped形式 嵌套形式 本地调用方法形式 Distinct形式 说明 与SQL命令中的select作用相似但位置不同,查询表达 ...
- MySQL 5.6 记录 SQL 语句与慢查询
环境: MySQL 如果需要记录 MySQL 的查询语句,需要在配置文件(Linux 下为 my.cnf,Windows 下为 my.ini)中添加配置: general_log = ON gener ...
随机推荐
- springboot项目中使用maven resources
maven resource 组件可以把pom的变量替换到相关的resouces目录中的资源文件变量 示例项目:内容中心 (文章管理) 生成jar包,生成docker ,生成k8s文件 1.项目结构 ...
- Android View的Adapter
1 Adapter适配的对象是View Adapter通过为View提供指定格式的数据来适配View,让View可以以事先约定好的方式将内容展示给用户. 所以,进行UI设计的关键是搞清楚各个View组 ...
- .Net Core - 使用Supervisor进行托管部署
环境 CentOS 7 x64,详见 安装CentOS7虚拟机 .Net Core 2.1.801 详见 CentOS 7 下安装.NET Core SDK 2.1 ftp 详见 CentOS7 ...
- BZOJ 3810 [Coci2015]Stanovi
这讲真就是一篇显得自己认真做题的博客 因为真的比较习惯将培训所有的题都放到一篇博客中,又因为暑假好多培训,所以单题很少,这也是从博客中摘出来的 题目链接 如果合法,一定有一条贯穿整个矩形的线: dp[ ...
- KMP字符串匹配 模板 洛谷 P3375
KMP字符串匹配 模板 洛谷 P3375 题意 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在s1中所有出现的位置. 为了减少骗分的情况,接下来还要输出子串的前缀数组next.(如果 ...
- Javascript高级面试
原型 异步 一.什么是单线程,和异步有什么关系 单线程:只有一个线程,同一时间只能做一件事原因:避免DOM渲染的冲突解决方案:异步 为什么js只有一个线程:避免DOM渲染冲突 浏览器需要渲染DOM J ...
- PY个康托展开
卡 PY 的题,和 BIT 一样,不说了 内存还卡的挺紧的? 具体而言,刚好打完的 BIT 扒过来用用,然后打个阶乘就完事儿了 没什么好说的 Code fac=[0 for i in range(10 ...
- Linux下配置JDK环境
安装前需要查询Linux中是否已经存在jdk 如果存在,将存在的jdk删除 在/etc/profile中添加以下 JAVA_HOME为jdk的安装目录 PATH为jdk可执行文件的目录 使用sourc ...
- Python爬虫之selenium高级功能
Python爬虫之selenium高级功能 原文地址 表单操作 元素拖拽 页面切换 弹窗处理 表单操作 表单里面会有文本框.密码框.下拉框.登陆框等. 这些涉及与页面的交互,比如输入.删除.点击等. ...
- 详解 nginx.conf 配置文件
Nginx 配置文件主要分为 4 部分: Main 全局设置:影响其他所有设置 Server 主机设置:配置指定的主机和端口 Upstream 负载均衡服务器设置 :设置一系列的后置服务器 Locat ...