最近用动软生成器三层基于企业库param的方式来生成相应的DAL数据层和MODEL实体类,每次要用到aspnetpage控件的分页,需要重载getlist方法来排序和新写方法获取记录数,网上一直没找到相应的教程,也不知从何下手,摸索了一上午,看到许多人用Codesmith 学了一下 要自己编写模板 感觉没有动软方便,于是摸索原来东软开源后自己来写模板也是那么的方便:
1: 动软.Net代码生成器 (.Net 2.0版)动软2.5
2:官方下载http://www.maticsoft.com/download.aspx 里面的 动软.Net代码生成插件源码
3:解压Builder 里面我是用的vs2008 打开项目根据自己的需要选择相应的项目 我选择的是BuilderDALELParam也就是企业库的param的方式 其他的方式可以看东软的帮助文件
4:打开BuilderDAL.cs,展开 数据层(整个类) 下面就是DAL中的数据库增删改查的一些方法
5:如果要重载Getlist的方法现在就简单了 把自己想新写入的代码写在后面这句的""里 strclass.AppendSpaceLine(2, "“);自己定义的方法具体写到什么地方 其实没有关系 只要是return strclass.Value;前面一句就可以了 随便哪个方法里面都可以。
2代表缩进 如果遇到里面有字符串如 strclass.AppendSpaceLine(3, "db.AddInParameter(dbCommand,\" tblName\", DbType.AnsiString,\"" + TableName + "\");");用\"" + TableName + "\来包含.表名用"+ TableName +" 来表示。
6:点重新生成后进入lib目录 找到相应的dll文件覆盖到动软安装目录,然后重启动软生成器,下面就是牛腩的东软生成器生成DAL层代码和MODEL层代码的方法了。
(1):新建服务器
(2):选择数据库文件
(3):右键数据库选择 代码 批量生成
(4): 根据自己需要选择表 命令空间 是否去掉前缀以及dal基于什么方式来生成 保存到自己的输出目录就可以了
(5):复制dal和model下的文件到自己的项目中 就可以了。
(6):东软2.5中时间字段如果遇到private DateTime? _createdate= Convert.ToDateTime(getdate);
请改成private DateTime? _createdate;
using System;
using System.Collections.Generic;
using System.Text;
using System.Collections;
using System.Data.SqlClient;
using LTP.Utility;
using LTP.IDBO;
using LTP.CodeHelper;
namespace LTP.BuilderDALELParam
{
/// <summary>
/// 数据访问层代码构造器(Parameter方式)
/// </summary>
public class BuilderDAL : LTP.IBuilder.IBuilderDAL
{
#region 私有变量
protected string _key = " ID " ; // 标识列,或主键字段
protected string _keyType = " int " ; // 标识列,或主键字段类型
#endregion
#region 公有属性
IDbObject dbobj;
private string _dbname;
private string _tablename;
private string _modelname; // model类名
private string _dalname; // dal类名
private List < ColumnInfo > _fieldlist;
private List < ColumnInfo > _keys; // 主键或条件字段列表
private string _namespace; // 顶级命名空间名
private string _folder; // 所在文件夹
private string _dbhelperName; // 数据库访问类名
private string _modelpath;
private string _dalpath;
private string _idalpath;
private string _iclass;
private string _procprefix;
public IDbObject DbObject
{
set { dbobj = value; }
get { return dbobj; }
}
/// <summary>
/// 库名
/// </summary>
public string DbName
{
set { _dbname = value; }
get { return _dbname; }
}
/// <summary>
/// 表名
/// </summary>
public string TableName
{
set { _tablename = value; }
get { return _tablename; }
}
/// <summary>
/// 选择要生成的字段集合
/// </summary>
public List < ColumnInfo > Fieldlist
{
set { _fieldlist = value; }
get { return _fieldlist; }
}
/// <summary>
/// 主键或条件字段的集合
/// </summary>
public List < ColumnInfo > Keys
{
set { _keys = value; }
get { return _keys; }
}
/// <summary>
/// 顶级命名空间名
/// </summary>
public string NameSpace
{
set { _namespace = value; }
get { return _namespace; }
}
/// <summary>
/// 所在文件夹
/// </summary>
public string Folder
{
set { _folder = value; }
get { return _folder; }
}
/* ============================ */
/// <summary>
/// 实体类的命名空间
/// </summary>
public string Modelpath
{
set { _modelpath = value; }
get { return _modelpath; }
}
/// <summary>
/// 类名
/// </summary>
public string ModelName
{
set { _modelname = value; }
get { return _modelname; }
}
/// <summary>
/// 实体类的整个命名空间 + 类名,即等于 Modelpath+ModelName
/// </summary>
public string ModelSpace
{
get { return Modelpath + " . " + ModelName; }
}
/* ============================ */
/// <summary>
/// 数据层的命名空间
/// </summary>
public string DALpath
{
set { _dalpath = value; }
get
{
return _dalpath;
}
}
public string DALName
{
set { _dalname = value; }
get { return _dalname; }
}
/* ============================ */
/// <summary>
/// 接口的命名空间
/// </summary>
public string IDALpath
{
set { _idalpath = value; }
get
{
return _idalpath;
}
}
/// <summary>
/// 接口类名
/// </summary>
public string IClass
{
set { _iclass = value; }
get { return _iclass; }
}
/* ============================ */
/// <summary>
/// 数据库访问类名
/// </summary>
public string DbHelperName
{
set { _dbhelperName = value; }
get { return _dbhelperName; }
}
/// <summary>
/// 存储过程前缀
/// </summary>
public string ProcPrefix
{
set { _procprefix = value; }
get { return _procprefix; }
}
// 语言文件
public Hashtable Languagelist
{
get
{
return LTP.CodeHelper.Language.LoadFromCfg( " BuilderDALELParam.lan " );
}
}
#endregion
#region 构造属性
/// <summary>
/// 所选字段的 select 列表
/// </summary>
public string Fieldstrlist
{
get
{
StringPlus _fields = new StringPlus();
foreach (ColumnInfo obj in Fieldlist)
{
_fields.Append(obj.ColumnName + " , " );
}
_fields.DelLastComma();
return _fields.Value;
}
}
/// <summary>
/// 不同数据库字段类型
/// </summary>
public string DbParaDbType
{
get
{
return " DbType " ;
}
}
/// <summary>
/// 存储过程参数 调用符号@
/// </summary>
public string preParameter
{
get
{
return " @ " ;
}
}
/// <summary>
/// 列中是否有标识列
/// </summary>
public bool IsHasIdentity
{
get
{
bool isid = false ;
if (_keys.Count > 0 )
{
foreach (ColumnInfo key in _keys)
{
if (key.IsIdentity)
{
isid = true ;
}
}
}
return isid;
}
}
private string KeysNullTip
{
get
{
if (_keys.Count == 0 )
{
return " //该表无主键信息,请自定义主键/条件字段 " ;
}
else
{
return "" ;
}
}
}
#endregion
#region 构造函数
public BuilderDAL()
{
}
public BuilderDAL(IDbObject idbobj)
{
dbobj = idbobj;
}
public BuilderDAL(IDbObject idbobj, string dbname, string tablename, string modelname, string dalName,
List < ColumnInfo > fieldlist, List < ColumnInfo > keys, string namepace,
string folder, string dbherlpername, string modelpath, string modelspace,
string dalpath, string idalpath, string iclass)
{
dbobj = idbobj;
_dbname = dbname;
_tablename = tablename;
_modelname = modelname;
_dalname = dalName;
_namespace = namepace;
_folder = folder;
_dbhelperName = dbherlpername;
_modelpath = modelpath;
_dalpath = dalpath;
_idalpath = idalpath;
_iclass = iclass;
Fieldlist = fieldlist;
Keys = keys;
foreach (ColumnInfo key in _keys)
{
_key = key.ColumnName;
_keyType = key.TypeName;
if (key.IsIdentity)
{
_key = key.ColumnName;
_keyType = CodeCommon.DbTypeToCS(key.TypeName);
break ;
}
}
}
#endregion
#region 根据列信息 得到参数的列表
/// <summary>
/// 得到Where条件语句 - Parameter方式 (例如:用于Exists Delete GetModel 的where)
/// </summary>
/// <param name="keys"></param>
/// <returns></returns>
public string GetWhereExpression(List < ColumnInfo > keys)
{
StringPlus strclass = new StringPlus();
foreach (ColumnInfo key in keys)
{
strclass.Append(key.ColumnName + " = " + preParameter + key.ColumnName + " and " );
}
strclass.DelLastChar( " and " );
return strclass.Value;
}
/// <summary>
/// 生成sql语句中的参数列表(例如:用于Add Exists Update Delete GetModel 的参数传入)
/// </summary>
/// <param name="keys"></param>
/// <returns></returns>
public string GetPreParameter(List < ColumnInfo > keys)
{
StringPlus strclass = new StringPlus();
foreach (ColumnInfo key in keys)
{
strclass.AppendSpaceLine( 3 , " db.AddInParameter(dbCommand, \ "" + key.ColumnName + " \ " , DbType. " + CSToProcType(key.TypeName) + " , " + key.ColumnName + " ); " );
}
return strclass.Value;
}
#endregion
#region 数据层(整个类)
/// <summary>
/// 得到整个类的代码
/// </summary>
public string GetDALCode( bool Maxid, bool Exists, bool Add, bool Update, bool Delete, bool GetModel, bool List)
{
StringPlus strclass = new StringPlus();
strclass.AppendLine( " using System; " );
strclass.AppendLine( " using System.Data; " );
strclass.AppendLine( " using System.Text; " );
strclass.AppendLine( " using System.Collections.Generic; " );
strclass.AppendLine( " using Microsoft.Practices.EnterpriseLibrary.Data; " );
strclass.AppendLine( " using Microsoft.Practices.EnterpriseLibrary.Data.Sql; " );
strclass.AppendLine( " using System.Data.Common; " );
if (IDALpath != "" )
{
strclass.AppendLine( " using " + IDALpath + " ; " );
}
strclass.AppendLine( " namespace " + DALpath);
strclass.AppendLine( " { " );
strclass.AppendSpaceLine( 1 , " /// <summary> " );
strclass.AppendSpaceLine( 1 , " /// " + Languagelist[ " summary " ].ToString() + " : " + DALName );
strclass.AppendSpaceLine( 1 , " /// </summary> " );
strclass.AppendSpace( 1 , " public class " + DALName);
if (IClass != "" )
{
strclass.Append( " : " + IClass);
}
strclass.AppendLine( "" );
strclass.AppendSpaceLine( 1 , " { " );
strclass.AppendSpaceLine( 2 , " public " + DALName + " () " );
strclass.AppendSpaceLine( 2 , " {} " );
strclass.AppendSpaceLine( 2 , " #region Method " );
#region 方法代码
if (Maxid)
{
strclass.AppendLine(CreatGetMaxID());
}
if (Exists)
{
strclass.AppendLine(CreatExists());
}
if (Add)
{
strclass.AppendLine(CreatAdd());
}
if (Update)
{
strclass.AppendLine(CreatUpdate());
}
if (Delete)
{
strclass.AppendLine(CreatDelete());
}
if (GetModel)
{
strclass.AppendLine(CreatGetModel());
}
if (List)
{
strclass.AppendLine(CreatGetList());
strclass.AppendLine(CreatGetListByPageProc());
strclass.AppendLine(CreatGetListArray());
strclass.AppendLine(CreatReaderBind());
}
#endregion
strclass.AppendSpaceLine( 2 , " #endregion Method " );
strclass.AppendSpaceLine( 1 , " } " );
strclass.AppendLine( " } " );
strclass.AppendLine( "" );
return strclass.ToString();
}
#endregion
#region 数据层(使用Parameter实现)
/// <summary>
/// 得到最大ID的方法代码
/// </summary>
/// <param name="TabName"></param>
/// <param name="ID"></param>
/// <returns></returns>
public string CreatGetMaxID()
{
StringPlus strclass = new StringPlus();
if (_keys.Count > 0 )
{
string keyname = "" ;
foreach (ColumnInfo obj in _keys)
{
if (CodeCommon.DbTypeToCS(obj.TypeName) == " int " )
{
keyname = obj.ColumnName;
if (obj.IsPK)
{
strclass.AppendLine( "" );
strclass.AppendSpaceLine( 2 , " /// <summary> " );
strclass.AppendSpaceLine( 2 , " /// " + Languagelist[ " summaryGetMaxId " ].ToString());
strclass.AppendSpaceLine( 2 , " /// </summary> " );
strclass.AppendSpaceLine( 2 , " public int GetMaxId() " );
strclass.AppendSpaceLine( 2 , " { " );
strclass.AppendSpaceLine( 3 , " string strsql = \ " select max( " + keyname + " ) + 1 from " + _tablename + " \ " ; " );
strclass.AppendSpaceLine( 3 , " Database db = DatabaseFactory.CreateDatabase(); " );
strclass.AppendSpaceLine( 3 , " object obj = db.ExecuteScalar(CommandType.Text, strsql); " );
strclass.AppendSpaceLine( 3 , " if (obj != null && obj != DBNull.Value) " );
strclass.AppendSpaceLine( 3 , " { " );
strclass.AppendSpaceLine( 4 , " return int.Parse(obj.ToString()); " );
strclass.AppendSpaceLine( 3 , " } " );
strclass.AppendSpaceLine( 3 , " return 1; " );
strclass.AppendSpaceLine( 2 , " } " );
break ;
}
}
}
}
return strclass.ToString();
}
/// <summary>
/// 得到Exists方法的代码
/// </summary>
/// <param name="_tablename"></param>
/// <param name="ID"></param>
/// <returns></returns>
public string CreatExists()
{
StringPlus strclass = new StringPlus();
if (_keys.Count > 0 )
{
strclass.AppendSpaceLine( 2 , " /// <summary> " );
strclass.AppendSpaceLine( 2 , " /// " + Languagelist[ " summaryExists " ].ToString());
strclass.AppendSpaceLine( 2 , " /// </summary> " );
strclass.AppendSpaceLine( 2 , " public bool Exists( " + LTP.CodeHelper.CodeCommon.GetInParameter(Keys, false ) + " ) " );
strclass.AppendSpaceLine( 2 , " { " );
strclass.AppendSpaceLine( 3 , " Database db = DatabaseFactory.CreateDatabase(); " );
strclass.AppendSpaceLine( 3 , " StringBuilder strSql = new StringBuilder(); " );
strclass.AppendSpace( 3 , " strSql.Append(\ " select count( 1 ) from " + _tablename);
strclass.AppendLine( " where " + GetWhereExpression(Keys) + " \ " ); " );
strclass.AppendSpaceLine( 3 , " DbCommand dbCommand = db.GetSqlStringCommand(strSql.ToString()); " );
strclass.Append(GetPreParameter(Keys));
strclass.AppendSpaceLine( 3 , " int cmdresult; " );
strclass.AppendSpaceLine( 3 , " object obj = db.ExecuteScalar(dbCommand); " );
strclass.AppendSpaceLine( 3 , " if ((Object.Equals(obj, null)) || (Object.Equals(obj, System.DBNull.Value))) " );
strclass.AppendSpaceLine( 3 , " { " );
strclass.AppendSpaceLine( 4 , " cmdresult = 0; " );
strclass.AppendSpaceLine( 3 , " } " );
strclass.AppendSpaceLine( 3 , " else " );
strclass.AppendSpaceLine( 3 , " { " );
strclass.AppendSpaceLine( 4 , " cmdresult = int.Parse(obj.ToString()); " );
strclass.AppendSpaceLine( 3 , " } " );
strclass.AppendSpaceLine( 3 , " if (cmdresult == 0) " );
strclass.AppendSpaceLine( 3 , " { " );
strclass.AppendSpaceLine( 4 , " return false; " );
strclass.AppendSpaceLine( 3 , " } " );
strclass.AppendSpaceLine( 3 , " else " );
strclass.AppendSpaceLine( 3 , " { " );
strclass.AppendSpaceLine( 4 , " return true; " );
strclass.AppendSpaceLine( 3 , " } " );
strclass.AppendSpaceLine( 2 , " } " );
}
return strclass.Value;
}
/// <summary>
/// 得到Add()的代码
/// </summary>
public string CreatAdd()
{
if (ModelSpace == "" )
{
// ModelSpace = "ModelClassName"; ;
}
StringPlus strclass = new StringPlus();
StringPlus strclass1 = new StringPlus();
StringPlus strclass2 = new StringPlus();
StringPlus strclass3 = new StringPlus();
StringPlus strclass4 = new StringPlus();
strclass.AppendLine();
strclass.AppendSpaceLine( 2 , " /// <summary> " );
strclass.AppendSpaceLine( 2 , " /// " + Languagelist[ " summaryadd " ].ToString() );
strclass.AppendSpaceLine( 2 , " /// </summary> " );
string strretu = " void " ;
if ((dbobj.DbType == " SQL2000 " || dbobj.DbType == " SQL2005 " || dbobj.DbType == " SQL2008 " ) && (IsHasIdentity))
{
strretu = " int " ;
}
// 方法定义头
string strFun = CodeCommon.Space( 2 ) + " public " + strretu + " Add( " + ModelSpace + " model) " ;
strclass.AppendLine(strFun);
strclass.AppendSpaceLine( 2 , " { " );
strclass.AppendSpaceLine( 3 , " StringBuilder strSql=new StringBuilder(); " );
strclass.AppendSpaceLine( 3 , " strSql.Append(\ " insert into " + _tablename + " (\ " ); " );
strclass1.AppendSpace( 3 , " strSql.Append(\ "" );
foreach (ColumnInfo field in Fieldlist)
{
string columnName = field.ColumnName;
string columnType = field.TypeName;
bool IsIdentity = field.IsIdentity;
string Length = field.Length;
if (field.IsIdentity)
{
continue ;
}
strclass1.Append(columnName + " , " );
strclass2.Append(preParameter + columnName + " , " );
strclass3.AppendSpaceLine( 3 , " db.AddInParameter(dbCommand, \ "" + columnName + " \ " , DbType. " + CSToProcType(columnType) + " , model. " + columnName + " ); " );
}
// 去掉最后的逗号
strclass1.DelLastComma();
strclass2.DelLastComma();
// strclass3.DelLastComma();
strclass1.AppendLine( " )\ " ); " );
strclass.AppendLine(strclass1.ToString());
strclass.AppendSpaceLine( 3 , " strSql.Append(\ " values (\ " ); " );
strclass.AppendSpaceLine( 3 , " strSql.Append(\ "" + strclass2.ToString() + " )\ " ); " );
if ((dbobj.DbType == " SQL2000 " || dbobj.DbType == " SQL2005 " || dbobj.DbType == " SQL2008 " ) && (IsHasIdentity))
{
strclass.AppendSpaceLine( 3 , " strSql.Append(\ " ;select @@IDENTITY\ " ); " );
}
strclass.AppendSpaceLine( 3 , " Database db = DatabaseFactory.CreateDatabase(); " );
strclass.AppendSpaceLine( 3 , " DbCommand dbCommand = db.GetSqlStringCommand(strSql.ToString()); " );
strclass.Append(strclass3.Value);
// 重新定义方法头
if ((dbobj.DbType == " SQL2000 " || dbobj.DbType == " SQL2005 " || dbobj.DbType == " SQL2008 " ) && (IsHasIdentity))
{
strclass.AppendSpaceLine( 3 , " int result; " );
strclass.AppendSpaceLine( 3 , " object obj = db.ExecuteScalar(dbCommand); " );
strclass.AppendSpaceLine( 3 , " if(!int.TryParse(obj.ToString(),out result)) " );
strclass.AppendSpaceLine( 3 , " { " );
strclass.AppendSpaceLine( 4 , " return 0; " );
strclass.AppendSpaceLine( 3 , " } " );
strclass.AppendSpaceLine( 3 , " return result; " );
}
else
{
strclass.AppendSpaceLine( 3 , " db.ExecuteNonQuery(dbCommand); " );
}
strclass.AppendSpace( 2 , " } " );
return strclass.ToString();
}
/// <summary>
/// 得到Update()的代码
/// </summary>
/// <param name="DbName"></param>
/// <param name="_tablename"></param>
/// <param name="_key"></param>
/// <param name="ModelName"></param>
/// <returns></returns>
public string CreatUpdate()
{
if (ModelSpace == "" )
{
// ModelSpace = "ModelClassName"; ;
}
StringPlus strclass = new StringPlus();
StringPlus strclass1 = new StringPlus();
StringPlus strclass2 = new StringPlus();
strclass.AppendSpaceLine( 2 , " /// <summary> " );
strclass.AppendSpaceLine( 2 , " /// " + Languagelist[ " summaryUpdate " ].ToString());
strclass.AppendSpaceLine( 2 , " /// </summary> " );
strclass.AppendSpaceLine( 2 , " public void Update( " + ModelSpace + " model) " );
strclass.AppendSpaceLine( 2 , " { " );
strclass.AppendSpaceLine( 3 , " StringBuilder strSql=new StringBuilder(); " );
strclass.AppendSpaceLine( 3 , " strSql.Append(\ " update " + _tablename + " set \ " ); " );
// int n = 0;
foreach (ColumnInfo field in Fieldlist)
{
string columnName = field.ColumnName;
string columnType = field.TypeName;
string Length = field.Length;
bool IsIdentity = field.IsIdentity;
bool isPK = field.IsPK;
strclass1.AppendSpaceLine( 3 , " db.AddInParameter(dbCommand, \ "" + columnName + " \ " , DbType. " + CSToProcType(columnType) + " , model. " + columnName + " ); " );
if (field.IsIdentity || field.IsPK || (Keys.Contains(field)))
{
continue ;
}
strclass.AppendSpaceLine( 3 , " strSql.Append(\ "" + columnName + " = " + preParameter + columnName + " ,\ " ); " );
}
// 去掉最后的逗号
strclass.DelLastComma();
strclass.AppendLine( " \ " ); " );
strclass.AppendSpaceLine( 3 , " strSql.Append(\ " where " + GetWhereExpression(Keys) + " \ " ); " );
strclass.AppendSpaceLine( 3 , " Database db = DatabaseFactory.CreateDatabase(); " );
strclass.AppendSpaceLine( 3 , " DbCommand dbCommand = db.GetSqlStringCommand(strSql.ToString()); " );
strclass.Append(strclass1.Value);
strclass.AppendSpaceLine( 3 , " db.ExecuteNonQuery(dbCommand);\r\n " );
strclass.AppendSpaceLine( 2 , " } " );
return strclass.ToString();
}
/// <summary>
/// 得到Delete的代码
/// </summary>
/// <param name="_tablename"></param>
/// <param name="_key"></param>
/// <returns></returns>
public string CreatDelete()
{
StringPlus strclass = new StringPlus();
strclass.AppendSpaceLine( 2 , " /// <summary> " );
strclass.AppendSpaceLine( 2 , " /// " + Languagelist[ " summaryDelete " ].ToString());
strclass.AppendSpaceLine( 2 , " /// </summary> " );
strclass.AppendSpaceLine( 2 , " public void Delete( " + LTP.CodeHelper.CodeCommon.GetInParameter(Keys, true ) + " ) " );
strclass.AppendSpaceLine( 2 , " { " );
strclass.AppendSpaceLine( 3 , KeysNullTip);
strclass.AppendSpaceLine( 3 , " StringBuilder strSql=new StringBuilder(); " );
// if (dbobj.DbType != "OleDb")
// {
// strclass.AppendSpaceLine(3, "strSql.Append(\"delete " + _tablename + " \");");
// }
// else
// {
strclass.AppendSpaceLine( 3 , " strSql.Append(\ " delete from " + _tablename + " \ " ); " );
// }
strclass.AppendSpaceLine( 3 , " strSql.Append(\ " where " + GetWhereExpression(Keys) + " \ " ); " );
strclass.AppendSpaceLine( 3 , " Database db = DatabaseFactory.CreateDatabase(); " );
strclass.AppendSpaceLine( 3 , " DbCommand dbCommand = db.GetSqlStringCommand(strSql.ToString()); " );
strclass.Append(GetPreParameter(Keys));
strclass.AppendSpaceLine( 3 , " db.ExecuteNonQuery(dbCommand);\r\n " );
strclass.AppendSpaceLine( 2 , " } " );
return strclass.Value;
}
/// <summary>
/// 得到GetModel()的代码
/// </summary>
/// <param name="DbName"></param>
/// <param name="_tablename"></param>
/// <param name="_key"></param>
/// <param name="ModelName"></param>
/// <returns></returns>
public string CreatGetModel()
{
if (ModelSpace == "" )
{
// ModelSpace = "ModelClassName"; ;
}
StringPlus strclass = new StringPlus();
strclass.Append( "" );
strclass.AppendSpaceLine( 2 , " /// <summary> " );
strclass.AppendSpaceLine( 2 , " /// " + Languagelist[ " summaryGetModel " ].ToString());
strclass.AppendSpaceLine( 2 , " /// </summary> " );
strclass.AppendSpaceLine( 2 , " public " + ModelSpace + " GetModel( " + LTP.CodeHelper.CodeCommon.GetInParameter(Keys, true ) + " ) " );
strclass.AppendSpaceLine( 2 , " { " );
strclass.AppendSpaceLine( 3 , KeysNullTip);
strclass.AppendSpaceLine( 3 , " StringBuilder strSql=new StringBuilder(); " );
strclass.AppendSpaceLine( 3 , " strSql.Append(\ " select " + Fieldstrlist + " from " + _tablename + " \ " ); " );
strclass.AppendSpaceLine( 3 , " strSql.Append(\ " where " + GetWhereExpression(Keys) + " \ " ); " );
strclass.AppendSpaceLine( 3 , " Database db = DatabaseFactory.CreateDatabase(); " );
strclass.AppendSpaceLine( 3 , " DbCommand dbCommand = db.GetSqlStringCommand(strSql.ToString()); " );
strclass.Append(GetPreParameter(Keys));
strclass.AppendSpaceLine( 3 , "" + ModelSpace + " model=null; " );
strclass.AppendSpaceLine( 3 , " using (IDataReader dataReader = db.ExecuteReader(dbCommand)) " );
strclass.AppendSpaceLine( 3 , " { " );
strclass.AppendSpaceLine( 4 , " if(dataReader.Read()) " );
strclass.AppendSpaceLine( 4 , " { " );
strclass.AppendSpaceLine( 5 , " model=ReaderBind(dataReader); " );
strclass.AppendSpaceLine( 4 , " } " );
strclass.AppendSpaceLine( 3 , " } " );
strclass.AppendSpaceLine( 3 , " return model; " );
strclass.AppendSpaceLine( 2 , " } " );
return strclass.Value;
}
/// <summary>
/// 得到GetList()的代码
/// </summary>
/// <param name="_tablename"></param>
/// <param name="_key"></param>
/// <returns></returns>
public string CreatGetList()
{
StringPlus strclass = new StringPlus();
strclass.AppendSpaceLine( 2 , " /// <summary> " );
strclass.AppendSpaceLine( 2 , " /// " + Languagelist[ " summaryGetList " ].ToString());
strclass.AppendSpaceLine( 2 , " /// </summary> " );
strclass.AppendSpaceLine( 2 , " public DataSet GetList(string strWhere) " );
strclass.AppendSpaceLine( 2 , " { " );
strclass.AppendSpaceLine( 3 , " StringBuilder strSql=new StringBuilder(); " );
strclass.AppendSpace( 3 , " strSql.Append(\ " select " );
strclass.AppendLine(Fieldstrlist + " \ " ); " );
strclass.AppendSpaceLine( 3 , " strSql.Append(\ " FROM " + TableName + " \ " ); " );
strclass.AppendSpaceLine( 3 , " if(strWhere.Trim()!=\ " \ " ) " );
strclass.AppendSpaceLine( 3 , " { " );
strclass.AppendSpaceLine( 4 , " strSql.Append(\ " where \ " +strWhere); " );
strclass.AppendSpaceLine( 3 , " } " );
strclass.AppendSpaceLine( 3 , " Database db = DatabaseFactory.CreateDatabase(); " );
strclass.AppendSpaceLine( 3 , " return db.ExecuteDataSet(CommandType.Text, strSql.ToString()); " );
strclass.AppendSpaceLine( 2 , " } " );
return strclass.Value;
}
/// <summary>
/// 得到GetList()的代码
/// </summary>
/// <param name="_tablename"></param>
/// <param name="_key"></param>
/// <returns></returns>
public string CreatGetListByPageProc()
{
StringPlus strclass = new StringPlus();
strclass.AppendSpaceLine( 2 , " /// <summary> 分页获取数据列表的方法 " );
strclass.AppendSpaceLine( 2 , " /// </summary> " );
strclass.AppendSpaceLine( 2 , " /// <param name='fileds'>选择的字段</param> " );
strclass.AppendSpaceLine( 2 , " /// <param name='order'>排序字段</param> " );
strclass.AppendSpaceLine( 2 , " /// <param name='ordertype'>排序类型desc或者asc</param> " );
strclass.AppendSpaceLine( 2 , " /// <param name='PageSize'>页大小</param> " );
strclass.AppendSpaceLine( 2 , " /// <param name='PageIndex'>第几页(索引)</param " );
strclass.AppendSpaceLine( 2 , " /// <param name='strWhere'>条件</param> " );
strclass.AppendSpaceLine( 2 , " /// <returns></returns> " );
strclass.AppendSpaceLine( 2 , " public DataSet GetList(string fileds, string order, string ordertype, int PageSize, int PageIndex, string strWhere) " );
strclass.AppendSpaceLine( 2 , " { " );
strclass.AppendSpaceLine( 3 , " Database db = DatabaseFactory.CreateDatabase(); " );
strclass.AppendSpaceLine( 3 , " DbCommand dbCommand = db.GetStoredProcCommand(\ " proc_SplitPage\ " ); " );
// 存储过程名
strclass.AppendSpaceLine( 3 , " db.AddInParameter(dbCommand,\ " tblName\ " , DbType.AnsiString,\ "" + TableName + " \ " ); " );
// 表名
strclass.AppendSpaceLine( 3 , " db.AddInParameter(dbCommand, \ " strFields\ " , DbType.AnsiString, fileds); " );
strclass.AppendSpaceLine( 3 , " db.AddInParameter(dbCommand, \ " PageSize\ " , DbType.Int32, PageSize); " );
strclass.AppendSpaceLine( 3 , " db.AddInParameter(dbCommand, \ " PageIndex\ " , DbType.Int32, PageIndex); " );
strclass.AppendSpaceLine( 3 , " db.AddInParameter(dbCommand, \ " strOrder\ " , DbType.String, order); " );
strclass.AppendSpaceLine( 3 , " db.AddInParameter(dbCommand, \ " strOrderType\ " , DbType.String, ordertype); " );
strclass.AppendSpaceLine( 3 , " db.AddInParameter(dbCommand, \ " strWhere\ " , DbType.AnsiString, strWhere); " );
strclass.AppendSpaceLine( 3 , " return db.ExecuteDataSet(dbCommand); " );
strclass.AppendSpaceLine( 2 , " } " );
strclass.AppendSpaceLine( 2 , " /// <summary> " );
strclass.AppendSpaceLine( 2 , " /// 计算记录数的方法 " );
strclass.AppendSpaceLine( 2 , " /// </summary> " );
strclass.AppendSpaceLine( 2 , " /// <param name=\ " strwhere\ " ></param> " );
strclass.AppendSpaceLine( 2 , " /// <returns></returns> " );
strclass.AppendSpaceLine( 2 , " public int datacount(string strwhere) " );
strclass.AppendSpaceLine( 3 , " { " );
strclass.AppendSpaceLine( 4 , " string sql = \ " select count( 1 ) from " + TableName + " \ " ; " );
strclass.AppendSpaceLine( 4 , " if (!string.IsNullOrEmpty(strwhere)) " );
strclass.AppendSpaceLine( 4 , " { " );
strclass.AppendSpaceLine( 5 , " sql += \ " where \ " + strwhere; " );
strclass.AppendSpaceLine( 4 , " } " );
strclass.AppendSpaceLine( 4 , " Database db = DatabaseFactory.CreateDatabase(); " );
strclass.AppendSpaceLine( 4 , " DbCommand dbCommand = db.GetSqlStringCommand(sql); " );
strclass.AppendSpaceLine( 4 , " int i = int.Parse(db.ExecuteScalar(dbCommand).ToString()); " );
strclass.AppendSpaceLine( 4 , " return i; " );
strclass.AppendSpaceLine( 3 , " } " );
return strclass.Value;
}
#region 生成对象实体绑定数据
/// <summary>
/// 生成对象实体绑定数据
/// </summary>
/// <param name="dt"></param>
/// <returns></returns>
public string CreatReaderBind()
{
if (ModelSpace == "" )
{
// ModelSpace = "ModelClassName"; ;
}
StringPlus strclass = new StringPlus();
StringPlus strclass1 = new StringPlus();
strclass.AppendLine( "" );
strclass.AppendSpaceLine( 2 , " /// <summary> " );
strclass.AppendSpaceLine( 2 , " /// 对象实体绑定数据 " );
strclass.AppendSpaceLine( 2 , " /// </summary> " );
strclass.AppendSpaceLine( 2 , " public " + ModelSpace + " ReaderBind(IDataReader dataReader) " );
strclass.AppendSpaceLine( 2 , " { " );
strclass.AppendSpaceLine( 3 , ModelSpace + " model=new " + ModelSpace + " (); " );
bool isobj = false ;
foreach (ColumnInfo field in Fieldlist)
{
string columnName = field.ColumnName;
string columnType = field.TypeName;
bool IsIdentity = field.IsIdentity;
string Length = field.Length;
switch (CodeCommon.DbTypeToCS(columnType))
{
case " int " :
{
isobj = true ;
strclass1.AppendSpaceLine( 3 , " ojb = dataReader[\ "" + columnName + " \ " ]; " );
strclass1.AppendSpaceLine( 3 , " if(ojb != null && ojb != DBNull.Value) " );
strclass1.AppendSpaceLine( 3 , " { " );
strclass1.AppendSpaceLine( 4 , " model. " + columnName + " =(int)ojb; " );
strclass1.AppendSpaceLine( 3 , " } " );
}
break ;
case " long " :
{
isobj = true ;
strclass1.AppendSpaceLine( 3 , " ojb = dataReader[\ "" + columnName + " \ " ]; " );
strclass1.AppendSpaceLine( 3 , " if(ojb != null && ojb != DBNull.Value) " );
strclass1.AppendSpaceLine( 3 , " { " );
strclass1.AppendSpaceLine( 4 , " model. " + columnName + " =(long)ojb; " );
strclass1.AppendSpaceLine( 3 , " } " );
}
break ;
case " decimal " :
{
isobj = true ;
strclass1.AppendSpaceLine( 3 , " ojb = dataReader[\ "" + columnName + " \ " ]; " );
strclass1.AppendSpaceLine( 3 , " if(ojb != null && ojb != DBNull.Value) " );
strclass1.AppendSpaceLine( 3 , " { " );
strclass1.AppendSpaceLine( 4 , " model. " + columnName + " =(decimal)ojb; " );
strclass1.AppendSpaceLine( 3 , " } " );
}
break ;
case " DateTime " :
{
isobj = true ;
strclass1.AppendSpaceLine( 3 , " ojb = dataReader[\ "" + columnName + " \ " ]; " );
strclass1.AppendSpaceLine( 3 , " if(ojb != null && ojb != DBNull.Value) " );
strclass1.AppendSpaceLine( 3 , " { " );
strclass1.AppendSpaceLine( 4 , " model. " + columnName + " =(DateTime)ojb; " );
strclass1.AppendSpaceLine( 3 , " } " );
}
break ;
case " string " :
{
strclass1.AppendSpaceLine( 3 , " model. " + columnName + " =dataReader[\ "" + columnName + " \ " ].ToString(); " );
}
break ;
case " bool " :
{
isobj = true ;
strclass1.AppendSpaceLine( 3 , " ojb = dataReader[\ "" + columnName + " \ " ]; " );
strclass1.AppendSpaceLine( 3 , " if(ojb != null && ojb != DBNull.Value) " );
strclass1.AppendSpaceLine( 3 , " { " );
strclass1.AppendSpaceLine( 4 , " model. " + columnName + " =(bool)ojb; " );
strclass1.AppendSpaceLine( 3 , " } " );
}
break ;
case " byte[] " :
{
isobj = true ;
strclass1.AppendSpaceLine( 3 , " ojb = dataReader[\ "" + columnName + " \ " ]; " );
strclass1.AppendSpaceLine( 3 , " if(ojb != null && ojb != DBNull.Value) " );
strclass1.AppendSpaceLine( 3 , " { " );
strclass1.AppendSpaceLine( 4 , " model. " + columnName + " =(byte[])ojb; " );
strclass1.AppendSpaceLine( 3 , " } " );
}
break ;
case " Guid " :
{
isobj = true ;
strclass1.AppendSpaceLine( 3 , " ojb = dataReader[\ "" + columnName + " \ " ]; " );
strclass1.AppendSpaceLine( 3 , " if(ojb != null && ojb != DBNull.Value) " );
strclass1.AppendSpaceLine( 3 , " { " );
strclass1.AppendSpaceLine( 4 , " model. " + columnName + " = new Guid(ojb.ToString()); " );
strclass1.AppendSpaceLine( 3 , " } " );
}
break ;
default :
strclass1.AppendSpaceLine( 3 , " model. " + columnName + " =dataReader[\ "" + columnName + " \ " ].ToString();\r\n " );
break ;
}
}
if (isobj)
{
strclass.AppendSpaceLine( 3 , " object ojb; " );
}
strclass.Append(strclass1.ToString());
strclass.AppendSpaceLine( 3 , " return model; " );
strclass.AppendSpaceLine( 2 , " } " );
return strclass.Value;
}
public string CreatGetListArray()
{
string strList = " List< " + ModelSpace + " > " ;
StringPlus strclass = new StringPlus();
strclass.AppendSpaceLine( 2 , " /// <summary> " );
strclass.AppendSpaceLine( 2 , " /// 获得数据列表(比DataSet效率高,推荐使用) " );
strclass.AppendSpaceLine( 2 , " /// </summary> " );
strclass.AppendSpaceLine( 2 , " public " + strList + " GetListArray(string strWhere) " );
strclass.AppendSpaceLine( 2 , " { " );
strclass.AppendSpaceLine( 3 , " StringBuilder strSql=new StringBuilder(); " );
strclass.AppendSpace( 3 , " strSql.Append(\ " select " );
strclass.AppendLine(Fieldstrlist + " \ " ); " );
strclass.AppendSpaceLine( 3 , " strSql.Append(\ " FROM " + TableName + " \ " ); " );
strclass.AppendSpaceLine( 3 , " if(strWhere.Trim()!=\ " \ " ) " );
strclass.AppendSpaceLine( 3 , " { " );
strclass.AppendSpaceLine( 4 , " strSql.Append(\ " where \ " +strWhere); " );
strclass.AppendSpaceLine( 3 , " } " );
strclass.AppendSpaceLine( 3 , strList + " list = new " + strList + " (); " );
strclass.AppendSpaceLine( 3 , " Database db = DatabaseFactory.CreateDatabase(); " );
strclass.AppendSpaceLine( 3 , " using (IDataReader dataReader = db.ExecuteReader(CommandType.Text, strSql.ToString())) " );
strclass.AppendSpaceLine( 3 , " { " );
strclass.AppendSpaceLine( 4 , " while (dataReader.Read()) " );
strclass.AppendSpaceLine( 4 , " { " );
strclass.AppendSpaceLine( 5 , " list.Add(ReaderBind(dataReader)); " );
strclass.AppendSpaceLine( 4 , " } " );
strclass.AppendSpaceLine( 3 , " } " );
strclass.AppendSpaceLine( 3 , " return list; " );
strclass.AppendSpaceLine( 2 , " } " );
return strclass.Value;
}
#endregion
#endregion
#region CSToProcType
/// <summary>
/// 企业库数据库字段对应
/// </summary>
/// <param name="cstype"></param>
/// <returns></returns>
private static string CSToProcType( string cstype)
{
string ProcType = cstype;
switch (cstype.Trim().ToLower())
{
case " string " :
case " nvarchar " :
case " nchar " :
case " ntext " :
ProcType = " String " ;
break ;
case " text " :
case " char " :
case " varchar " :
ProcType = " AnsiString " ;
break ;
case " datetime " :
case " smalldatetime " :
ProcType = " DateTime " ;
break ;
case " smallint " :
ProcType = " Int16 " ;
break ;
case " tinyint " :
ProcType = " Byte " ;
break ;
case " int " :
ProcType = " Int32 " ;
break ;
case " bigint " :
case " long " :
ProcType = " Int64 " ;
break ;
case " float " :
ProcType = " Double " ;
break ;
case " real " :
case " numeric " :
case " decimal " :
ProcType = " Decimal " ;
break ;
case " money " :
case " smallmoney " :
ProcType = " Currency " ;
break ;
case " bool " :
case " bit " :
ProcType = " Boolean " ;
break ;
case " binary " :
case " varbinary " :
ProcType = " Binary " ;
break ;
case " image " :
ProcType = " Image " ;
break ;
case " uniqueidentifier " :
ProcType = " Guid " ;
break ;
case " timestamp " :
ProcType = " String " ;
break ;
default :
ProcType = " String " ;
break ;
}
return ProcType;
}
#endregion
}
}