同义词的作用

2024-03-24 00:20
文章标签 作用 同义词

本文主要是介绍同义词的作用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645

同义词

同义词本质上属于近义词的概念,它是表、索引、视图等模式对象的一个别名

通过为模式对象创建同义词,可以隐藏对象的实际名称和所有者信息,这样可以为对象提供一定的安全性保证

SELECT SYSDATE FROM dual ;

此时的程序就是查询日期时间,但是在之前说过 dual 属于一张临时表,那么这张临时表到底是属于谁的呢?

通过一系列的查询可以发现,dual 数据表是属于 sys 用户的。

既然 dual 属于 sys,那么按照之前的概念来说,不同的用户要进行表的互相访问,前面需要使用模式名,也就是说如果 scott 用户要使用 dual,则应该使用 sys.dual 才对。

而这个操作就属于同义词的定义范畴,也就是说 dual 是 sys.dual 的同义词。如果想创建同义词,可使用一下语法:

create [PUBLIC] SYNONYM 同义词名称 FOR 模式.表名称

其中 PUBLIC 表示创建的同义词是公用的,数据库中所有用户都可以使用

将 scott.emp 数据表映射为 semp,连接 sys 用户

CREATE SYNONYM semp FOR scott.emp ;

 同义词创建完成之后就可以直接利用同义词进行数据查询

SELECT * FROM semp ;

但是现在的问题是,此同义词无法被其他用户使用,它只能够被 sys 使用

如果想让一个同义词被所有用户使用,那么应该将其创建为公共同义词

切换回 sys 用户,重新创建同义词

CONN sys/change_on_install AS SYSDBA ;
DROP SYNONYM semp ;
CREATE PUBLIC SYNONYM semp FOR scott.emp ;

 上面代码中“DROP SYNONYM semp ”为删除同义词的语句。虽然同义词可以被其他用户访问了,但是对我们开发的意义不大

如果在当前模式中创建私有同义词,要求数据库用户必须具有 create synonym 的系统权限

如果要在其他模式中创建私有同义词,要求数据库用户必须具有 create any synonym注意的系统权限

这篇关于同义词的作用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/839985

相关文章

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么

java中反射Reflection的4个作用详解

《java中反射Reflection的4个作用详解》反射Reflection是Java等编程语言中的一个重要特性,它允许程序在运行时进行自我检查和对内部成员(如字段、方法、类等)的操作,本文将详细介绍... 目录作用1、在运行时判断任意一个对象所属的类作用2、在运行时构造任意一个类的对象作用3、在运行时判断

python常用的正则表达式及作用

《python常用的正则表达式及作用》正则表达式是处理字符串的强大工具,Python通过re模块提供正则表达式支持,本文给大家介绍python常用的正则表达式及作用详解,感兴趣的朋友跟随小编一起看看吧... 目录python常用正则表达式及作用基本匹配模式常用正则表达式示例常用量词边界匹配分组和捕获常用re

Java 继承和多态的作用及好处

《Java继承和多态的作用及好处》文章讲解Java继承与多态的概念、语法及应用,继承通过extends复用父类成员,减少冗余;多态实现方法重写与向上转型,提升灵活性与代码复用性,动态绑定降低圈复杂度... 目录1. 继承1.1 什么是继承1.2 继承的作用和好处1.3 继承的语法1.4 子类访问父类里面的成

SpringBoot 中 CommandLineRunner的作用示例详解

《SpringBoot中CommandLineRunner的作用示例详解》SpringBoot提供的一种简单的实现方案就是添加一个model并实现CommandLineRunner接口,实现功能的... 目录1、CommandLineRunnerSpringBoot中CommandLineRunner的作用

$在R语言中的作用示例小结

《$在R语言中的作用示例小结》在R语言中,$是一个非常重要的操作符,主要用于访问对象的成员或组件,它的用途非常广泛,不仅限于数据框(dataframe),还可以用于列表(list)、环境(enviro... 目录1. 访问数据框(data frame)中的列2. 访问列表(list)中的元素3. 访问jav

Kotlin运算符重载函数及作用场景

《Kotlin运算符重载函数及作用场景》在Kotlin里,运算符重载函数允许为自定义类型重新定义现有的运算符(如+-…)行为,从而让自定义类型能像内置类型那样使用运算符,本文给大家介绍Kotlin运算... 目录基本语法作用场景类对象数据类型接口注意事项在 Kotlin 里,运算符重载函数允许为自定义类型重

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa