1.自定义 表名属性 TableNameAttribute
2.自定义 主键属性 PrimaryKeyAttribute
3.自定义 列名属性 TableColumnAttribute
4.数据表person对应的实体类person.cs
5.获得person.cs类型实体 对应的表名及字段名
=========================================
下面的属性代码文件 都直接建立在App_Code下 以方便使用
1.自定义 表名属性 TableNameAttribute
------------------------------------
using System;
/**//// <summary>
/// TableNameAttribute 的摘要说明
/// </summary>
[AttributeUsage( AttributeTargets.Class, AllowMultiple=false, Inherited=true )]
public sealed class TableNameAttribute : Attribute
{
private string name;
private string schema;
//private CacheStrategy cacheStrategy = GentleSettings.DefaultCacheStrategy;
/**//// <summary>
/// The constructor for the TableName attribute.
/// </summary>
/// <param name="name">The name of the database table used to store instances of this class.</param>
public TableNameAttribute( string name )
{
this.name = name;
}
/**//// <summary>
/// The constructor for the TableName attribute.
/// </summary>
/// <param name="name">The name of the database table used to store instances of this class.</param>
/// <param name="strategy">The cache stratgey to use for instances of this type. <see
/// cref="CacheStrategy"/> for a list of available options.</param>
//public TableNameAttribute( string name, CacheStrategy strategy )
//{
// this.name = name;
// this.cacheStrategy = strategy;
//}
/**//// <summary>
/// The name of the database table used to store instances of this class.
/// </summary>
public string Name
{
get { return name; }
}
/**//// <summary>
/// The optional schema name with which to prefix the table name in queries.
/// This value overrides the default schema definition (if present) in the
/// configuration file. Note: this property is currently unused.
/// </summary>
public string Schema
{
get { return schema; }
set { schema = value; }
}
/**////// <summary>
///// The cache behavior for objects of this type. <see cref="CacheStrategy"/>
///// for a list of available options.
///// </summary>
//public CacheStrategy CacheStrategy
//{
// get { return cacheStrategy; }
// set { cacheStrategy = value; }
//}
}
2.自定义 主键属性 PrimaryKeyAttribute
------------------------------------
using System;
/**//// <summary>
/// PrimaryKeyAttribute 的摘要说明
/// </summary>
[AttributeUsage(AttributeTargets.Property | AttributeTargets.Field, AllowMultiple = true, Inherited = true)]
public sealed class PrimaryKeyAttribute : Attribute
{
private bool autoGenerated = false;
/**//// <summary>
/// Set this property to true for primary keys that are automatically assigned
/// by the database on insert (identity columns in SQL server terminology).
/// </summary>
public bool AutoGenerated
{
get { return autoGenerated; }
set { autoGenerated = value; }
}
}
3.自定义 列名属性 TableColumnAttribute
--------------------------------------
using System;
using System.Data;
/**//// <summary>
/// TableColumnAttribute 的摘要说明
/// </summary>
[AttributeUsage( AttributeTargets.Property | AttributeTargets.Field, AllowMultiple=false, Inherited=true )]
public class TableColumnAttribute : Attribute
{
private string name;
private bool notNull;
private int size;
private bool hasDbType = false; // true when DbType property has been set
private long dbType;
private object nullValue = null;
private bool handleEnumAsString = false;
private bool isReadOnly = false;
private bool isUpdateAfterWrite = false;
/**//// <summary>
/// Constructor for table columns that are named after their property counterpart
/// and whose value cannot be null.
/// </summary>
public TableColumnAttribute()
: this(null, true)
{
}
/**//// <summary>
/// Constructor for table columns that are named after their property counterpart.
/// </summary>
/// <param name="notNull">A boolean telling whether null values are allowed in the database</param>
public TableColumnAttribute(bool notNull)
: this(null, notNull)
{
}
/**//// <summary>
/// Constructor for table columns whose value cannot be null.
/// </summary>
/// <param name="name">The name of the database column</param>
public TableColumnAttribute(string name)
: this(name, true)
{
}
/**//// <summary>
/// Constructor for table columns.
/// </summary>
/// <param name="name">The name of the database column</param>
/// <param name="notNull">A boolean telling whether null values are allowed in the database</param>
public TableColumnAttribute(string name, bool notNull)
{
this.name = name;
this.notNull = notNull;
}
/**//// <summary>
/// The name of the database column for storing the property decorated with this attribute.
/// </summary>
public string Name
{
get { return name; }
}
/**//// <summary>
/// This property (defaults to true) can be used to specify whether NULL values are
/// allowed in the database. This allows the framework to fail early if a constraint
/// is violated.
/// </summary>
public bool NotNull
{
get { return notNull; }
set { notNull = value; }
}
/**//// <summary>
/// The database type of the field in the database. Beware that the DbType enumeration
/// values are NOT the ones used by the individual providers. Gentle does NOT convert
/// the DbType to a "best match" for the provider. It is therefore recommended that
/// you use the DatabaseType below until a better type definition system is available.
/// </summary>
[Obsolete("Please use DatabaseType instead.")]
public DbType DbType
{
get { return (DbType)dbType; }
set
{
hasDbType = true;
dbType = (long)value;
}
}
/**//// <summary>
/// The database type of the field in the database. Convert the actual database type
/// enumeration to a long by casting it in the declaration.
/// </summary>
public long DatabaseType
{
get { return dbType; }
set
{
hasDbType = true;
dbType = value;
}
}
/**//// <summary>
/// The size or length of the field in the database. String properties will be clipped
/// to fit.
/// This feature will obsoleted once Gentle is capable of extracting type and size
/// information directly from the database. If specified, the values must match
/// those extracted from the database (when implemented).
/// </summary>
public int Size
{
get { return size; }
set { size = value; }
}
/**//// <summary>
/// This property indicates whether a DbType was specified. This construct is necessary
/// because the DbType enum has no value for undefined.
/// </summary>
public bool HasDbType
{
get { return hasDbType; }
}
/**//// <summary>
/// Obsolete, use NullValue instead.
/// </summary>
[Obsolete("Use NullValue instead.")]
public object MagicValue
{
get { return nullValue; }
set { nullValue = value; }
}
/**//// <summary>
/// This value of this property is used when a column is NotNull and the property value
/// is null. If this is undefined the framework will throw an error for NotNull columns
/// whose values are null.
/// </summary>
public object NullValue
{
get { return nullValue; }
set { nullValue = value; }
}
NullValue Helper Properties for VB.NET Users#region NullValue Helper Properties for VB.NET Users
/**//// <summary>
/// This property allows type-safe setting of the NullValue for VB users.
/// </summary>
public int NullValue_int
{
set { NullValue = value; }
}
/**//// <summary>
/// This property allows type-safe setting of the NullValue for VB users.
/// </summary>
public NullOption NullValue_opt
{
set { NullValue = value; }
}
#endregion
/**//// <summary>
/// This value indicates that the column should not be set on insert and update. It is
/// primarily useful for columns that are set internally by the database.
/// </summary>
public bool IsReadOnly
{
get { return isReadOnly; }
set { isReadOnly = value; }
}
/**//// <summary>
/// This value indicates that the column must be read after each insert and update. It is
/// primarily useful for columns that are set internally by the database. Note that using
/// this feature (by setting this to true for any column) will significantly impact
/// performance for the worse, as for every update/insert another select will be
/// performed. Also, fields will be updated using reflection after select, which is also
/// quite slow (depending on the number of columns).
/// </summary>
public bool IsUpdateAfterWrite
{
get { return isUpdateAfterWrite; }
set { isUpdateAfterWrite = value; }
}
/**//// <summary>
/// If member which has this attribute attached is enum then this property
/// indicates wheter framework saves it as string or as integer.
/// Default is false, ie enums are saved as integers
/// </summary>
public bool HandleEnumAsString
{
get { return handleEnumAsString; }
set { handleEnumAsString = value; }
}
}
public enum NullOption
{
/**//// <summary>
/// <type>.MinValue will be stored as NULL, and NULL will be read as <type>.MinValue.
/// </summary>
MinValue,
/**//// <summary>
/// <type>.MaxValue will be stored as NULL, and NULL will be read as <type>.MaxValue.
/// </summary>
MaxValue,
/**//// <summary>
/// 0 (or the equivalent for other numeric types) will be stored as NULL, and NULL will be read as 0.
/// </summary> This value can only be used with numeric types (such as decimal).
Zero,
/**//// <summary>
/// Guid.Empty will be stored as NULL, and NULL will be read as Guid.Empty. This value can only be
/// used with Guid fields.
/// </summary>
EmptyGuid
}
4.数据表person对应的实体类person.cs
------------------------------------
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
/**//// <summary>
/// person 的摘要说明
/// </summary>
[TableName("person")]
public class person
{
public person()
{
}
//[TableColumn("personID", NotNull = true), PrimaryKey]
protected int _personID;
//[TableColumn("personName", NotNull = true)]
protected string _personName = String.Empty;
[TableColumn("personID", NotNull = true), PrimaryKey]
public int PersonID
{
get { return _personID; }
set { _personID = value; }
}
[TableColumn("personName", NotNull = true)]
public string PersonName
{
get { return _personName; }
set { _personName = value; }
}
}
5.获得person.cs类型实体 对应的表名及字段名
------------------------------------------
protected void Button1_Click(object sender, EventArgs e)
{
person aPerson = new person();
aPerson.PersonID = 22;
aPerson.PersonName = "zhangsan";
Type aType = aPerson.GetType();
//类实体公开属性对应的列名属性
PropertyInfo[] aPropertyInfos = aType.GetProperties();
string strPublicProperty = " ";
for (int i = 0; i < aPropertyInfos.Length; i++)
{
PropertyInfo aPropertyInfo = (PropertyInfo)aPropertyInfos[i];
strPublicProperty += i.ToString() + " : 实体属性名 " + aPropertyInfo.Name;
strPublicProperty += " 对应值 " + aPropertyInfo.GetValue(aPerson, null).ToString() + " ";
object[] attrs = aPropertyInfo.GetCustomAttributes(typeof(TableColumnAttribute), true);
for (int m = 0; m < attrs.Length; m++)
{
strPublicProperty += " 对应列名 " + ((TableColumnAttribute)attrs[m]).Name;
}
}
this.TextBox1.Text = strPublicProperty;
//FieldInfo[] aFieldInfos = aType.GetFields();
//string strPublicField = " ";
//for (int j = 0; j < aFieldInfos.Length; j++)
//{
// FieldInfo aFieldInfo = (FieldInfo)aFieldInfos[j];
// strPublicField += j.ToString() + " : " + aFieldInfo.Name + " ";
//}
//this.TextBox2.Text = strPublicField;
//类实体对应的表名属性
string strTablePKName = " ";
object[] attrsAA = aType.GetCustomAttributes(typeof(TableNameAttribute), true);
for (int n = 0; n < attrsAA.Length; n++)
{
strTablePKName += " " + ((TableNameAttribute)attrsAA[n]).Name;
}
//类实体对应的主键属性
MemberInfo[] aMemberInfos = aType.GetMembers(BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance);
string strMemberInfo = " ";
for (int k = 0; k < aMemberInfos.Length; k++)
{
MemberInfo aM = aMemberInfos[k];
object[] attrs = aM.GetCustomAttributes(typeof(PrimaryKeyAttribute), true);
for (int m = 0; m < attrs.Length; m++)
{
strTablePKName += " 主键 " + aM.Name;
}
}
this.TextBox2.Text = strTablePKName;
}