Entity Framework 中 Schema是什么

在使用Entity Framework时,会注意到下面这句:

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{

    modelBuilder.HasDefaultSchema("DEV");
..... }

如果是sql server的话,写上dbo. 就行了

如果是oracle的话,写上“用户名”。

如果schema是用户的话,那为什么不叫HasDefaultUser呢? 非要叫个schema,弄的我都不知道怎么翻译它!

我们再来看,在数据迁移的过程生成的语句:

CreateTable(
                "DEV.BackgroundJobs",
                c => new
                    {
                        Id = c.Long(nullable: false, identity: true),
                        JobType = c.String(nullable: false, maxLength: 512),
                        JobArgs = c.String(nullable: false),
                        TryCount = c.Short(nullable: false),
                        NextTryTime = c.DateTime(nullable: false),
                        LastTryTime = c.DateTime(),
                        IsAbandoned = c.Boolean(nullable: false),
                        Priority = c.Byte(nullable: false),
                        CreationTime = c.DateTime(nullable: false),
                        CreatorUserId = c.Long(),
                    })
                .PrimaryKey(t => t.Id)
                .Index(t => new { t.IsAbandoned, t.NextTryTime });

更加坚定了我的判断 ,schema就是用户名.

然而,经过一翻百度... 终于颠覆了我的认识。

DEV.BackgroundJobs。这里的DEV不是用户,是schema.

总的来看:

1. 用户user不是管理表的,user只是负责连接数据库的。别把它想的那么复杂。

2. schema是管理数据库对象的,当然包括表了,还有packages functions proceures等。

总结一句:

A USER may be given access to SCHEMA OBJECTS owned by different USERS. (https://asktom.oracle.com/pls/asktom/f?p=100:11:0::::P11_QUESTION_ID:6162110256950)

 

但这里也解释不了为什么user和schema会重名。

原来,当在数据库中创建了一个用户的时候,会自动创建一个同名的schema.

引用上文的话:

once you create a user in the database -- there is a schema. it is empty, but there is a schema. 

In fact, we have the concept of a schemaless user (user is stored outside the database, in an ldap respository for example). Here, there is no schema, not even the empty one. 

后面这句我选择忽略,很少用到。

 

所以最后用这位Tom大叔的话,做一个总结:他们是完全可相互替换使用

in oracle for all intents and purposes they are 100% interchangeable. 

 

posted @ 2017-11-01 16:46  二奎  阅读(1738)  评论(0编辑  收藏  举报