常用经典SQL语句
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
常用经典SQL语句
5.3 常用经典SQL语句
本节将列出一些在平常开发过程中会用到的比较经典的SQL语句,常常用于实现一些很特别的功能。
1.SQL插入语句得到自动生成的递增ID值
1.insert into Table1(Name,des,num) values ('ltp','thisisbest', 10);
2.
3.select @@identity as'Id'
2.实现是1或0想显示为男或女
1.select name,Sex=
2.
3.case Sex
4.
5.when '1' then '男'
6.
7.when '0' then '女'
8.
9.end
10.
11.from Tablename
3.嵌套子查询
1.select a,b,c from T able1 where a IN (select a from Table2)
4.显示文章、提交人和最后回复时间
1.select a.title,ername,b.adddate
2.
3.from tablename a,(select max(adddate) adddate from ta blename where
4.
5.tablename.title=a.title) b
5.随机提取条记录的例子
1.SQL Server:Select Top 10 * From Tablename Order By NewID()
2.
3.Access:
Select Top 10 * From Tablename Order By Rnd(ID)
4.
5.
6.
7.Rnd(ID) 其中的ID是自动编号字段,可以利用其他任何数值来完成,
8.比如用姓名字段UserName)
9.
10.Select Top 10 * From 表Order BY Rnd(Len(UserName))
11.
12.MySql:Select * From 表Order By Rand() Limit 10
6.在同一表内找相同属性的记录
1.select UserID from Accounts_Users
2.
3.where UserName is not null
4.
5.group by UserID
6.
7.having count (*)>1
7.查询类别所有的产品对应数据
1.SELECT CategoryName,ProductName
2.
3.FROM Categories LEFT JOIN Products
4.
5.ON Categories.CategoryID = Products.CategoryID;
8.按范围查询编号在2到5之间的用户信息
1.select * from UserValue where UserID between 2 and 5
9.日程安排提前5分钟提醒
1.Select * from TabSchedule where datediff(minute,getdate (),开始时间)<5
10.得出某日期所在月份的最大天数
1.SELECT DAY(DATEADD(dd, -DAY('2008-02-
13'),DATEADD(mm, 1,
2.'2008-02-13')))
3.
4.AS 'DayNumber'
11.按姓氏笔画排序
1.Select * From TableName Order By CustomerName Colla te
2.Chinese_PRC_Stroke_ci_as
12.通配符的一些用法
1.1select * from tablename where column1 like '[A-M]%'
2.
3.这样可以选择出column字段中首字母在A-M之间的记录
4.
5.2select * from tablename where column1 like '[ABC]%'
6.
7.这样可以选择出column字段中首字母是A或者B或者C的记录
8.
9.3select * from tablename where column1 like '[A-CG]%'
10.
11.这样可以选择出column字段中首字母在A-C之间的或者是G的记录
12.
13.4select * from tablename where column1 like '[^C ]%'
14.
15.这样可以选择出column字段中首字母不是C的记录
16.
17.单字符(关键字:like _):
18.
19.通过使用下滑线字符(_),可以匹配任意单个字符
20.
21.select * from tablename where column1 like 'M_cr osoft'
22.
23.匹配特殊字符:([ ] _ - %)
24.
25.把它们都放到[]中就行了,比如:
26.
27.select * from tablename where column1 like '%[% ]%'
13.复制表结构(只复制结构,源表名:a,目标表名:b)
1.select * into b from a where 1<>1
2.或
3.select top 0 * into [b] from [a]
14.复制表数据(复制数据,源表名:a,目标表名:b)
1.insert into b(Name,des,num) select Name,des,num from
Table1;
15.编辑一个列
1.增加列:
2.
3.alter table Table1 add username varchar(30) not null defa ult''
4.
5.修改列:
6.
7.alter table Table1 alter column username varchar(40)
8.
9.删除列:
10.
11.alter table Table1 drop column username
16.修改时间字段的小时部分
--把所有时间2006-11-1的数据 23点修改为 21点
1.update Ad_Browse_20061101
2.
3.set browsetime='2006-11-01 21'+
4.
5.SUBSTRING(CONVERT(VARCHAR(30),browsetime,8),3,7)
6.
7.where DATEPART(Hour,browsetime)=23
【责任编辑:董书 TEL:(010)68476606】。