实现多数据库的访问

如果为了实现数据库操作类DbHelperSQL能同一项目支持多个数据库访问的情况,则可以保留原来带有的连接字符串参数的方法,实现方法的重载。例如:

1.     public static int ExecuteSql(string SQLString)  

2.     {  

3.     }  

4.     public static int ExecuteSql(string conString, string SQLString)  

5.     {  

6.     }  

7.     public static int ExecuteSql(string SQLString, params SqlParameter[] 
cmdParms)  

8.     {  

9.     }  

10. public static int ExecuteSql(string conString, string SQLString,  

11.         params SqlParameter[] cmdParms) 

12. {  

13. 

如果只有一个数据库,则直接使用默认的无连接字符串参数的方法会比较简洁,当需要改变数据库时,只需要把不同的数据库连接字符串传进去就可以了。

当然,我们可以把stringconString抽象出去,作为公共属性,在构造函数中被动态地传递进来,也可以支持不同数据的访问。例如:

1.     //<summary> 

2.     //数据访问类,可用于访问不同数据库 

3.     //</summary> 

4.     public class DbHelperSQLP 

5.     {     

6.         public string connectionString = PubConstant.ConnectionString;   

7.         public DbHelperSQLP(string ConnectionString) 

8.         { 

9.             connectionString = ConnectionString;     

10.     } 

11.     public int ExecuteSql(string StrSql)  

12.     { 

13.         using (SqlConnection connection = new SqlConnection(conString)) 

14.         { 

15.             using (SqlCommand cmd = new SqlCommand(StrSql, connection)) 

16.             { 

17.                 connection.Open(); 

18.                 int rows = cmd.ExecuteNonQuery(); 

19.                 return rows;  

20.             } 

21.         } 

22.     } 

23.     public int ExecuteSql(string SQLString, params SqlParameter[] cmdParms) 

24. {  

25.     ……// 

26. }  

27. }  

28. 调用代码:  

29. DbHelperSQLP dbHelperSQL = new DbHelperSQLP(connectionString2); 

30. dbHelperSQL.ExecuteSql(strSql); 

通过以上示例,我们阐述了如何对工作中常用的共性的数据访问代码进行抽象和封装,从而达到复用及提高工作效率的目的。从而使我们的代码更简洁,更易于维护。

 

 常用经典SQL语句

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

1.SQL插入语句得到自动生成的递增ID值

1.     insert into Table1(Name,des,num) values ('ltp','thisisbest',10);  

2.     select @@identity as 'Id' 

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

1.     select name,Sex= 

2.       case Sex   

3.       when '1' then '男'   

4.       when '0' then '女' 

5.       end  

6.     from Tablename 

3.嵌套子查询

1.     select a,b,c from Table1 where a IN (select a from Table2) 

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

1.     select a.title,a.username,b.adddate  

2.     from tablename a,(select max(adddate) adddate from tablename where  

3.             tablename.title=a.title) b 

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

1.     SQL Server:Select Top 10 * From Tablename Order By NewID()  

2.     Access:Select Top 10 * From Tablename Order By Rnd(ID)   

3.      

4.     Rnd(ID) 其中的ID是自动编号字段,可以利用其他任何数值来完成,
比如用姓名字段UserName)   

5.     Select Top 10 * From 表Order BY Rnd(Len(UserName))  

6.     MySql:Select * From 表Order By Rand() Limit 10 

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

1.     select UserID from Accounts_Users 

2.     where UserName is not null 

3.     group by UserID 

4.     having count (*)>1 

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

1.     SELECT CategoryName,ProductName 

2.     FROM Categories LEFT JOIN Products  

3.     ON Categories.CategoryID = Products.CategoryID; 

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

1.     select * from UserValue  where UserID between 2 and 5 

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

1.     Select * from TabSchedule where datediff(minute,getdate(),开始时间)<5 

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

1.     SELECT DAY(DATEADD(dd, -DAY('2008-02-13'),DATEADD(mm, 1,
'2008-02-13')))   

2.             AS 'DayNumber' 

11.按姓氏笔画排序

1.     Select * From TableName Order By CustomerName Collate 
Chinese_PRC_Stroke_ci_as 

12.通配符的一些用法

1.     1select * from tablename where column1 like '[A-M]%' 

2.     这样可以选择出column字段中首字母在A-M之间的记录  

3.     2select * from tablename where column1 like '[ABC]%' 

4.     这样可以选择出column字段中首字母是A或者B或者C的记录  

5.     3select * from tablename where column1 like '[A-CG]%' 

6.     这样可以选择出column字段中首字母在A-C之间的或者是G的记录  

7.     4select * from tablename where column1 like '[^C]%' 

8.     这样可以选择出column字段中首字母不是C的记录  

9.     单字符(关键字:like _):  

10. 通过使用下滑线字符(_),可以匹配任意单个字符  

11. select * from tablename where column1 like 'M_crosoft' 

12. 匹配特殊字符:([ ] _ - %)  

13. 把它们都放到[]中就行了,比如:  

14. select * from tablename where column1 like '%[%]%' 

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

1.                     select * into b from a where 1<>1  

2.                     或  

3.                     select top 0 * into [b] from [a]  

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

1.     insert into b(Name,des,num) select Name,des,num from Table1; 

15.编辑一个列

1.     增加列:  

2.     alter table Table1 add username varchar(30) not null default '' 

3.     修改列:  

4.     alter table Table1 alter column username varchar(40) 

5.     删除列:   

6.     alter table Table1 drop column username 

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

--把所有时间2006-11-1的数据 23点 修改为 21点

1.     update Ad_Browse_20061101 

2.     set browsetime='2006-11-01 21'+  

3.     SUBSTRING(CONVERT(VARCHAR(30),browsetime,8),3,7) 

where DATEPART(Hour,browsetime)=23

视频课堂https://edu.csdn.net/course/play/7621