支持MySQL数据库,SPL升级到3.2

此文章主要讲述的是SPL升级到3.2全面支持MySQL数据库的实际应用与具体操作,如果你是MySQL数据库方面的新手,对MySQL数据库的相关实际应用不是很了解的话,以下的文章会给你提供更全面的知识。

SPL从上次的3.1.0.5开始,经过了一段时间,积累了一些修改并进行了MySQL数据库的支持,现在发布SPL版本为3.2.0.4,Dll下载地址:这里 。只需要在项目中,把原来的Dll覆盖即可,如果还没下载过SPL早期版本的朋友,本次SPL自上次发布的3.1.0.5以后进行的更新有:

1、支持MS SQL SERVER中的Bit型数据类型

映射到ClassMap中的类型为boolean,如:

 

  1. <attribute name="IsOver" column="IsOver" type="boolean" /> 

对应的实体类类型为bool型,如:

 

  1. private bool m_IsOver;   
  2. public bool IsOver  
  3. {  
  4. get  
  5. {  
  6. return this.m_IsOver;  
  7. }  
  8. set  
  9. {  
  10. this.m_IsOver = value;  
  11. }  

在查询时可以通过Condition进行比较判断了:

  1. Codition c=....  
  2. c.AddEqualTo("IsOver",false); 

这会最终生成 IsOver=’0’的查询条件

2、提供了对数据源的提供者类型的判断,这将方便区分不同的MySQL数据库提供者手动组装不同的SQL语句

用Setting.Instance().GetDatabaseVendor(dbName)根据dbName数据源取得数据源提供者,然后与DatabaseVendor枚举型比较

如Access的日期比较与Sql Server的不一致:一个采用#号,一个采用’号

 

  1. if(Setting.Instance().GetDatabaseVendor(dbName)==DatabaseVendor.MsAccess)  
  2. {  
  3. builder.Append(" and SpecialPriceD2.FromDate<=#"+itemDate.Day.ToString()+"-"+itemDate.Month.ToString()+"-"+itemDate.Year.ToString()+"#");  
  4. builder.Append(" and SpecialPriceD2.ToDate>=#"+itemDate.Day.ToString()+"-"+itemDate.Month.ToString()+"-"+itemDate.Year.ToString()+"#");  
  5. }  
  6. if(Setting.Instance().GetDatabaseVendor(dbName)==DatabaseVendor.MsSqlServer)  
  7. {  
  8. builder.Append(" and SpecialPriceD2.FromDate<='"+itemDate.Day.ToString()+"-"+itemDate.Month.ToString()+"-"+itemDate.Year.ToString()+"'");  
  9. builder.Append(" and SpecialPriceD2.ToDate>='"+itemDate.Day.ToString()+"-"+itemDate.Month.ToString()+"-"+itemDate.Year.ToString()+"'");  

 

这个功能将为系统对多种MySQL数据库的支持***的灵活性,虽然SPL本身的“实体”与“标准”都可以区分不同的数据源提供者,但在需要手写SQL的地方,也需要根据不同的数据源提供者提供不同的语句执行

3、修订了对所有保留字的兼容性

目前对所有的SPL中的操作,都加了定界符,ORACLE采用“””号,MS的采用“[]”号,MySql的采用“`”号,所有测试都通过了

4、在Condition里添加了对Null值的查询功能

此方式只针对AddEqualTo()和AddNotEqualTo()有效:

  1. c.AddEqualTo("字段名",System.DBNull.Value);  
  2. c.AddNotEqualTo("字段名",System.DBNull.Value);  

5、增加了对MySql数据库的支持

SPL对MySql的访问连接采用的是MySql提供的专用.NET connector,此驱动应该说是目前.NET连接MySql的***选择,在使用SPL访问MySql时,只需要安装一下此驱动即可,下载与介绍请看

使用时只需要配置DatabaseMap时类型设为“MySql”即可,如下:

  1. <database name="MySqlDB" type="MySql">   
  2. <parameter name="User Id" value="root"/> 
  3. <parameter name="Data Source" value="localhost"/> 
  4. <parameter name="Database" value="mysql"/> 
  5. <parameter name="password" value=""/> 
  6. <classMapFile path="ClassMap.xml" /> 
  7. </database> 

只需这里配置后,SPL在具体应用中与其他的完全一样,测试情况:

实体测试—>通过

RetrieveCriteira、UpdateCriteria、DeleteCriteria测试—>通过

Transaction测试—>通过

自动增长主键测试—>通过

TOP功能测试—>通过

6、对DateTime的Null值进行了处理 (3.2.0.1开始支持)

如果要对DateTime类型的字段赋于Null值,只需要使用DateTime.MinValue即可:

aEntity.CreateDate=DateTime.MinValue;

在SPL内部会判断如果DateTime.MinValue的话,自动保存到MySQL数据库为System.DBNull.Value,这就解决了不能给 DateTime类型直接赋于System.DBNull.Value的问题。

7、修订了UpdateCriteria对属性名与字段名不一致时导致的错误(3.2.0.2开始修订)

原来在UpdateCriteira时没有对属性进行转化为字段名,导致在属性名与字段名不一致的情况下会找不到字段。

(非常感谢iamsunrise提供的建议,请下载了SPL3.2的朋友重新下载一下)
(感谢子扬报出的BUG)

8、本3.2.0.4已经修复了DataBaseType的MySql类型了。

【编辑推荐】

  1. MySQL 备份的实际应用与功能介绍
  2. MySQL表种类中两大经常使用的类型
  3. 远程连接MySQL速度慢如何破解?
  4. MySQL命令备忘的“后备军”
  5. MySQL常用技巧大汇总

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/229098.html<

(0)
运维的头像运维
上一篇2025-04-18 14:55
下一篇 2025-04-18 14:56

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注