1.asp.net çConnectionç±»å¨åªå
2..NET Dapper的数数据正确使用姿势
asp.net çConnectionç±»å¨åªå
é¦å å¼ç¨å½å空é´ï¼ConnectionåOleDbConnectionï¼SqlConnection
SqlConnectionè´è´£é¾æ¥SQLæ°æ®åº
OleDbConnectionè´è´£é¾æ¥ACCESSæ°æ®åº
using System.Data;
using System.Data.SqlClient;//è¿éçå¼ç¨å¯ä»¥è°ç¨SqlConnection ç±»
using System.Data.OleDb;//è¿éçå¼ç¨å¯ä»¥è°ç¨OleDbConnectionç±»
ç¶åå¨ç±»ä¸å®ä¹ï¼è¿éæ就以ACCESS举ä¾
public static class DBHelper
{
private static OleDbConnection connection;
public static OleDbConnection Connection
{
get
{
string connectionString = "Provider=Microsoft.ACE.OLEDB..0;Data Source=" + System.Web.HttpContext.Current.Server.MapPath(@"~\App_Data\#wnbeauty#.accdb");
string str = connectionString;
if (connection == null)
{
connection = new OleDbConnection(connectionString);
connection.Open();
}
else if (connection.State == System.Data.ConnectionState.Closed)
{
connection.Open();
}
else if (connection.State == System.Data.ConnectionState.Broken)
{
connection.Close();
connection.Open();
}
return connection;
}
}
å¤æ³¨ï¼
string connectionString = "Provider=Microsoft.ACE.OLEDB..0;Data Source=" + System.Web.HttpContext.Current.Server.MapPath(@"~\App_Data\#wnbeauty#.accdb");
provideræ¯ç¨æ¥è®¾ç½®æ°æ®æºçç±»åï¼Data Sourceç¨æ¥è®¾ç½®æ°æ®æºçä½ç½®ã
å¨çæConnectionçå®ä¾æ¶ï¼å ¶è¢«åå§å为"å ³éç¶æ"ãæ¢å¥è¯è¯´ï¼æ è®ºå ¶å称æ¯ä»ä¹ï¼ä»é½æ²¡æå®é è¿æ¥å°æ°æ®æºä¸ãå¦æå¨æ²¡ææå¼è¿æ¥çæ åµä¸æ§è¡Connectionçæ¥è¯¢ï¼å°ä¼æ¶å°âéè¦ä¸ä¸ªæå¼çå¯ç¨è¿æ¥âçé误æ示ã
è¦è¿æ¥è³æ°æ®æºï¼é¦å å©ç¨æé å½æ°æè 设置该对象çConnectionStringå±æ§æ¥æä¾ä¸ä¸ªææçè¿æ¥å符串ï¼ç¶åè°ç¨è¯¥å¯¹è±¡çopenæ¹æ³ã
2ãå ³éConnection对象
ç¨Closeæ¹æ³å³å¯ï¼å¦æ使ç¨äºè¿æ¥æ± ï¼é£ä¹ä¸æ°æ®åºçç©çè¿æ¥å°è¢«æ¾å¨æ± ä¸èä¸æ¯è¢«å ³éï¼ä»¥ä¾¿å¨ä»¥åéå¤å©ç¨ï¼å¦æ没æ使ç¨è¿æ¥æ± ï¼åä¸æ°æ®åºçç©çè¿æ¥è¢«å ³éã
3ãè¿æ¥å符串
è¿æ¥å符串æ¯ä»ä¹ï¼
å¨ä¸é¢ä»£ç ä¸ä¸ºæ°çConnection对象æä¾äºä¸ä¸ªè¿æ¥å符串ï¼è¿æ¥å符串æ¯ç±ä¸ç³»åç¨åå·éå¼çå-å¼å¯¹ç»æã设置åå¼åå³äºå¸æè¿æ¥çæ°æ®æºï¼ä»¥å为è¿æ¥å°æ°æ®åºèéç¨çææ¯ã
.NET Dapper的正确使用姿势
高性能、易排查、据库接池易运维、连接灵活可控是池源.NET Dapper的显著优点。
与Entity Framework相比,库连异步提交表单源码Dapper依赖手动编写SQL语句,数数据app启动-源码这在修改数据库结构时可能不易发现错误。据库接池但通过单元测试和细心操作可以避免这类问题。连接
数据库连接的池源管理需视情况而定:主动管理需手动控制连接打开与关闭,而自动管理则由Dapper自行负责。库连GitHub上的数数据源码提供具体实现细节。
ADO.NET默认配置了连接池,据库接池但使用Dapper时可能出现连接池超出最大限制的连接分销棋盘源码情况。解决方案是池源确保连接的正确打开和关闭。
批量操作如新增、库连修改、删除数据时,应用盒子源码可利用参数化和IN语法优化。
在Dapper中,通过C#语法优势,可以简化IF条件语句的ieeevr论文源码编写。例如,可以使用字符串拼接方式进行操作,提升代码可读性。
事务处理在Dapper中不如EF便捷。通过标记特性,实现方法自动开启和提交事务,简化代码结构。需要借助Nuget包Autofac实现。
SQL监控是Dapper的一个关键功能,MiniProfiler是一个强大的工具,可用于检测和性能监控,支持多种数据库。通过Nuget包MiniProfiler.AspNetCore实现监控。
完整源码示例可从GitHub链接获取,具体实现细节在文末提供。