不简单的SQL查询和排序语句
真不简单!!

一:使用select语句进行查询
语法:
SELECT <列名>
FROM <表名>
[WHERE <查询条件表达式>]
[ORDER BY <排序的列名>[ASC或DESC]]
eg1:
SELECT SCode,SName,SAddress
FROM Students
WHERE SSEX = 0
ORDER BY SCode
二:查询所有列和行:
eg:
SELECT * FROM Course
SELECT * FROM Students
三:查询部分列
eg:
SELECT SName, SAddress FROM Students
SELECT SName ,SGrade FROM Students
WHERE SAddress = '北京'
四:列别名
eg:
SELECT SCode AS 学生编号,SName AS 学生姓名,
SAddress AS 学生地址
FROM Students
WHERE SAddress <> '河南新乡'
SELECT FirstName + '.' + LastName AS 姓名
FROM Employees
注意:
1. + 连接的数据类型必须兼容
2. 如果 + 连接字符型数据,结果为字符串数据的连接
3. 如果 + 连接数值型数据,结果为数值的和
五:使用等号命名列
eg:
SELECT 姓名 = FirstName+'.'+LastName
FROM Employees
六:查询空行
eg:
SELECT SName FROM Students WHERE SEmail IS NULL
七:使用常量列
eg:
SELECT 姓名=SName,地址= SAddress , '北京新兴桥' AS 学校名称
FROM Students
八:限制固定行数
eg:
SELECT TOP 5 SName, SAddress
FROM Students WHERE SSex = 0
九:按百分数返回行
SELECT TOP 20 PERCENT SName, SAddress
FROM Students WHERE SSex = 0
十:相关练习:
SELECT StudentID,Score FROM Score ORDER BY Score
SELECT StudentID AS 学生编号,(Score*0.9+5) AS 综合成绩
FROM Score
WHERE (Score*0.9+5)>60
ORDER BY Score
十二:降序排列
eg:
SELECT StudentID,Score FROM Score ORDER BY Score DESC
十三:按多列排序
eg:
SELECT StudentID AS 学生编号, CourseID AS 课程ID, Score AS 成绩
FROM Score
WHERE Score > 60
ORDER BY CourseID, Score
常见问题:
.SQL语句不区分大小写
.字符串和日期类型都需要单引号
.起表名的时候,千万不要起得太好,例如不要使用User作为表名。
如果表名和关键字重复了,我们可以通过[]取消转义。
select * from [User]
注意:新建查询窗口中的中文空格。
select * from Message
十四:常用的几类函数:

函数名称:CharIndex('str1','str2',index)//位置从开始
--参数含义:
--第一个参数:要查询的字符串
--第二个参数:在哪个字符串中搜索
--第三个参数:从str2的第几个字母开始搜索
eg:
select charindex('好好学','S1是S2的基础,所以大家好好学',1)
SELECT CHARINDEX('JBNS','My Jbns Course')
select charindex('微冷的雨','好人啊微冷的雨',4)
select charindex('妈妈说','我们要为国家争光,妈妈说,是人就要有理想',11)
len():获取小括号中字符串的长度,空格也算一个字符长度
eg:
select len('明天咱们还上课,希望大家回去好好休息')
select len('大家都是好孩子 ')
注意点:如果内容以多个空格结尾,那么结尾的多个空格,是不计算长度的
upper():将括号中出现的英文全部转换成大写
select upper('i can speak english.你能吗?')
select lower('I HAVE A DREAM')
select upper('i have a dream,俺有一个梦想')
LTrim():清除括号中内容左边的空格(left:right)
select ltrim(' 生活不是林黛玉, '
select rtrim(' 生活不是林黛玉, ')
--既想移除左边空格,也想移除右边空格
select rtrim(ltrim(' 生活, '))
select ltrim(rtrim(' 你还好吧! '))
select len(rtrim('今年奇怪了,北京没下雪, '))
substring('字符串',截取的位置,截取的长度)
select substring('好吧,我爱自己伟大的祖国,真的',6,1)
right():从字符串右边返回指定类型的字符
select left('大家今天好像都没有交日记本,我去',3)
select right('大家今天好像都没有交日记本,我去',2)
replace('str1','要替换的字符','目标字符'):
select replace('周杰伦,残疾人,虽然手不残疾,但是X残疾','残疾','好')
stuff('字符串',删除的起始位置,删除的长度,'插入的字符串')
select stuff('我爱你中国,我爱你故乡',4,2,'北京')
select stuff('我们都要有理想,为了理想我们熬夜,当然以牺体为代价',6,2,'自信')

--01.getdate():获取当前日期和时间
select getdate()
--1000ms是s
--02.dateadd(按年/月/日添加,增量,时间)
select dateadd(yy,100,'2014-8-6')
select dateadd(year,-20,getdate())
--03.datediff(按年/月/日求差,小时间,大时间)
select datediff(year,'1998-01-01',getdate())
--04.datename:获取某个日期是星期几
select datename(dw,'2014-08-06')
--05.datepart(mm,日期):获取指定日期对应的年/月/日部分
select datepart(yy,getdate())
--Year yy
--Month mm
--Day dd
--push(推) pull(拉)
--通过该方式也可以获取当天是周几
select datepart(dw,getdate())

--01.rand():产生一个到之间的随机数
select right(rand(),4)
Select rand()
--如果产生四位数(-9999)
--02.abs:取绝对值
select abs(-10)
select abs(10)
--非负数
--03.ceiling:天花板,你要看天花板,抬头,向上取整
select ceiling(1.999991)
--04.floor:向下取整
select floor(1.999999)
select ceiling(1.000000000000001)
select floor(2.999999999999999)
--04.power(5,2)求幂值
select power(4,4)
select 1*2/3+5-56+100-5/100
select power(2,3)
--05.round:将一个数字四舍五入到指定精度
select round(42.564,1)
--06.sign:如果括号中写的是一个正数,返回,如果是负数,返回-1
--如果是返回
select sign(20)
select sign(0)
--07.sqrt()开平方
select sqrt(9)

卡里面的字母“O和数字0”、“字母i和数字1”,用户反映说看不清楚,公司决定,把存储在数据库中的密码中所有的“O”都改成“0”,把所有的“i”都改成“1”;
密码列名:PassWord
UPDATE Card SET PassWord = REPLACE(PassWord ,'O','0')
UPDATE Card SET PassWord = REPLACE(PassWord ,'i','1')
2:在数据库表中有以下字符数据,如:
13-1、13-2、13-3、13-10、13-100、13-108、13-18、13-11、13-15、14-1、14-2
13-1、13-2、13-3、13-10、13-11、13-15、13-18、13-100、13-108、14-1、14-2
后半部分的数字:
使用CONVERT函数将其转换为数字:0
SELECT ListNumber
FROM SellRecord
ORDER BY
CONVERT(int, LEFT(ListNumber, CHARINDEX('-', ListNumber)-1)),
CONVERT(int, STUFF(ListNumber,1, CHARINDEX('-', ListNumber), ''))
3:
新生入学,为其分配一个Email地址
分析:
DATEDIFF(DD,BornDate, GETDATE())>=365*20
RIGHT(Email, LEN(Email) - CHARINDEX('@',Email) )
CONVERT(VARCHAR(4), DATEPART(YYYY,GETDATE()))
获取4位随机数
RIGHT(RAND(),4)
世上无难事,只怕有心人。
不简单的SQL查询和排序语句的更多相关文章
- SQL查询结果排序
<第二章:查询结果排序>1:以指定的次序返回查询结果条件:显示部门10中员工名字,职位和工资并按照工资升序排列:升序asc 降序descSELECT ename,job,sal FRO ...
- [转载]要提高SQL查询效率where语句条件的先后次序应如何写
出处:https://www.cnblogs.com/exe19/p/5786806.html 我们要做到不但会写SQL,还要做到写出性能优良的SQL语句. (1)选择最有效率的表名顺序(只在基于规则 ...
- 要提高SQL查询效率where语句条件的先后次序应如何写
我们要做到不但会写SQL,还要做到写出性能优良的SQL语句. (1)选择最有效率的表名顺序(只在基于规则的优化器中有效): Oracle的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句 ...
- sql查询的常用语句
一.基础 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database 数据库名 3.说明:备份sql server --- 创建 ...
- Oracle提高SQL查询效率where语句条件的先后次序
(1)选择最有效率的表名顺序(只在基于规则的优化器中有效): Oracle的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 driving table)将被最先处 ...
- SQL查询效率where语句条件
有索引的列优先,都有索引的看查询出来的数据量,少的优先 in ,not in,<>,is null,is not null 等由于不会走索引,尽量不要使用. WHERE子句后面的条件顺序对 ...
- 执行sql查询,并查看语句执行花费时间
declare @d datetimeset @d=getdate() select * from A PRINT '[语句执行花费时间(毫秒)]'+LTRIM(datediff(ms,@d,getd ...
- SQL查询语句备忘录
有关于SQL查询的相关语句和语法的记录!备忘与复习用 1.SQL多表联合查询 select a.字段1,a.字段2,b,字段2 from 表1 a,表2 b where a.字段1 =b.字段1 2. ...
- 提高SQL查询效率(SQL优化)
要提高SQL查询效率where语句条件的先后次序应如何写 http://blog.csdn.net/sforiz/article/details/5345359 我们要做到不但会写SQL,还要做到 ...
随机推荐
- KnockoutJS 3.X API 第四章 表单绑定(8) submit、enable、disable绑定
submit绑定目的 submit绑定即为提交绑定,通常用于form元素.这种绑定方式会打断默认的提交至服务器的操作.转而提交到你设定好的提交绑定回调函数中.如果要打破这个默认规则,只需要在回调函数中 ...
- Android开发之网络
很多初学Android开发的人员对网络这一点感觉很高大上,现在我就和大家分享一下我的学习心得. 就目前的Android手机来说,可能存在5种网络状态: ----无网络(这种状态可能是因为手机停机,网络 ...
- SQLExecption:Operation not allowed after ResultSet closed解决办法
原网址:http://blog.csdn.net/sku0923/article/details/1722370 一个stmt多个rs进行操作引起的ResultSet已经关闭错误 一个stmt多个rs ...
- 理解Docker容器的进程管理
摘要: Docker在进程管理上有一些特殊之处,如果不注意这些细节中的魔鬼就会带来一些隐患.另外Docker鼓励"一个容器一个进程(one process per container)&qu ...
- Docker 有什么优势?
1.什么是容器? 依托与linux 内核功能的虚拟化技术 2. docker 是什么? 能够把应用程序自动部署到容器的开源引擎 3. docker 跟原有的工具有何区别? 传统的部署模式是:安装(包管 ...
- 基于Metronic的Bootstrap开发框架经验总结(6)--对话框及提示框的处理和优化
在各种Web开发过程中,对话框和提示框的处理是很常见的一种界面处理技术,用得好,可以给用户很好的页面体验,Bootstrap开发也一样,我们往往在页面新增.编辑.查看详细等界面使用弹出对话框层的方式进 ...
- 一套后台管理html模版
最近自己需要一套后台管理的模版,然后去网上查找,模版的确很多,但是适合我的并不多.我需要的模版是不会很大,我能够控制代码,样式不要太古朴,最好有点CSS3的效果.最后终于找到一张主页,然后再根据这个主 ...
- RHEL6 某业务用户ulimit -a命令找不到
最终确定是shell环境问题,临时改为/bin/bash即可查看. 1.问题现象 # su - jingyu $ id uid=(jingyu) gid=(jingyu) (jingyu) $ uli ...
- html选中图片时,在页面回写图片
我们经常会遇到这种情况,就是上传一个图片,但是点击一个图片的时候,最好是可以在浏览器预览这个图片,不然用户还以为没有选择图片呢,但是浏览器的安全机制却阻止了这个问题,就是当访问的是网络上的网站的时候, ...
- C#实现通用数据过滤窗体
最近一直在做WINFORM项目,所以经常有些新的想法或尝试与大家分享,之前与大家分享了通用窗体遮罩层.通用可附加数据绑定的DataGridView.窗体渐显,今天来分享一个大家在其它软件中常见的功能: ...