using System; using System.Text; using System.Data; using System.Data.Common; using CSFramework.DB; using CSFrameworkV5.Models; using CSFrameworkV5.Common; using CSFrameworkV5.Core; using CSFrameworkV5.Core.CodeGenerator; using CSFrameworkV5.DataAccess; using CSFrameworkV5.Interfaces; /*=================================================================== * 程序说明: demo的数据访问层源码 * 作者资料: 孙中吕 * 创建日期: 2024/05/14 04:06:07 * 最后修改: 2024/05/14 04:06:07 * * 注: 本文件由代码生成器(Code Generator)自动生成。 * (此源码文件请放置在 YourProject.DataAccess 模块) * 版权所有 Copyright 2006~2024, C/S框架网(www.cscode.net) *===================================================================*/ namespace CSFrameworkV5.DataAccess { /// /// DAL数据层:daldemo /// [DefaultORM_UpdateMode(typeof(demo), true)] public class daldemo : dalBaseDataDict { /// /// 构造器 /// /// 当前登录用户 public daldemo(Loginer loginer) : base(loginer) { _KeyName = demo.__KeyName; //主键字段 _TableName = demo.__TableName; //表名 _ModelType = typeof(demo); //指定ORM模型 _ReplaceString = false; _UpdateSummaryKeyMode = UpdateKeyMode.None; } /// /// 根据表名获取该表的SQL命令生成器 /// /// 表名 /// protected override IGenerateSqlCommand CreateSqlGenerator( DataTable table) { Type ORM = null; if (table.TableName == demo.__TableName) ORM = typeof(demo); //指定表与ORM模型的对应关系 if (ORM == null) throw new Exception(table.TableName + "表没有ORM模型!"); return new GenerateSqlCmdByTableFields(ORM, table, GeneratorFactory); } public DataTable Query(string name) { //构建CommandHelper实例,用于动态创建参数对象 var cmd = _Database.CreateCommand(""); var sb = new StringBuilder(); sb.Append("SELECT * FROM demo WHERE 1=1 "); var p = _Database.ParamSymboName; //SQL参数符号 if (!string.IsNullOrEmpty(name)) { sb.Append($" AND name LIKE {p}name"); //拼接SQL条件 cmd.AddParam("name", "%" + name + "%"); // 添加SQL参数对象,组合LIKE条件的值 } sb.Append(" ORDER BY " + demo.__KeyName); //给DbCommand设置SQL脚本 cmd.Command.CommandText = sb.ToStringEx(); //调用IDatabase底层组件的方法 return _Database.GetTable(cmd.Command, demo.__TableName); } } //public class } //namespace