create table #temp
(
id int identity(1,1),
name varchar(20),
startYear int,
startMonth int
)
insert into #temp
select 'z','2010','12' union all
select 'e','2011','11' union all
select 'a','2011','2' union all
select 'b','2011','5' union all
select 'c','2011','10' union all
select 'd','2011','7'
--查询早于等于指定日期的数据
declare @condition varchar(6)
set @condition='201110'
select * from #temp A
where
(case when LEN(A.startMonth)=1 and A.startMonth!=0 then cast((CAST(startYear as varchar(4))+'0'+cast(A.startMonth as varchar(1))) as date)
when LEN(A.startMonth)=2 then cast(CAST(startYear as varchar(4))+cast(A.startMonth as varchar(2)) as date) end) <=cast(@condition as date)
分享到:
相关推荐
在 SQL 查询语言中,`CASE WHEN` 结构是一种非常有用的工具,可以用来根据条件返回不同的值。它的工作原理类似于编程语言中的 `if...else` 语句,但在 SQL 中用于创建动态列或进行复杂的条件判断。 #### 基本语法 ...
在SQL Server中,`CASE WHEN` 语句是一种强大的逻辑表达式,用于处理基于不同条件的复杂查询。在多条件模糊查询中,`CASE WHEN` 可以避免在程序端或数据库端拼接SQL字符串,从而减少代码量,提高安全性,并避免SQL...
在SQL Server中,CASE表达式是一种强大的工具,用于在查询中进行条件判断和逻辑操作。它的功能远不止创建新字段那么简单,而是可以在多个方面增强你的SQL查询能力。以下是对CASE关键字在SQL Server中不同用法的详细...
### CDC操作Sqlserver2008 #### 概述 变更数据捕获(Change Data Capture,简称CDC)是SQL Server的一项重要功能,主要用于记录数据库表中的数据更改历史。这一功能在进行数据分析、日志记录、数据复制等场景下...
最后,在HAVING子句中使用Case函数可以在对分组后的数据进行过滤时增加条件逻辑: ```sql SELECT Category, AVG(Price) AS AveragePrice FROM Products GROUP BY Category HAVING CASE WHEN AVG(Price) > 80 THEN ...
需要注意的是,PIVOT 和 UNPIVOT 语句只能在 SQL Server 2005 及更高版本中使用。在 SQL Server 2000 中,需要使用 CASE 语句配合聚合函数或 UNION 语句来实现行列转换。 在实际应用中,行列转换可以用于数据分析和...
SQL Server 2008 实验答案 ...本资源提供了 SQL Server 2008 的实验答案,涵盖了 SELECT 语句、查询特定列、使用 DISTINCT 关键字、使用 WHERE 子句、使用 CASE 语句、使用 Aggregate 函数和使用子查询等知识点。
5. **是否主键**:(CASE WHEN (SELECT COUNT(*) FROM sysobjects WHERE (name IN (SELECT name FROM sysindexes WHERE (id = a.id) AND (indid IN (SELECT indid FROM sysindexkeys WHERE (id = a.id) AND (colid IN...
在选择使用存储过程或自定义函数时,如果需要执行一系列操作、处理条件分支或动态SQL,通常使用存储过程。如果需要在查询中嵌入计算或返回单一值,那么用户定义函数更合适。 3. 统计特定日期的胜利和失败次数: ...
以上内容主要介绍了 SQL Server 中存储过程中的一些基本语法和操作方法,包括变量定义及赋值、表和临时表的操作、循环以及条件语句等,这些知识点对于理解和使用 SQL Server 存储过程至关重要。
在数据库迁移项目中,从Oracle迁移到SQL Server是一种常见的场景。本文旨在提供一份详细的指南,帮助开发者更好地理解这两种数据库系统在存储过程方面的语法差异,并指导如何进行有效的转换。 #### 一、基本语法...
### 使用SQL查询生成SQL Server数据库结构字典并输出为HTML 在进行数据库管理与维护时,经常需要了解数据库中的各种对象及其属性。SQL Server数据库字典可以帮助我们清晰地看到每张表的结构、各字段的定义等信息。...
标题“SQLServer获取2019年节假日列表”表明我们需要关注的是如何在SQL Server中查询并提取特定年份,比如2019年的公共假期信息。这通常涉及到设计日期表、编写查询脚本以及可能使用内置或自定义函数来实现。 首先...
这里没有使用 `GROUP BY`,而是直接在 `SELECT` 子句中进行条件判断。如果学生没有某一科目的成绩,则会显示为0。 ### 方法三:使用多表联接 除了上述方法外,还可以使用多个表之间的左连接来实现行转列。这种方法...
在SQL语言中,可以使用Update表名Set字段名=case字段名when值1then值2else值三endFrom表名Where条件语句来实现条件语句的写法。 四、取余函数Mod() 在PB脚本中,可以使用Mod(要取余数的值,取余值)函数来实现取余数...
其他四种方法展示了更复杂的技巧,例如使用`COLUMNPROPERTY`函数检查列是否隐藏或计算得到,利用`CASE`语句根据条件选择性地展示列,创建视图简化查询过程,以及使用动态SQL构建灵活的查询语句。 #### 4. 查询被...
在SQL Server中,逻辑表达式是构建复杂查询和控制流程的关键元素。它们允许数据库操作根据特定条件执行不同的操作,从而增强了SQL语言的功能性和灵活性。以下是对给定文件中提到的几种涉及逻辑表达式的SQL Server...
在SQL Server面试中,了解和熟练掌握SQL语言是至关重要的。以下是一些常见的SQL Server面试题及相关的知识点解析: 1. 查询每门课都大于80分的学生姓名: 这个问题涉及到子查询和聚合函数。解决方案是通过找出所有...
在 SQL Server 中,查询优化是非常重要的。通过编写高效的 SQL 语句,可以大大提高查询速度。例如,使用索引、优化查询顺序、减少 JOIN 操作等方法可以提高查询效率。 二、查询员工信息 在员工信息表中,需要查询...