GaussDB数据库中的同义词SYNONYM

2023-12-30 05:28

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

目录

一、前言

二、GasussDB数据库中的Synonym

1、Synonym的概念

2、语法介绍

3、Synonym的用途

三、Synonym在GaussDB数据库中是如何使用的

1、表的同义词使用(示例)

2、视图的同义词使用(示例)

3、函数的同义词使用(示例)

4、存储过程的同义词使用(示例)

5、在GaussDB数据库中使用同义词时的注意事项

四、小结

一、前言

在GasussDB数据库中,Synonym是一种灵活且强大的工具,用于简化数据库对象的访问和管理。通过Synonym,用户可以创建具有特定名称的别名,以替代复杂的数据库对象名称,从而提高查询效率、方便维护、增强安全性,并扩展数据库的使用范围。

二、GasussDB数据库中的Synonym

1、Synonym的概念

同义词(Synonym)是数据库中的一个对象,它是一个别名,经常用于简化对象访问和提高对象访问的安全性。在GaussDB数据库中,管理员可以为大部分对象,如表、视图、序列、存储过程、包等等,定义同义词。

2、语法介绍

1)创建一个同义词对象。同义词是数据库对象的别名,用于记录与其他数据库对象名间的映射关系,用户可以使用同义词访问关联的数据库对象。

ALTER SYNONYM synonym_name OWNER TO new_owner;

参数说明:

  • synonym_name:待修改的同义词名字,可以带模式名。
  • new_owner: 同义词对象的新所有者。

3、Synonym的用途

  • 简化数据库对象的访问:Synonym可以创建并使用别名来简化对数据库对象的访问,无需每次都输入完整的对象名称,从而减少输入量,提高访问效率。
  • 提高数据库对象访问的安全性:Synonym可以授权不同的用户访问特定的数据库对象,从而限制他们对数据库的访问权限,提高系统的安全性。
  • 扩展数据库的使用范围:Synonym可以在不同的数据库用户之间创建映射关系,使得用户可以在不知道其他数据库中的对象名称和结构的情况下,通过Synonym访问其他数据库中的对象,实现跨数据库的交互。
  • 提高查询效率:Synonym可以减少查询的时间和SQL语句的复杂度。用户可以通过Synonym来访问数据库中的对象,从而避免了在查询时需要使用完整的对象名。
  • 方便维护:Synonym可以提高代码的可读性,并且降低了更改数据库对象名称给程序带来的影响。如果需要更改对象的名称,只需修改Synonym即可,而不需要在代码中进行修改。

总之,Synonym在GasussDB数据库中可以提高数据库对象的访问效率和安全性,扩展数据库的使用范围,方便用户对数据库的访问和管理。

三、Synonym在GaussDB数据库中是如何使用的

GaussDB支持通过同义词访问的数据库对象包括表、视图、函数和存储过程。支持的DML语句包括SELECT、INSERT、UPDATE、DELETE、EXPLAIN、CALL。

1、表的同义词使用(示例)

--创建表omm2.test1
CREATE TABLE omm2.test1
(
id int
,name varchar2(10)
);--创建表的同义词t1
CREATE OR REPLACE SYNONYM t1 FOR omm2.test1;--使用同义词t1。
INSERT INTO t1 VALUES (1, 'zhangsan'), (2, 'lisi');
UPDATE t1 SET t1.name = 'ZhangSan' WHERE t1.id = 1;
UPDATE t1 SET t1.name = 'LiSi' WHERE t1.id = 2;
SELECT * FROM t1;

执行过程如下:

2、视图的同义词使用(示例)

--创建视图
CREATE VIEW omm2.v_test1 AS SELECT * FROM omm2.test1;--创建同义词v1
CREATE SYNONYM v1 FOR omm2.v_test1;--使用同义词v1。
SELECT * FROM v1;

执行过程如下:

3、函数的同义词使用(示例)

--创建函数根据姓名(参数)获取信息
CREATE OR REPLACE FUNCTION f_test1 (c_name VARCHAR)
RETURNS VOID PACKAGE
LANGUAGE plpgsql
AS $$
DECLARE s_sql TEXT;
BEGIN    s_sql := 'CREATE OR REPLACE VIEW omm2.v_test2 AS SELECT * FROM omm2.test1 where name=''' || c_name || '''' ;EXECUTE s_sql;
END $$;--创建同义词
CREATE OR REPLACE SYNONYM omm2.f1 FOR f_test1;--调用
CALL omm2.f1('ZhangSan'); --查看执行结果
select * from omm2.v_test2;

执行过程如下:

4、存储过程的同义词使用(示例)

--创建存储过程
CREATE OR REPLACE PROCEDURE p_test1(a integer,b varchar2(10))      
SECURITY INVOKER
AS
BEGININSERT INTO omm2.test1 VALUES(a,b);
END;
/--创建同义词
CREATE OR REPLACE SYNONYM omm2.p1 FOR omm2.p_test1;--使用同义词p1,调用存储过程。
CALL omm2.p1(3,'WangWu');SELECT * FROM omm2.test1;

执行过程如下:

5、在GaussDB数据库中使用同义词时的注意事项

FAQ解决思路:

  • 定义同义词的用户成为其所有者。
  • 若指定模式名称,则同义词在指定模式中创建。否则,在当前模式创建。
  • 使用同义词时,用户需要具有对关联对象的相应权限。
  • 不建议对临时表创建同义词。如果需要创建的话,需要指定同义词的目标临时表的模式名,否则无法正常使用改同义词,并且在当前会话结束前执行DROP SYNONYM命令。
  • 删除原对象后,与之关联同义词不会被级联删除,继续访问该同义词会报错,并提示已失效。
  • 不支持针对包含加密列的密态表及基于密态表的视图、函数、存储过程创建同义词。
  • 只有系统管理员有权限修改SYNONYM对象的属主信息。目前仅支持修改属主,且新属主必须具有SYNONYM对象所在模式的CREATE权限。

四、小结

GaussDB的同义词是一种数据库对象,用于为其他数据库对象提供别名。同义词可以简化SQL查询语句,提高可读性和可维护性。同时,同义词还可以实现数据的逻辑隔离和访问控制,提高数据库的安全性。

在GaussDB中,可以使用CREATE SYNONYM语句创建同义词。同义词的定义与被它所引用的对象具有相同的模式(schema)。如果同义词的模式与被引用对象的模式不同,则需要在同义词名称后面加上模式名称进行限定。

需要注意的是,同义词并不实际存储数据,它只是对其他数据库对象的引用。因此,删除同义词并不会删除被引用的对象。同时,同义词也不能跨数据库或实例使用。

更多信息可参考官方文档:

https://support.huaweicloud.com/centralized-devg-v2-gaussdb/devg_03_0574.html

——结束

这篇关于GaussDB数据库中的同义词SYNONYM的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

查看Oracle数据库中UNDO表空间的使用情况(最新推荐)

《查看Oracle数据库中UNDO表空间的使用情况(最新推荐)》Oracle数据库中查看UNDO表空间使用情况的4种方法:DBA_TABLESPACES和DBA_DATA_FILES提供基本信息,V$... 目录1. 通过 DBjavascriptA_TABLESPACES 和 DBA_DATA_FILES

Java实现数据库图片上传与存储功能

《Java实现数据库图片上传与存储功能》在现代的Web开发中,上传图片并将其存储在数据库中是常见的需求之一,本文将介绍如何通过Java实现图片上传,存储到数据库的完整过程,希望对大家有所帮助... 目录1. 项目结构2. 数据库表设计3. 实现图片上传功能3.1 文件上传控制器3.2 图片上传服务4. 实现

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

Java实现数据库图片上传功能详解

《Java实现数据库图片上传功能详解》这篇文章主要为大家详细介绍了如何使用Java实现数据库图片上传功能,包含从数据库拿图片传递前端渲染,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、数据库搭建&nbsChina编程p; 3、后端实现将图片存储进数据库4、后端实现从数据库取出图片给前端5、前端拿到

IDEA连接达梦数据库的详细配置指南

《IDEA连接达梦数据库的详细配置指南》达梦数据库(DMDatabase)作为国产关系型数据库的代表,广泛应用于企业级系统开发,本文将详细介绍如何在IntelliJIDEA中配置并连接达梦数据库,助力... 目录准备工作1. 下载达梦JDBC驱动配置步骤1. 将驱动添加到IDEA2. 创建数据库连接连接参数

Jmeter如何向数据库批量插入数据

《Jmeter如何向数据库批量插入数据》:本文主要介绍Jmeter如何向数据库批量插入数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Jmeter向数据库批量插入数据Jmeter向mysql数据库中插入数据的入门操作接下来做一下各个元件的配置总结Jmete