本文整理匯總了Golang中github.com/cockroachdb/cockroach/pkg/sql/sqlbase.DescriptorProto.TypeName方法的典型用法代碼示例。如果您正苦於以下問題:Golang DescriptorProto.TypeName方法的具體用法?Golang DescriptorProto.TypeName怎麽用?Golang DescriptorProto.TypeName使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/cockroachdb/cockroach/pkg/sql/sqlbase.DescriptorProto
的用法示例。
在下文中一共展示了DescriptorProto.TypeName方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: anyPrivilege
// anyPrivilege implements the DescriptorAccessor interface.
func (p *planner) anyPrivilege(descriptor sqlbase.DescriptorProto) error {
if userCanSeeDescriptor(descriptor, p.session.User) {
return nil
}
return fmt.Errorf("user %s has no privileges on %s %s",
p.session.User, descriptor.TypeName(), descriptor.GetName())
}
示例2: createDescriptor
// createDescriptor implements the DescriptorAccessor interface.
func (p *planner) createDescriptor(
plainKey sqlbase.DescriptorKey, descriptor sqlbase.DescriptorProto, ifNotExists bool,
) (bool, error) {
idKey := plainKey.Key()
if exists, err := p.descExists(idKey); err == nil && exists {
if ifNotExists {
// Noop.
return false, nil
}
// Key exists, but we don't want it to: error out.
switch descriptor.TypeName() {
case "database":
return false, sqlbase.NewDatabaseAlreadyExistsError(plainKey.Name())
case "table", "view":
return false, sqlbase.NewRelationAlreadyExistsError(plainKey.Name())
default:
return false, descriptorAlreadyExistsErr{descriptor, plainKey.Name()}
}
} else if err != nil {
return false, err
}
id, err := GenerateUniqueDescID(p.txn)
if err != nil {
return false, err
}
return true, p.createDescriptorWithID(idKey, id, descriptor)
}
示例3: checkPrivilege
// checkPrivilege implements the DescriptorAccessor interface.
func (p *planner) checkPrivilege(
descriptor sqlbase.DescriptorProto, privilege privilege.Kind,
) error {
if descriptor.GetPrivileges().CheckPrivilege(p.session.User, privilege) {
return nil
}
return fmt.Errorf("user %s does not have %s privilege on %s %s",
p.session.User, privilege, descriptor.TypeName(), descriptor.GetName())
}