您好,欢迎访问一九零五行业门户网

SQL Server 搜索技巧随记

平时做项目过程中,会遇到各种问题,如 sql server 中的查询,有时一些棘手的问题,可能最终解决,但会费很大的劲,但如果了解某些技巧,却能事半功倍。 1、空记录的处理。 之前在做机房收费系统时,日结账单中,需要对数据汇总,但汇总结果可能为null,那么
        平时做项目过程中,会遇到各种问题,如 sql server 中的查询,有时一些棘手的问题,可能最终解决,但会费很大的劲,但如果了解某些技巧,却能事半功倍。
1、空记录的处理。
        之前在做机房收费系统时,日结账单中,需要对数据汇总,但汇总结果可能为null,那么如何把这种情况下的null转成0呢?在客户端程序中进行处理?那肯定比较费事!有没有更好的办法?——这时可以用到isnull(,)函数。如:
-- =============================================-- author: 张连海-- create date: 2013.09.28-- description: 用于机房收费系统中结账,查询相应的信息-- =============================================alter procedure [dbo].[proc_selectaccounts] @operateusername varchar(20), @issettleaccounts varchar(10)asbegin select (select isnull(count(cardno),0) from t_register where reguser =@operateusername and issettleaccounts=@issettleaccounts) as '售卡张数', (select isnull(count(cardno),0) from t_absentcard where abcarduser =@operateusername and issettleaccounts=@issettleaccounts) as '退卡张数', (select isnull(sum(recmoney),0) from t_recharge where recuser=@operateusername and issettleaccounts=@issettleaccounts) as '充值金额', (select isnull(sum(abcardmoney),0) from t_absentcard where abcarduser=@operateusername and issettleaccounts=@issettleaccounts) as '退卡金额', (select isnull(count(cardno),0) from t_register where reguser =@operateusername) as '总售卡张数'end
2.insert一句话实现插入一条数据并且返回这条数据的某列 。
        在做“善良公社”项目时,用到关系表,其中在往别的表里添加数据时,插入一条数据之后(id为自动增长列),返回该条数据的id,再存入该关系表。最好插入和返回不存在时间差。即:不选择先insert然后再select,有无根据sql server机制,直接插入的同时返回。
--可使用如下代码:insert into [table] output inserted.columnname values()--举例:insert into 用户信息表 (name) output inserted.id values(张三)
3.实现是1 或0 想显示为男或女
        数据库对于数据的存储可能会用到某种标记,比如“1”表示“男”,“0”表示“女”;“y”表示“已结账”,“n”表示“未结账”,如何在查询时进行自动转换?
select name,sex=(case sex when '1' then '男' when '0' then '女' end) from tablename
4.按姓氏笔画排序
        我们在书籍的鸣谢中或参与人员中,经常看到人名是按姓氏笔画进行排序的。那么sql server中如何实现?
select * from tablename order by customername collate chinese_prc_stroke_ci_as
5.……………………
学习在继续,随记在继续。点点滴滴,相信定会汇成江海!
其它类似信息

推荐信息