关于SQL查询语句关键字方法
2023-06-13 09:19:56 时间
显示没有重复记录的商品名称,商品价格和商品类别列表
select distinct ware_name,price from t_ware; 2、使用计算列查询所有商品价格提高20%后的价格
select ware_id,ware_name,price*1.2 from t_ware 3、列的别名a) 不使用as
select ware_id,ware_name,price*1.2 price_raisefrom t_ware;
b)使用as
select ware_id,ware_name,price*1.2 price_raisefrom t_ware; 4、使用逻辑表达式
a)not 显示商品价格不大于100的商品
select ware_id,ware_name,price,category_idfrom t_ware
where not price
b)or 显示商品类别编号为5或6或7的商品
select ware_id,ware_name,price,category_idfrom t_ware
where category_id=5 or category_id=6
or category_id=7;
c)and 显示商品价格大于100且商品类别编号为5的商品
select ware_id,ware_name,price,category_idfrom t_ware
where not price 100 and category_id = 5; 5、使用between关键字
显示商品价格在200元至1000元之间的商品(留心一下,是半开区间还是封闭区间?)
select ware_id,ware_name,price,category_idfrom t_ware
where price between 200 and 1000; 6、使用in关键字
显示商品类别为5,6,7且价格不小于200元的商品
select ware_id,ware_name,price,category_idfrom t_ware
where category_id in (5,6,7) and price =200; 7、使用like子句进行模糊查询
a)%(百分号)表示0到n个任意字符
select ware_id,ware_name,price,category_idfrom t_ware
where ware_name like %纯棉%
b)_(下划线)表示单个的任意字符
select ware_id,ware_name,price,category_idfrom t_ware
where ware_name like %长袖_恤% 8、转义字符escape的使用 select ware_id,ware_name,price,category_id
from t_ware
where ware_name like %\%% escape \ 9、使用order by给数据排序 select * from t_ware_category
where parent_id = 0 order by ware_id ;
select * from t_ware_category
where parent_id = 0 order by ware_id asc;
select * from t_ware_category
where parent_id = 0 order by ware_id desc ;
rownum
a)查询前20条商品记录
select ware_id,ware_name,pricefrom t_ware
where rownum = 20;
b)查询第11条至第20条记录
select ware_id,ware_name,pricefrom t_ware
where rownum =10 and ware_id
not in(select ware_id from t_ware where rownum =10); 10、常用统计函数
a) sum()返回一个数字列或计算列的总和
select sum(price) from t_ware;b) avg()对一个数字列或计算列球平均值
c) min()返回一个数字列或一个数字表达式的最小值
d) max()返回一个数字列或一个数字表达式的最大值
e) count()返回满足select语句中指定的条件的记录值
11、多表查询和笛卡尔乘积查询商品编号,商品名称,商品价格和商品类别名称
selectt_ware.ware_id, t_ware.ware_name, t_ware.price ,t_ware_category_name
from t_ware, t_ware_category
where t_ware.category_id=t_ware_category.category_id;
使用join
a)左连接
selectt_ware.ware_id,t_ware.ware_name,t_ware.price,t_ware_category.category_name
from t_ware
left join t_ware_category
on t_ware.category_id=t_ware_category.category_id; select w.ware_id,w.ware_name,w.price,wc.category_name
from t_ware w
left join t_ware_category wc
on w.category_id=wc.category_id;
b) 右连接
select t_ware.ware_id,t_ware.ware_name,t_ware.price,t_ware_category.category_namefrom t_ware
left join t_ware_category
on t_ware.category_id=t_ware_category.category_id; 12、使用union select ware_id,ware_name
from t_ware
where ware_name like %T恤%
union
select ware_id,ware_name
from t_ware
where ware_name like %手提包% 13、使用group by
a)统计每个二级类别下有多少商品,以及商品总价值
select w.category_id,wc.category_name,count(w.ware_id),sum(w.price)
from t_ware w
left join t_ware_category wc
on w.category_id=wc.category_id
group by w.category_id,wc.category_name;
b) 统计每个一级类别下有多少商品,以及商品总价值
select wc2.category_id,wc2.category_name,sum(w.price)from t_ware w
left join t_ware_category wc
on w.category_id=wc.category_id
left join t_ware_category wc2
on wc.parent_id=wc2.category_id
group by wc2.category_id,wc2.category_name; 14、使用having对结果进行筛选
举例子说明:查询table表查询每一个班级中年龄大于20,性别为男的人数
select COUNT(*)as 20岁人数 ,classidfrom Table1
where sex= 男
group by classid,age having age 20
需要注意说明:当同时含有where子句、group by 子句 、having子句及聚集函数时,执行顺序如下:
执行where子句查找符合条件的数据;
使用group by 子句对数据进行分组;对group by 子句形成的组运行聚集函数计算每一组的值;最后用having 子句去掉不符合条件的组。
having 子句中的每一个元素也必须出现在select列表中。有些数据库例外,如oracle. having子句和where子句都可以用来设定限制条件以使查询结果满足一定的条件限制。 having子句限制的是组,而不是行。where子句中不能使用聚集函数,而having子句中可以。以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 关于SQL查询语句关键字方法
相关文章
- SQL开发知识:Oracle 12c sql 查询转换之临时表转换详解
- SQL Server评估期已过问题的解决方法
- 查询SQL Server Index上次Rebuild时间的方法
- sql语句优化之SQL Server(详细整理)
- 掌握Oracle动态SQL拼接技巧,实现查询性能优化(oracle动态sql拼接)
- Oracle分页查询实战: 构建有效的SQL语句(oracle分页sql语句)
- sql性能优化优化Oracle中PL/SQL性能的方法(oracle中pl)
- Linux添加用户:安全、简便的方法(linux添加用户和密码)
- sql掌握MySQL,才能写出精彩的SQL语句(mysql不等于如何写)
- MySQL查询:精准搜索SQL语句(mysql查询sql)
- /sql数据库应用:Oracle PL/SQL编程(oraclepl)
- 数据库使用SQL链接Oracle数据库的技术窍门(sql链接oracle)
- ”SQL Server中空字符串的判断方法(sqlserver判断)
- 在红帽企业版和CentOS上安装SQL Server的方法
- MongoDB断开连接的处理方法(mongodb关闭的连接)
- SQL Server 中的数据去重方法(sqlserver去重)
- Oracle与SQL的不同之处(oracle和sql区别)
- SQL Server数据导出表方法大揭秘!(sqlserver导出表)
- SQL Server下处理整数的方法(整数sqlserver)
- SQL与MSSQL:各有自身特性的不同之处(sql与mssql的区别)
- 方法利用SQL Server中的IN方法提升数据查询效率(sqlserver的in)
- SQL Server实现只取出年信息的方法(sqlserver只取年)
- sql探索SQL Server:前六条SQL语句(sqlserver前六条)
- sql 注入MSSQL防止SQL注入:强力防护的关键步骤(mssql阻止)
- Oracle SQL跟踪工具:优化SQL查询的得力助手(oracle跟踪sql工具)
- MySQL查询父子级关系的SQL语句(mysql 上下级sql)
- 深入比较Oracle与SQL的异同(oracle与sql比较)
- 查询Oracle SQL当天查询实战揭秘不一样的技术(oracle sql当天)
- sql多条件组合查询,并根据指定类别找出所有最小子类别的SQL语句备忘
- SQL复合查询条件(AND,OR,NOT)对NULL值的处理方法
- 在SQL查询中使用LIKE来代替IN查询的方法
- SQLServer中用T—SQL命令查询一个数据库中有哪些表的sql语句
- phpmssql扩展SQL查询中文字段名解决方法
- sql语句中单引号,双引号的处理方法
- SQL中WHERE变量ISNULL条件导致全表扫描问题的解决方法