视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
[.NET]TitanORM中执行数据添加Insert-快速示例
2020-11-09 15:56:50 责编:小采
文档


本 示例 使用SqlServer2005,先在 数据 库中创建一张表, 其中CustomerId是主键且自动增长;CustomerType用来保存int枚举,字段类型使用int;InsertTime将系统时间作为默认值 CREATE TABLE [ Customer ] ( [ CustomerId ] [ int ] IDENTITY ( 1 , 1 ) NOT NU

本示例使用SqlServer2005,先在数据库中创建一张表,

其中CustomerId是主键且自动增长;CustomerType用来保存int枚举,字段类型使用int;InsertTime将系统时间作为默认值

CREATE TABLE [Customer](
 [CustomerId] [int] IDENTITY(1,1) NOT NULL,
 [CustomerName] [nvarchar](50) NOT NULL,
 [CustomerType] [int] NOT NULL,
 [Description] [int] NULL,
 [InsertTime] [datetime] NOT NULL default(getdate()), --用于测试在数据库中设置默认值
 CONSTRAINT [PK_Customer] PRIMARY KEY([CustomerId])
) ON [PRIMARY]

接下来创建相应的实体类,可以使用枚举:

 public enum CustomerType
 {
 Home, Abroad
 }

 [Table]
 public class Customer
 {
 [Column(IsPrimaryKey=true)]
 [SqlServerColumn(IsIdentity=true)]//针对SqlServer特有的标识列
 public int CustomerId { get; set; } 

 [Column]
 public string CustomerName { get; set; } 

 [Column]
 public CustomerType CustomerType { get; set; }

 [Column]
 public string Description { get; set; }

 [Column]
 [SqlServerColumn(GenerateInsert=AttributeBoolean.False)]//数据库中已有默认值,告诉Titan在生成Insert语句时不要包含本列
 public DateTime InsertTime { get; set; } 
 }

使用Titan往数据库中添加一条记录:

 class Program
 {
 static void Main(string[] args)
 {
 IDbSession se = OpenDbSession();

 Customer customer = new Customer();
 customer.CustomerName = "customer name";
 customer.CustomerType = CustomerType.Abroad;

 se.Insert(customer);
 Console.WriteLine(string.Format("执行Insert后标识列返回的CustomerId={0}",customer.CustomerId));

 se.Close();

 Console.ReadLine();
 }

 static IDbSession OpenDbSession()
 {
 //使用SqlServer。如果是其它数据库则可以使用:OracleSqlProvider,MySqlSqlProvider,SQLiteSqlProvider...
 Type providerType = typeof(SqlServerSqlProvider);

 //数据库连接支付串
 string connectionString = @"Data Source=192.168.17.129\SQLEXPRESS;Initial Catalog=titandemo;User Id=sa;Password=123456;";

 //sql语句追踪,可以跟踪Titan生成的Sql语句,此处使用控制台中查看生成的Sql语句
 ISqlTracer[] sqlTracers = new ISqlTracer[] { new ConsoleSqlTracer() };

 return DbSessionFactory.CreateAndOpenSession(providerType, connectionString, sqlTracers); 
 }
 }

查看数据库已经添加成功:

控制台程序运行截屏:

从中可以看到生成的Sql语句中不包含CustomerId列和InsertTime列,

由于CustomerId使用了[SqlServerColumn(IsIdentity=true)]标注,Titan在生成Insert语句时不会包含此列,默认情况下还会在Insert语句中包含set @4=SCOPE_Identity()用以取回数据库自动生成的值。

另外数据库中InsertTime列使用了默认值,并且实体类属性中使用了[SqlServerColumn(GenerateInsert=AttributeBoolean.False)]标注,因此生成的Sql语句中也不包含此列。

关于IsIdentity=true标注,如果在[Column]标注中强制不返回,那么Insert语句中set @4=SCOPE_Identity()语句不会被生成。代码如下(注意红色部分):

 [Table]
 public class Customer
 {
 [Column(IsPrimaryKey = true, ReturnAfterInsert = AttributeBoolean.False)]
 [SqlServerColumn(IsIdentity = true)]//针对SqlServer特有的标识列
 public int CustomerId { get; set; }

再运行程序,发现Insert语句中不再包含set @4=SCOPE_Identity(),CustomerId的值仍为0。

下载本文
显示全文
专题