C#三十四 常用开发的部分总结

简介: C#三十四 常用开发的部分总结

实现多数据库的访问

如果为了实现数据库操作类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



目录
相关文章
|
7天前
|
测试技术 Go C#
C#一分钟浅谈:ReSharper 插件增强开发效率
【10月更文挑战第25天】ReSharper 是 JetBrains 开发的一款 Visual Studio 插件,旨在提高 .NET 开发者的生产力。它通过代码分析、重构、导航等功能,帮助开发者避免常见错误,提升代码质量和开发效率。本文将通过具体代码案例,详细介绍 ReSharper 的常见功能及其应用。
22 1
|
12天前
|
C# Python
使用wxpython开发跨平台桌面应用,对wxpython控件实现类似C#扩展函数处理的探究
【10月更文挑战第30天】使用 `wxPython` 开发跨平台桌面应用时,可以通过创建辅助类来模拟 C# 扩展函数的功能。具体步骤包括:1. 创建辅助类 `WxWidgetHelpers`;2. 在该类中定义静态方法,如 `set_button_color`;3. 在应用中调用这些方法。这种方法提高了代码的可读性和可维护性,无需修改 `wxPython` 库即可为控件添加自定义功能。但需要注意显式调用方法和避免命名冲突。
|
20天前
|
JSON C# 开发者
C#语言新特性深度剖析:提升你的.NET开发效率
【10月更文挑战第15天】C#语言凭借其强大的功能和易用性深受开发者喜爱。随着.NET平台的演进,C#不断引入新特性,如C# 7.0的模式匹配和C# 8.0的异步流,显著提升了开发效率和代码可维护性。本文将深入探讨这些新特性,助力开发者在.NET开发中更高效地利用它们。
29 1
|
26天前
|
开发框架 NoSQL MongoDB
C#/.NET/.NET Core开发实战教程集合
C#/.NET/.NET Core开发实战教程集合
|
2月前
|
物联网 C# C语言
物联网开发中C、C++和C#哪个更好用
在物联网(IoT)开发中,C、C++和C#各有优缺点,适用场景不同。C语言性能高、资源占用低,适合内存和计算能力有限的嵌入式系统,但开发复杂度高,易出错。C++支持面向对象编程,性能优秀,适用于复杂应用,但学习曲线陡峭,编译时间长。C#易于学习,与.NET框架结合紧密,适合快速开发Windows应用,但性能略低,平台支持有限。选择语言需根据具体项目需求、复杂性和团队技术栈综合考虑。
|
1月前
|
XML 存储 安全
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
C#开发的程序如何良好的防止反编译被破解?ConfuserEx .NET混淆工具使用介绍
47 0
|
3月前
|
JSON C# 开发者
💡探索C#语言进化论:揭秘.NET开发效率飙升的秘密武器💼
【8月更文挑战第28天】C#语言凭借其强大的功能与易用性深受开发者喜爱。伴随.NET平台演进,C#持续引入新特性,如C# 7.0的模式匹配,让处理复杂数据结构更直观简洁;C# 8.0的异步流则使异步编程更灵活高效,无需一次性加载全部数据至内存。通过示例展示了模式匹配简化JSON解析及异步流实现文件逐行读取的应用。此外,C# 8.0还提供了默认接口成员和可空引用类型等特性,进一步提高.NET开发效率与代码可维护性。随着C#的发展,未来的.NET开发将更加高效便捷。
57 1
|
3月前
|
Android开发 iOS开发 C#
Xamarin:用C#打造跨平台移动应用的终极利器——从零开始构建你的第一个iOS与Android通用App,体验前所未有的高效与便捷开发之旅
【8月更文挑战第31天】Xamarin 是一个强大的框架,允许开发者使用单一的 C# 代码库构建高性能的原生移动应用,支持 iOS、Android 和 Windows 平台。作为微软的一部分,Xamarin 充分利用了 .NET 框架的强大功能,提供了丰富的 API 和工具集,简化了跨平台移动应用开发。本文通过一个简单的示例应用介绍了如何使用 Xamarin.Forms 快速创建跨平台应用,包括设置开发环境、定义用户界面和实现按钮点击事件处理逻辑。这个示例展示了 Xamarin.Forms 的基本功能,帮助开发者提高开发效率并实现一致的用户体验。
144 0
|
3月前
|
开发者 iOS开发 C#
Uno Platform 入门超详细指南:从零开始教你打造兼容 Web、Windows、iOS 和 Android 的跨平台应用,轻松掌握 XAML 与 C# 开发技巧,快速上手示例代码助你迈出第一步
【8月更文挑战第31天】Uno Platform 是一个基于 Microsoft .NET 的开源框架,支持使用 C# 和 XAML 构建跨平台应用,适用于 Web(WebAssembly)、Windows、Linux、macOS、iOS 和 Android。它允许开发者共享几乎全部的业务逻辑和 UI 代码,同时保持原生性能。选择 Uno Platform 可以统一开发体验,减少代码重复,降低开发成本。安装时需先配置好 Visual Studio 或 Visual Studio for Mac,并通过 NuGet 或官网下载工具包。
212 0
|
3月前
|
开发者 Apache 程序员
揭秘Apache Wicket:页面生命周期背后的神秘力量!
【8月更文挑战第31天】李工是一位热爱Web开发的程序员,近日在技术博客上分享了他对Apache Wicket框架的学习心得,特别是页面生命周期的理解。他认为掌握Wicket页面生命周期对于开发富交互式Web应用至关重要。他通过一个简单的计数器应用示例,详细解释了Wicket的组件化设计理念以及页面和组件在生命周期中的变化。
43 0