常用SQL语句(嵌套子查询/随机等等)详细整理

网络编程 2021-07-05 13:42www.168986.cn编程入门
本文整理了一些常用的sql语句插入语句得到自动生成的递增ID值实现是1 或0 想显示为男或女/嵌套子查询/显示文章、提交人和回复时间/随机提取条记录的例子等等太多了就不一一讲了,感兴趣的朋友可以聊接下
1.SQL 插入语句得到自动生成的递增ID值
代码如下:

insert into Table1(Name,des,num) values ('ltp','thisisbest',10);
select @@identity as 'Id'

2.实现是1 或0 想显示为男或女
代码如下:

select name,Sex=(case Sex when '1' then '男' when '0' then '女' end) from Tablename

3.嵌套子查询
代码如下:

select a,b,c from Table1 where a IN (select a from Table2)

4.显示文章、提交人和回复时间
代码如下:

select a.title,a.username,b.adddate from tablename a,(select max(adddate) adddate from tablename where tablename.title=a.title) b

5.随机提取条记录的例子
代码如下:

SQL ServerSelect Top 10 From Tablename Order By NewID()

AessSelect Top 10 From Tablename Order By Rnd(ID)

Rnd(ID) 其中的ID 是自动编号字段,可以利用其他任何数值来完成,比如用姓名字段UserName

Select Top 10 From 表Order BY Rnd(Len(UserName))

MySqlSelect From 表Order By Rand() Limit 10

6.在同一表内找相同属性的记录
代码如下:

select UserID from Aounts_Users where UserName is not null group by UserID having count ()>1

7.查询类别所有的产品对应数据
代码如下:

SELECT CategoryName,ProductName FROM Categories LEFT JOIN Products ON Categories.CategoryID = Products.CategoryID;

8.按范围查询编号在2 到5 之间的用户信息
代码如下:

select from UserValue where UserID between 2 and 5;

9.日程安排提前5 分钟提醒
代码如下:

Select from TabSchedule where datediff(minute,getdate(),开始时间)<5

10.得出某日期所在月份的最大天数
代码如下:

SELECT DAY(DATEADD(dd, -DAY('2008-02-13'),DATEADD(mm, 1, '2008-02-13'))) AS 'DayNumber'

11.按姓氏笔画排序
代码如下:

Select From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as

12.通配符的一些用法
代码如下:

1.select from tablename where column1 like '[A-M]%' 这样可以选择出column 字段中首字母在A-M 之间的记录
2.select from tablename where column1 like '[ABC]%' 这样可以选择出column 字段中首字母是A 或者B 或者C 的记录
3.select from tablename where column1 like '[A-CG]%' 这样可以选择出column 字段中首字母在A-C 之间的或者是G 的记录
4.select from tablename where column1 like '[^C]%' 这样可以选择出column 字段中首字母不是C 的记录

13.复制表结构(只复制结构,源表名a,目标表名b)
代码如下:

select into b from a where 1<>1 或 select 0 into [b] from [a]

14.复制表数据(复制数据,源表名a,目标表名b)
代码如下:

insert into b(Name,des,num) select Name,des,num from Table1;

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by