CYQ.Data V5 从入门到放弃ORM系列:教程 - AppConfig、AppDebug类的使用-阿里云开发者社区

开发者社区> 晚来风急> 正文

CYQ.Data V5 从入门到放弃ORM系列:教程 - AppConfig、AppDebug类的使用

简介:
+关注继续查看

1:AppConfig类的介绍:

Public Static (Shared) Properties

IsEnumToInt 是否使用表字段枚举转Int方式(默认为false)。 设置为true时,可以加快一点性能,但生成的表字段枚举必须和数据库一致。
Aop Aop 插件配置项 示例配置:[ 完整类名,程序集(dll)名称]<add key="Aop" value="Web.Aop.AopAction,Aop"/>
ThreadBreakPath Tool.ThreadBreak 使用时,外置的文件配置相对路径(默认在环境变量Temp对应文件中)
EntitySuffix 生成的实体类的后缀。
Version 获取当前Dll的版本号
RunPath 框架的运行路径(Bin目录)

Public Static (Shared) Methods

GetApp Overloaded. 获取Web.config或App.config的值。
GetAppInt 获取Web.config或App.config的数字值(允许值不存在或为空时输出默认值)。
GetConn Overloaded. 获取Web.config或App.config的connectionStrings节点的值。
SetApp 设置Web.config或App.config的值。 

说明:

1:AppConfig类的属性名和Web.config/App.config的AppSetting节点的Key同名。

2:除了基本的属性和方法,还包括以下的五大类配置。

AppConfig.Cache 

Public Static (Shared) Properties

IsAutoCache 是否智能缓存数据(默认开启)
DefaultCacheTime Cache.CacheManage 默认缓存项的时间[分钟(默认60)]
MemCacheServers 分布式缓存的服务器配置,多个用逗号(,)分隔
NoCacheTables AutoCache开启时,可以设置不缓存的Table,多个用逗号分隔
IngoreCacheColumns AutoCache开启时,可以设置不受更新影响的列名,用Json格式。 {talbeName1:'column1,column2',talbeName2:'column1,column2'} 

AppConfig.DB

Public Static (Shared) Properties

PagerBySelectBase MSSQL是否启用分页存储过程SelectBase,默认false
DefaultDalType 默认数据库类型(只读)
CommandTimeout 全局的数据库命令默认超时设置,默认值120秒(单位:秒)
MasterSlaveTime 读写分离时用户对主数据库操作持续时间,默认值10秒(单位:秒)
DefaultConn 默认数据库链接(可赋完整链接语句或Web.config配置项名称) 如果不在配置文件(Web.Config)上配置Conn链接,可对此属性赋值进行配置。
DefaultDataBase 默认数据库名称(只读)
FilterSqlInjection MAction所有操作中的where条件,默认有超强的过滤单词,来过滤Sql注入关键字,如果语句包含指定的过滤词,则会返回错误信息,并记录日志。 如果需要自定义关键字,可配置此项,如:“delete;from,truncate,其它单词”,分号表词组,需要同时包含两个词; 多个过滤词组以","逗号分隔
AutoID MAction 操作 Oracle 时自增加int类型ID所需要配置的序列ID,Guid为ID则不用。 如果需要为每个表都配置一个序列号,可以使用:SEQ_{0} 其中{0}会自动配对成表名,如果没有{0},则为整个数据库共用一个序列。 默认参数值:SEQ_{0}
SchemaMapPath MAction 可将表架构映射到外部指定相对路径[外部存储,可避开数据库读取]
DeleteField 删除字段名称(若表存在此设置的字段名称时,MActon的删除操作将变更变为更新操作) 默认:IsDeleted
EditTimeFields 更新时间字段名称(若表存在指定字段名称时,自动更新时间,多个用逗号分隔)
HiddenFields 系统全局要隐藏的字段名称(默认值为:"cyqrownum,rowguid,deletefield") 

AppConfig.Debug

Public Static (Shared) Properties

OpenDebugInfo 开启信息调试记录:开启后MAction.DebugInfo可输出执行日志。 同时AppDebug若要使用,也需要开启此项。
SqlFilter 毫秒数(这个是在对所有SQL语句的:将所有长时间(ms)的SQL语句写入日志,对应配置项LogPath的路径)
InfoFilter 毫秒数(这个是在AppDebug开启后的:可通过此项设置条件过滤出时间(ms)较长的SQL语句) 

AppConfig.Log

Public Static (Shared) Properties

IsWriteLog 是否写数据库异常日志:开启时:有异常不抛出,转写入数据库;不开启:有异常会抛出
LogConn CYQ.Data.Log 类记录数据库异常日志 - 数据库链接配置
LogPath 文本日志的配置相对路径(默认为:Logs\\")
LogTableName 异常日志表名(默认为SysLogs,可配置) 

AppConfig.XHtml 

Public Static (Shared) Properties

CDataLeft Xml.XHtmlHelper 中使用的 "<![CDATA[" 项
CDataRight Xml.XHtmlHelper 中使用的 "]]>" 项
DtdUri Xml.XHtmlHelper 中操作Html需要配置的DTD解析文档相对路径
Domain Xml.MutilLanguage 语言切换设置时Cookie所需要的网站主域名[不带www]
SysLangKey Xml.MutilLanguage 类的默认语言Key,默认值:Chinese 

 

2:AppDebug

Public Static (Shared) Properties

IsRecording 正在记录中
Info 获取调试信息

Public Static (Shared) Methods

Start 开始记录调试信息
Stop 停止并清除记录的调试信息 

示例代码:

复制代码
class Program
    {
        static void Main(string[] args)
        { 
            AppConfig.Debug.OpenDebugInfo = true;//首先要打开这个

            AppConfig.Debug.InfoFilter = 20;//记录SQL语句执行时间>1毫秒的(这个是在AppDebug开启后的:)
            AppConfig.Debug.SqlFilter = 2;//记录SQL执行语句时间>2毫秒的(这个是所有的SQL语句)
            //注意打开软件文件,执行时间大于2毫秒的将记录在在 SqlFilter_时间.txt 

            AppDebug.Start();//开始记录
            Exe1();
            Exe2();
            Exe3();
            Console.WriteLine(AppDebug.Info);//拿到调试信息
            AppDebug.Stop();//关闭记录
            Console.Read();
        }
        static void Exe1()
        {
             string sql = "select count(*) from users";
             using (MProc proc = new MProc(sql))
             {
                 proc.ExeScalar<string>();
             }

        }
        static void Exe2()
        {
            using (MAction action = new MAction("V_Article"))
            {
                action.Select();
            }
        }
        static void Exe3()
        {
            using (MAction action = new MAction("Users"))
            {
                action.Fill(1);
            }
        }
    }
复制代码

运行结果:

总结:

1:AppConfig是比较常用(通常不是直接操作这个类,而是指配置Web.config)

2:AppDebug:只有在sql语句性能需要监控或优化的时候,才会使用。

CYQ.Data:GitHub源码:https://github.com/cyq1162/cyqdata

CYQ.Data:Demo 源码:http://code.taobao.org/p/cyqopen/src/trunk/CYQ.Data.GettingStarted/ 


本文原创发表于博客园,作者为路过秋天,原文链接:http://www.cnblogs.com/cyq1162/p/5863384.html

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
分享录制的正则表达式入门、高阶以及使用 .NET 实现网络爬虫视频教程
我发布的「正则表达式入门以及高阶教程」,欢迎学习。 课程简介 正则表达式是软件开发必须掌握的一门语言,掌握后才能很好地理解到它的威力; 课程采用概念和实验操作 4/6 分隔,帮助大家理解概念后再使用大量的实例加深对概念的理解; 实例操作是对概念最好的理解,也是学习新语言最有效的办法; 在课程中也穿插着大量软件开发的技巧和大家分享; 应该是把晦涩的正则表达式讲解的最生动的课程; 掌握了正则表达式后,您一定会觉得这是一门最值得掌握的语言。
886 0
怎么设置阿里云服务器安全组?阿里云安全组规则详细解说
阿里云服务器安全组设置规则分享,阿里云服务器安全组如何放行端口设置教程
6896 0
django的orm中F对象的使用
今天不巧就用上了。 就是将数据库的字段,自增1的场景。 from django.db.models import F DeployPool.objects.filter(name=deployversion_id).
1120 0
React Native 教程:001 - 如何运行官方控件示例 App
原文发表于我的技术博客 本文主要讲解了如何运行 React Native 官方控件示例 App,包含了一些 React Native 的基础知识以及相关环境的配置。原文发表于我的技术博客 React Native 以及示例 App 简介 关于 React Native 的简要介绍。
874 0
uni-app自定义返回逻辑教程
自 HBuilderX v1.1.0 起,uni-app 的页面新增 onBackPress(event) 生命周期函数。 onBackPress(event) 返回 event ={form: backbutton | navigateBack} 说明 当用户进行以下操作时,会触发该函数: A...
6058 0
Android 数据库ORM框架GreenDao学习心得及使用总结<二>
转:http://blog.csdn.net/xushuaic/article/details/24496191   第五篇 查询 查询会返回符合某些特定标准的实体。你可以使用原始的SQL定制查询语句,或者更好的方式:使用GreenDao的QueryBuilder API。
708 0
+关注
9380
文章
243
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载