1、连接字符串

  SQL Server 身份验证,如:"server=yqzhu-peter;database=WindWMNew1_DB;uid=sa;pwd=ABcd1234;Connect Timeout=1000"

2、sa(system administrator),dbo(database owner)

3、SQL 不区分大小写,包括sql语句,数据库名,表名,字段名,变量名,函数名,以及字段中实际值的比较

use wfc_db
go create table TestCase(
Id int,
CaseName varchar(20),
UpdateDate datetime
) alter table testcase
add [from] varchar(20) insert into Dbo.TestCase
values(1, '', Getdate(), 'shanghai')
insert into Dbo.TestCase
values(2, '', Getdate(), 'NANJING') select * from Dbo.TestCase declare @aa varchar(20)
select @aa = 'SHANGHAI'
print @AA
if @AA = (select [from] from testcase)
print 'yes'
else
print 'no' select [from] from testcase
DELETE FROM TESTCASE WHERE ID = 2

  1、当对象名为sql中的关键字时,需要用[]包括

  2、创建表时,字段默认是可空的

4、in的两种基本使用方式:

  1、简单的方式:select * from testcase where [from] in ('shanghai')

  2、组合方式: select * from testcase where [from] in (select [from] from testcase where datediff(day, updatedate, getdate()) = 4)

   注意该方式的select子句返回必须为一维表,否则会报错

5、 批量插入:  insert into persons(name, classId)  select name, 1 from students  

      或       insert into persons(name, classId)  values ('cheng', 1), ('cheng2', 2), ('cheng3', 3),     

6、可以定义表变量:

    DECLARE @temptb TABLE (

      [id] int identity(1,1),
      UserID varchar(50)
    )

  该变量常用于字符串的处理

7、自定义函数:

  有三种类型: 1、标量函数 2、内联表值函数 3、多语句表值函数

  详细可参考: 1、SQL Function 自定义函数

         2、SQLServer:FUNCTION/CURSOR/PROCEDURE/TRIGGER

         3、SQL Server游标的使用【转】

8、查询重复记录

  distinct关键字只能去除重复字段,而不能用于多个字段,如select distinct name from tb_student可行,但select distinct name, age from tb_student会报错

  查询重复记录方式是使用group by及having子句,如

select wid, count(*) from TB_CustLotteryInfo
where [datetime] > ''
group by wid
having count(*) > 3

9、存储过程返回数据的三种方式:

  a、通过select,返回标量值或table

    对应标量值,sql:select 1,c#:dt.Rows[0][0].ToString()

  b、output关键字,可以参考SQLServer:FUNCTION/CURSOR/PROCEDURE/TRIGGER

    这种方式应用在sql调用存储过程

  c、影响的行数

  sql中return的作用是使存储过程立即返回,与其他编程语言的return不同

10、游标的使用,详细可参考: SQL Server游标的使用【转】

使用C#定义一个DBHelper,并兼容多种类型的数据库

实例源码DBHelperTest.rar

说明:

1、当记录的某列为可空时,应当判断是否为DBNull.Value再进行类型转换,如:

  FirstName = reader["FirstName"] == DBNull.Value ?  "" : (string)reader["FirstName"];

2、表Employees的模式

create table Employee(
id int IDENTITY(1,1) primary key,
FirstName varchar(255),
SecondName varchar(255),
Salary decimal(10, 2)
)

  存储过程SP_DeleteEmployeeById

ALTER PROCEDURE [dbo].[SP_DeleteEmployeeById](
@ids varchar(100)
)
AS
BEGIN
declare @temptb table(
id int
)
declare @index int
declare @str varchar(10)
select @str = @ids
select @index = charindex(',', @str)
while @index > 1
begin
insert into @temptb values(cast(left(@str, @index - 1) as int))
select @str = right(@str, len(@str) - @index)
select @index = charindex(',', @str)
end
insert into @temptb values(cast(@str as int)) delete from dbo.Employees where id in (select id from @temptb)
END

  存储过程SP_GetEmployees

ALTER PROCEDURE [dbo].[SP_GetEmployees](
@id int
)
AS
BEGIN
if @id = 0
select * from dbo.Employees
else
select * from dbo.Employees where id = @id
END

参考:1、数据库访问类DBHelper  2、如何做个好用的数据库访问类

SQL Server使用笔记的更多相关文章

  1. SQL Server -- 回忆笔记(五):T-SQL编程,系统变量,事务,游标,触发器

    SQL Server -- 回忆笔记(五):T-SQL编程,系统变量,事务,游标,触发器 1. T-SQL编程 (1)声明变量 declare @age int (2)为变量赋值 (3)while循环 ...

  2. 【SQL Server学习笔记】Delete 语句、Output 子句、Merge语句

    原文:[SQL Server学习笔记]Delete 语句.Output 子句.Merge语句 DELETE语句 --建表 select * into distribution from sys.obj ...

  3. sql server 常见问题笔记

    1.关于复制类型 快照发布:发布服务器按预定的时间间隔向订阅服务器发送已发布数据的快照. 事务发布:在订阅服务器收到已发布数据的初始快照后,发布服务器将事务流式传输到订阅服务器. 对等发布:对等发布支 ...

  4. sql server 2008笔记

    sql server 2008开启远程访问数据库 1.以windows验证模式进入数据库管理器. 第二步:右击sa,选择属性: 在常规选项卡中,重新填写密码和确认密码(改成个好记的).把强制实施密码策 ...

  5. SQL server 学习笔记1

    1.查询安装的排序规则选项喝当前的排序规则服务器属性 select * from fn_helpcollations(); 2.查看当前服务器的排序规则 select serverproperty(' ...

  6. SQL Server 自学笔记

    --★★★SQL语句本身区分大小写吗 --SQLServer 不区分大小写 --Oracle 默认是区分大小写的 --datetime的输入格式,2008-01-07输入进去后显示为1905-06-2 ...

  7. SQL Server -- 回忆笔记(四):case函数,索引,子查询,分页查询,视图,存储过程

    SQL Server知识点回忆篇(四):case函数,索引,子查询,分页查询,视图,存储过程 1. CASE函数(相当于C#中的Switch) then '未成年人' else '成年人' end f ...

  8. SQL Server -- 回忆笔记(三):ADO.NET之C#操作数据库

    SQL Server知识点回忆篇(三):ADO.NET之C#操作数据库 1.连接数据库 (1)创建连接字符串: 使用windows身份验证时的连接字符串: private string conStr= ...

  9. SQL Server -- 回忆笔记(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询

    SQL Server知识点回忆篇(二):增删改查,修改表结构,约束,关键字使用,函数,多表联合查询 1. insert 如果sql server设置的排序规则不是简体中文,必须在简体中文字符串前加N, ...

  10. SQL Server -- 回忆笔记(一):初见数据库

    SQL Server知识点回忆篇(一):初见数据库 1.  主键 primary key    唯一标识, 不会重复的值才会用来当做主键使用. 表可以没有主键,但建议每张表都有主键. 2.  数据冗余 ...

随机推荐

  1. redis底层设计(三)——redis数据类型

    今天我们来看一下redis的数据类型.既然redis的键值对可以保存不同类型的值,那么很自然就需要对键值对的类型进行检查以及多态处理.下面我们将对redis所使用的对象系统进行了解,并分别观察字符串. ...

  2. JenKins自动化构建部署流程参考

    Jenkins工作流程 程序员提交代码到Git/SVN仓库,触发钩子程序向 JenKins 进行通知,Jenkins 调用Git/SVN插件获取源码,调用Maven打包为war包,调用Deploy t ...

  3. .NetCore简单学习图谱

    一.学习途径 学习.netcore的最佳途径在哪里,无疑是微软官方.netCore指南.它覆盖十分全面,就目前网上经常看到的各种文章都能在微软处找到类似文章,堪称.netcore的百科全书.所以我利用 ...

  4. Item 13: 比起iterator优先使用const_iterator

    本文翻译自modern effective C++,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 博客已经迁移到这里啦 STL中的const_iterator等价于pointers-to ...

  5. Python全栈开发之路 【第八篇】:面向对象编程设计与开发(2)

    一.继承与派生 什么是继承? 继承指的是类与类之间的关系,是一种什么是什么的关系,继承的功能之一就是用来解决代码重用问题. 继承是一种创建新的类的方式,在python中,新建的类可以继承一个或多个父类 ...

  6. HDU - 1255 扫描线+离散化进阶

    这道题最开始我以为和HDU - 1542 那道题一样,只需要把cover次数改成2次即可,但是后面仔细一想,我们需要求的是覆盖次数大于等于2次的,这样的话,我们需要维护两个长度,HDU-1542 由于 ...

  7. HDU - 1754 线段树-单点修改+询问区间最大值

    这个也是线段树的经验问题,待修改的,动态询问区间的最大值,只需要每次更新的时候,去把利用子节点的信息进行修改即可以. 注意更新的时候区间的选择,需要对区间进行二分. #include<iostr ...

  8. c++入门之 再话类

    对于类,其结构并不难,但要理解其设计思想也并不容易,在此,我们可以通过下面的代码进一步理解和使用类: # ifndef VECTOR_H_ # define VECTOR_H_ # include & ...

  9. java.lang.LinkageError: JAXB 2.0 API is being loaded from the bootstrap classloader

    我的解决办法:    1.如果是application工程,则在程序中打印出         system.out.println(System.getProperty("java.endo ...

  10. jQuery实现Ajax请求时,页面显示等待的效果,超过指定请求时间后,进行其他操作

    背景:有一个按钮,点击之后向后端程序发起Ajax请求,在请求结果没有返回之前,页面显示等待的效果,此时仍旧是异步请求,等待的效果在接收到结果后撤销. 需求:因为网络延迟或者后端程序的问题,在发起Aja ...