搜索
首页数据库mysql教程发布一个轻量级的SQLSERVER数据处理库 DotNetSQL

DotNetSQL是一个轻量级的数据处理封装,建议用作项目数据持久层, 支持 MSSQL2000/2005, 2008下未测试. 可以满足常规的数据处理需要.适合于基于ASP.NET中小型项目! 能够帮助初学者在一定程度上提高开发效率. DotNetSQL主要分以下模块 DotNetSQL.Proc :执行常

      DotNetSQL是一个轻量级的数据处理封装,建议用作项目数据持久层, 支持 MSSQL2000/2005, 2008下未测试. 可以满足常规的数据处理需要.适合于基于ASP.NET中小型项目!

  能够帮助初学者在一定程度上提高开发效率.

      DotNetSQL主要分以下模块

 

  DotNetSQL.Proc :执行常规的存储过程,包括返回datatable,dataset,sqldatareader,return,output

  DotNetSQL.Sql:执行常规的sql语句,提取了sqlhelper的基本操作方法.

  DotNetSQL.ORM.Sql : 常规的模型操作,insert,update,delete Model

  DotNetSQL.ORM.Proc :基于存储过程的模型操作

  DotNetSQL.Config:动态配置 (非web.config),适合于winForm

  DotNetSQL.Cache:目前只开放了存储过程参数名称缓存,暂无数据缓存.

 

 简单的列出几个调用例子:

一,普通调用存储过程


CREATE PROCEDURE [dbo].[sp_Test]
@a varchar(20),
@b int,
@c float,
@d text,
@e datetime,
@f int output,
@g varchar(20) output
AS
BEGIN
    
SET NOCOUNT ON;
    
--逻辑处理代码发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
END

 

这是一个简单的存贮过程,里面关系到了输入参数,输出参数,用DotNetSQL执行代码如下

 

 

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQLCode
using DotNetSQL.Proc;

ExecuteProc ep 
= new ExecuteProc();
Dictionary
stringobject> Out;
int f;
string g;

Out
=ep.RunProc("sp_Test","LiLei",20,32.3,"这里是长文本",DateTime.Now); 

//参数说明
//RunProc(存储过程名称,参数a,参数b,参数c,参数d,参数e) 无需再每个参数都new一次SqlParameter对象

//读取output参数
 if(Out.ContainsKey("@f")){
    f
=(int)Out["@f"];
 }
 
if(Out.ContainsKey("@g")){
    g
=Out["@g"].ToString();
 }

 

此外 ExecuteProc下还有多个方法,例如无任何返回值,返回DataTable,SqlDataReader,DataSet等等.

 

另外备注一下使用DotNetSQL执行存储过程与常规ADO.NET操作的性能对比.

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL

 以上测试是在我的小本本上测试结果,两者误差基本在2ms内.

 二,基于ORM的数据操作

 

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQLC# Code(Model类)
发布一个轻量级的SQLSERVER数据处理库 DotNetSQLusing System;
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
using DotNetSQL.ORM; //必需引用该命名空间
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL[Property(
"Member")] //设置该model对应的表名
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
public class Member
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
public Member()
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
//
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
//TODO: 在此处添加构造函数逻辑
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
//
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
    }

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
private int _id;
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
private string _name;
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
private bool _sex;
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
private decimal _money;
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
private DateTime _addtime;
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
private string _ext;
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    [Property(ColumnKeyType.PrimaryKeyAndIdentity)] 
//表示Id列为该表的主键且自增
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
    public int Id
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
get 发布一个轻量级的SQLSERVER数据处理库 DotNetSQLreturn _id; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
set 发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{ _id = value; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    }

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
public string Name
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
get 发布一个轻量级的SQLSERVER数据处理库 DotNetSQLreturn _name; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
set 发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{ _name = value; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    }

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
public bool Sex
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
get 发布一个轻量级的SQLSERVER数据处理库 DotNetSQLreturn _sex; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
set 发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{ _sex = value; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    }

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    [Property(ColumnKeyType.ReadOnly)] 
//表示在处理数据时,该列为只读,即不参与修改.
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
    public decimal Money
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
get 发布一个轻量级的SQLSERVER数据处理库 DotNetSQLreturn _money; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
set 发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{ _money = value; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    }

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
public DateTime AddTime
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
get 发布一个轻量级的SQLSERVER数据处理库 DotNetSQLreturn _addtime; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
set 发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{ _addtime = value; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    }

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    [Property(ColumnKeyType.Extend)] 
//表示该列为扩展列,当数据库表中不存在该字段时,可以标识该属性
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
    public string Ext
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
get 发布一个轻量级的SQLSERVER数据处理库 DotNetSQLreturn _ext; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL        
set 发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{ _ext = value; }
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL    }

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL}

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
//ColumnKeyType详细枚举请参考文档

 注:Model类中的字段必需于数据库中表的字段名称相同,包括大小写,建议使用代码生成器生成Model!

DotNetSQL的操作代码如下

 

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQLCode
发布一个轻量级的SQLSERVER数据处理库 DotNetSQLMember memberModel = new Member();
发布一个轻量级的SQLSERVER数据处理库 DotNetSQLORMToSQL ormToSql 
= new ORMToSQL();
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
//根据主键(Id)得到实体。
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
memberModel=ormToSql.GetModelMember>(1); //得到Id=1的数据行(实体)
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
if(memberModel!=null)发布一个轻量级的SQLSERVER数据处理库 DotNetSQL{
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL   Response.Write (memberModel.Name);
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL}

发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
//插入一个新的实体到数据库中
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
memberModel.Name="sun.Lei";
发布一个轻量级的SQLSERVER数据处理库 DotNetSQLmemberModel.Sex
=false;
发布一个轻量级的SQLSERVER数据处理库 DotNetSQLmemberModel.Money
=45.46//因为在model类中,给该列标识了ReadOnly属性,所以不会插入该列值
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
memberModel.AddTime = DateTime.Now;
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
int key=ormToSql.InsertModelMember>(memberModel); //插入数据,并返回该条数据的自增ID
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
发布一个轻量级的SQLSERVER数据处理库 DotNetSQL
//update,delete都类似,此外以上方法都有相关重载,例如更新指定的列,详情参照文档。

DotNetSQL还集成了基于存储过程的模型操作。

DotNetSQL也集成了sqlhelper中的基本操作方法。

具体请参见文档,点击下载

欢迎大家批评指正,如果你对DotNetSQL感兴趣可以向我索要源码!也希望DotNetSQL能够帮助初学者实现快速开发!

 

 

 

 

 

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
如何向新的MySQL用户授予权限如何向新的MySQL用户授予权限May 09, 2025 am 12:16 AM

TograntpermissionstonewMySQLusers,followthesesteps:1)AccessMySQLasauserwithsufficientprivileges,2)CreateanewuserwiththeCREATEUSERcommand,3)UsetheGRANTcommandtospecifypermissionslikeSELECT,INSERT,UPDATE,orALLPRIVILEGESonspecificdatabasesortables,and4)

如何在MySQL中添加用户:逐步指南如何在MySQL中添加用户:逐步指南May 09, 2025 am 12:14 AM

toadduserInmysqleffectection andsecrely,theTheSepsps:1)USEtheCreateuserStattoDaneWuser,指定thehostandastrongpassword.2)GrantNectalRevileSaryPrivilegesSustate,usiveleanttatement,AdheringTotheTeprinciplelastPrevilegege.3)

mysql:添加具有复杂权限的新用户mysql:添加具有复杂权限的新用户May 09, 2025 am 12:09 AM

toaddanewuserwithcomplexpermissionsinmysql,loldtheSesteps:1)创建eTheEserWithCreateuser'newuser'newuser'@''localhost'Indedify'pa ssword';。2)GrantreadAccesstoalltablesin'mydatabase'withGrantSelectOnMyDatabase.to'newuser'@'localhost';。3)GrantWriteAccessto'

mysql:字符串数据类型和coltrationsmysql:字符串数据类型和coltrationsMay 09, 2025 am 12:08 AM

MySQL中的字符串数据类型包括CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT,排序规则(Collations)决定了字符串的比较和排序方式。1.CHAR适合固定长度字符串,VARCHAR适合可变长度字符串。2.BINARY和VARBINARY用于二进制数据,BLOB和TEXT用于大对象数据。3.排序规则如utf8mb4_unicode_ci忽略大小写,适合用户名;utf8mb4_bin区分大小写,适合需要精确比较的字段。

MySQL:我应该在Varchars上使用什么长度?MySQL:我应该在Varchars上使用什么长度?May 09, 2025 am 12:06 AM

最佳的MySQLVARCHAR列长度选择应基于数据分析、考虑未来增长、评估性能影响及字符集需求。1)分析数据以确定典型长度;2)预留未来扩展空间;3)注意大长度对性能的影响;4)考虑字符集对存储的影响。通过这些步骤,可以优化数据库的效率和扩展性。

mysql blob:有什么限制吗?mysql blob:有什么限制吗?May 08, 2025 am 12:22 AM

mysqlblobshavelimits:tinyblob(255bytes),blob(65,535 bytes),中间布洛布(16,777,215个比例),andlongblob(4,294,967,967,295 bytes).tousebl观察性:1)考虑performance impactsandSandStorelargeblobsextern; 2)管理backbackupsandreplication carecration; 3)usepathsinst

MySQL:自动化用户创建的最佳工具是什么?MySQL:自动化用户创建的最佳工具是什么?May 08, 2025 am 12:22 AM

自动化在MySQL中创建用户的最佳工具和技术包括:1.MySQLWorkbench,适用于小型到中型环境,易于使用但资源消耗大;2.Ansible,适用于多服务器环境,简单但学习曲线陡峭;3.自定义Python脚本,灵活但需确保脚本安全性;4.Puppet和Chef,适用于大规模环境,复杂但可扩展。选择时需考虑规模、学习曲线和集成需求。

mysql:我可以在斑点内搜索吗?mysql:我可以在斑点内搜索吗?May 08, 2025 am 12:20 AM

是的,YouCansearchInIdeAblobInMysqlusingsPecificteChniques.1)转换theblobtoautf-8StringWithConvertFunctionWithConvertFunctionandSearchusiseLike.2)forCompresseBlyblobs,useuncompresseblobs,useuncompressbeforeconversion.3)acpperformance impperformance imperformance imptactsanddataEccoding.4)

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具