SQL Server去重和判断是否为数字——OBJECT_ID的使用
sql 语句查询时去掉重复项:
使用 distinct 去掉重复项:

首先可以明确的看到存在重复的名字,那么接下来就让我们试试使用 distinct 去重吧。
select distinct * from Student

咦,怎么没效果呢?原来,distinct 是根据所查询的字段去重的。* 表示所有的字段,可以明确的看到字段 S_Id 和 S_StuNo 是不可能有重复的,因为一个为主键和自增长的标识列,一个有 unique (唯一)的约束。
既然明白了这一点,那下面就根据 S_Name,S_Sex,S_Height 这三个字段去重吧:
select distinct S_Name,S_Sex,S_Height from Student

sql判断字符串是否为数字:
方法一: 使用sql server的内置函数 ISNUMERIC():
select ISNUMERIC('') -- 返回 1
select ISNUMERIC('123.12') -- 返回 1
select ISNUMERIC('a123.12') -- 返回 0
select ISNUMERIC('abc') -- 返回 0
函数 ISNUMERIC() 返回结果为 1 表示全是数字,结果为 0 表示有除了数字的其他字符,但是“.”(小数点也会被当做其中一部分)。
方法二: 匹配字符串中是否存在除了数字之外的其他字符(小数点也算作其他字符)
if(('' not like '%[^0-9]%')) -- 数字
begin
select '数字'
end
else
begin
select '非数字'
end
if(('a123' not like '%[^0-9]%')) -- 非数字
begin
select '数字'
end
else
begin
select '非数字'
end
if(('123.1' not like '%[^0-9]%')) -- 非数字
begin
select '数字'
end
else
begin
select '非数字'
end
当然,我们也可以根据这种方式,定义一个自定义函数,这个后面再说。
sql 查询出某字段出现最多次数的值:
-- 查询出表 Student 中名字(S_Name)出现次数最多的名字
select top 1 S_Name,COUNT() from Student group by S_Name order by COUNT() desc
sql server [case when then else end]:
select S_StuNo 学号,S_Name 姓名,
case S_Sex when '男' then '男生' when '女' then '女生' else '保密' end 性别, -- 方式一
case when S_Sex='男' then '男生' when S_Sex='女' then '女生' else '保密' end 性别, -- 方式二
S_Height 身高
from Student
sql OBJECT_ID、OBJECT_NAME、OBJECT_DEFINITION:
if (OBJECT_ID('Student') is not null) --判断是否存在 Student 这个表
begin
select '表已存在'
end
else
begin
select '表不存在,请创建'
end
--指定一个临时表名,则必须在临时表名前面加上数据库名,例如:
IF OBJECT_ID('tempdb..#table1') is not null --判断临时表 table1 是否存在,
select '表已存在'
else
select '表不存在,请创建'
select OBJECT_ID('Student') -- 返回 245575913 根据对象名称返回对象ID
select OBJECT_NAME('') -- 返回 Student 根据对象ID返回对象名称
select OBJECT_DEFINITION('') --返回对象的源文本
select OBJECT_DEFINITION(OBJECT_ID('Student'))
示例,返回系统存储过程 sys.sp_columns 的定义:
SELECT OBJECT_DEFINITION (OBJECT_ID(N'sys.sp_columns'));
OBJECT_ID语法: OBJECT_ID ( '[ database_name . [ schema_name ] . | schema_name . ] object_name' [ ,'object_type' ] )
参数:
' object_name ' (必填)
是要使用的对象。 object_name是varchar或nvarchar。 如果object_name是varchar,它将隐式转换为nvarchar。 可以选择是否指定数据库和架构名称。
' object_type ' (可选)
架构范围的对象类型。 object_type是varchar或nvarchar。 如果object_type是varchar,它将隐式转换为nvarchar。
返回类型:
return int
PS:对于空间索引,OBJECT_ID 返回 NULL。出现错误时,返回 NULL。
OBJECT_NAME语法: OBJECT_NAME ( object_id [, database_id ] )
参数:
' object_id ' (必填)
要使用的对象的 ID。 object_id是int ,假定在指定的数据库中,或在当前数据库上下文中为架构范围的对象。
' database_id '(可选)
要在其中查找对象的数据库的 ID。 database_id是int。
返回类型:
return nvarchar(max)
PS:出现错误时或调用方没有查看对象的权限时,将返回 NULL。 如果目标数据库的 AUTO_CLOSE 选项设置为 ON,则此函数将打开此数据库。
用户只能查看符合如下条件的安全对象的元数据:该安全对象为该用户所有,或已授予该用户对该安全对象的权限。
也就是说,如果用户对该对象没有任何权限,则那些会生成元数据的内置函数(如 OBJECT_NAME)可能返回 NULL。
OBJECT_DEFINITION语法:OBJECT_DEFINITION ( object_id )
参数:
' object_id ' (必填)
要使用的对象的 ID。 object_id是int,和假定以表示当前的数据库上下文中的对象。
返回类型:
return nvarchar(max)
PS:出现错误时或调用方没有查看对象的权限时,将返回 NULL。 参考:
https://msdn.microsoft.com/zh-cn/library/ms176090.aspx
SQL Server去重和判断是否为数字——OBJECT_ID的使用的更多相关文章
- 在Sql Server触发器中判断操作是Insert还是Update还是Delete
在Sql Server触发器中判断操作是Insert还是Update还是Delete DECLARE @IsInsert bit, @IsUpdate bit, @IsDelete ...
- SQL SERVER 将表中字符串转换为数字的函数 (详询请加qq:2085920154)
在SQL SERVER 2005中,将表中字符串转换为数字的函数共2个:1. convert(int,字段名) 例如:select convert(int,'3')2. cast(字段名 as i ...
- SQL Server数据库存在判断语句及系统表简介 转
Transact-SQL Exists Sentences--判断数据库是否存在IF EXISTS(SELECT * FROM master.sysdatabases WHERE name=N'库名' ...
- SQL Server数据库存在判断语句及系统表简介
Transact-SQL Exists Sentences--判断数据库是否存在IF EXISTS(SELECT * FROM master.sysdatabases WHERE name=N'库名' ...
- SQL Server IF Exists 判断数据库对象是否存在的用法
1 判断数据库是否存在Sql代码 if exists (select * from sys.databases where name = ’数据库名’) drop database [数据库名] ...
- Sql Server,如何去含有非数字的nvarchar,再转为为数值
菜鸟一枚,今天做项目时,突然遇到一个问题: 在数据库中中存放的nvarchar类型的“时间”,例如:‘08:00’,而我需要进行时间的范围比较,这时就想到了将nvarchar类型转化为int类型. 这 ...
- sql server case when 判断为空
代码如下 select distinct G.* ,(select BUSINESS_NAME from BusinessInfo where BusinessInfo.BUSINESS_BID=G. ...
- sql server生成自动增长的字母数字字符串
在开发的过程中,我们经常会遇到要生成一些固定格式字符串,例如“BX201903150001”,结构为:BX+日期+N位序号,类似这种的字符串我们很难生成,在这里我们借助一个存储过程来实现这个功能. 1 ...
- SQL Server提取字段中的所有数字
今天公司项目中遇到了一个需求,要求提取用户电话号码字段中的所有电话信息. 由于该字段在项目最初设计中没有严格控制数据质量,导致用户在输入时包含了很多非电话的信息,如用户名字等(136 **** *** ...
随机推荐
- 欧拉函数 & 【POJ】2478 Farey Sequence & 【HDU】2824 The Euler function
http://poj.org/problem?id=2478 http://acm.hdu.edu.cn/showproblem.php?pid=2824 欧拉函数模板裸题,有两种方法求出所有的欧拉函 ...
- 谈谈Jquery ajax中success和complete有哪些不同点
记录下,以备将来有需时用 http://www.jb51.net/article/75206.htm
- django头像上传详解
使用form组件上传头像 实现的效果如下: 将默认的上传文件框隐藏起来变成了一个默认的头像 而且可以点击上传 处理步骤 avatar = forms.FileField( widget = widge ...
- m2014-c->c模拟java的hashmap容器类
转自:http://bbs.csdn.net/topics/390034346 在java中像ArrayList,HashMap都是现成的,在java.util包中,用的时候直接import java ...
- 常用SEO优化技巧
SEO是指搜索引擎优化 搜索引擎优化是一种利用搜索引擎的搜索规则来提高目前网站在有关搜索引擎内的自然排名的方式.SEO的目的理解是:为网站提供生态式的自我营销解决方案,让网站在行业内占据领先地位,从而 ...
- js 连等赋值 分析
JavaScript权威指南-第6版 4.11 赋值表达式 提到了连等赋值的情况,但是解释的不够详细,所以在此总结下: 首先看书上最重要的一句话: 这句话总结下就是: A = B ; // 整个表达式 ...
- 区分兼容IE6/IE7/IE8/IE9/FF的CSS HACK写法
HACK原理:不同浏览器对各中字符的识别不同 在 CSS中常用特殊字符识别表: (1)*: IE6+IE7都能识别*,而标准浏览器FF+IE8是不能识别*的; (2)!important: 除IE6 ...
- 转载hiberinate的懒加载
Hibernate的强大之处之一是懒加载功能,可以有效的降低数据库访问次数和内存使用量.但用的不好就会出现org.hibernate.LazyInitializationException. 这个异常 ...
- Python全栈day21(函数的解耦)
针对上一篇对文件的操作程序,执行一次操作的函数查询,添加,修改,删除都需要在函数里面定义文件处理的过程,整体函数看起来比较乱,代码重复过多 下面新定义一个函数专门用于处理文件操作,然后在不同的函数里面 ...
- R语言中聚类确定最佳K值之Calinsky criterion
Calinski-Harabasz准则有时称为方差比准则 (VRC),它可以用来确定聚类的最佳K值.Calinski Harabasz 指数定义为: 其中,K是聚类数,N是样本数,SSB是组与组之间的 ...