一些在平常开发过程中会用到的比较经典的 SQL 语句,常常用于实现一些很特别的功能。

一些在平常开发过程中会用到的比较经典的 SQL 语句,常常用于实现一些很特别的功能。

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

2.实现是1或0想显示为男或女

sql 复制代码
          select name,Sex=
            case Sex
            when '1' then '男'
            when '0' then '女'
            end
          from Tablename

3.嵌套子查询

sql 复制代码
select a,b,c from Table1 where a IN (select a from Table2)

4.显示文章、提交人和最后回复时间

sql 复制代码
 select a.title,a.username,b.adddate
          from tablename a,(select max(adddate) adddate from tablename where
              tablename.title=a.title) b

5.随机提取条记录的例子

sql 复制代码
          SQL Server:Select Top 10 * From Tablename Order By NewID()
          Access:Select Top 10 * From Tablename Order By Rnd(ID)
          Rnd(ID) 其中的ID是自动编号字段,可以利用其他任何数值来完成,比如用姓名字段UserName)
          Select Top 10 * From 表Order BY Rnd(Len(UserName))
          MySql:Select * From 表Order By Rand() Limit 10

6.在同一表内找相同属性的记录

sql 复制代码
          select UserID from Accounts_Users
          where UserName is not null
          group by UserID
          having count (*)>1

7.查询类别所有的产品对应数据

sql 复制代码
SELECT CategoryName,ProductName FROM Categories LEFT JOIN Products ON Categories.CategoryID = Products.CategoryID;

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

sql 复制代码
          select * from UserValue where UserID between 2 and 5

9.日程安排提前5分钟提醒

sql 复制代码
          Select * from TabSchedule where datediff(minute,getdate(),开始时间)<5

10.得出某日期所在月份的最大天数

sql 复制代码
          SELECT DAY(DATEADD(dd, -DAY('2008-02-13'),DATEADD(mm, 1, '2008-02-13')))
              AS 'DayNumber'

11.按姓氏笔画排序

sql 复制代码
          Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as

12.通配符的一些用法

sql 复制代码
          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的记录

单字符(关键字:like _)​:

sql 复制代码
          通过使用下滑线字符(_),可以匹配任意单个字符
          select * from tablename where column1 like 'M_crosoft'

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

sql 复制代码
          select * into b from a where 1<>1
          或
          select top 0 * into [b] from [a]

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

sql 复制代码
          insert into b(Name,des,num) select Name,des,num from Table1;

15.编辑一个列

sql 复制代码
          增加列:
          alter table Table1 add username varchar(30) not null default ''
          修改列:
          alter table Table1 alter column username varchar(40)
          删除列:
          alter table Table1 drop column username

16.修改时间字段的小时部分

sql 复制代码
          --把所有时间2006-11-1的数据 23点 修改为 21点
          update Ad_Browse_20061101
          set browsetime='2006-11-01 21'+
          SUBSTRING(CONVERT(VARCHAR(30),browsetime,8),3,7)
          where DATEPART(Hour,browsetime)=23
相关推荐
这个DBA有点耶10 分钟前
时序数据库选型:吞吐、压缩与查询延迟的均衡之术
数据库·sql·架构·时序数据库·dba
luck_bor13 分钟前
数据库简介
数据库·oracle
hikktn23 分钟前
Oracle批量UPDATE空值覆盖陷阱:CASE WHEN优雅防御方案【宗申集团】
数据库·oracle
Han_han91927 分钟前
数据库基本操作:
数据库
J.Kuchiki40 分钟前
【PostgreSQL 内核学习:平衡 K 路归并(Balanced k-way Merge)】
数据库·学习·postgresql
xieliyu.1 小时前
MySQL 全套入门笔记:基础、库操作、数据类型
数据库·笔记·mysql
lvbinemail1 小时前
【无标题】
数据库·postgresql·zabbix·监控
技术小甜甜1 小时前
[办公效率] Excel 表格越做越乱,先整理字段、格式还是公式?
数据库·excel·办公效率·数据整理
Data-Miner1 小时前
休闲食品行业数据分析平台建设方案,揭秘增长新引擎!
大数据·数据库·数据分析
invicinble1 小时前
sql层面语法的总结(mysql层面语法,主要侧重于sql的查询相关的信息量积累)
sql·mysql·oracle