视图,存储过程

2024-09-03 18:32
文章标签 过程 存储 视图

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

视图:view

它也是一类数据库对象,其信息保存到sysobjects表中。格式为v。

这种对象和表息息相关的,它是完全依赖于表的,不能独立存在

视图是指从不同角度看表,所得到的信息。

视图在操作时相当于一个指针(其实内部实现就是用指针来实现的),来指向表的不同列。通过一个表可以创建无数视图对象,

在实际程序开发中,会大量使用视图。因为表只有一张(因为表复制的情况是很少的),但可以根据不同的需要,根据不同的角度得到多个视图。

在使用视图时,对于一张表而生成的视图,无论操作哪个视图,都是操作的同一张表。

一个视图的创建,就是一个select查询语句的创建;

--创建一个student表的视图,用来观察全表

if exists(select name from sysobjects  where name='v_student'

   and  xtype='v')

drop view v_student

go

create view v_student

as

select * from student

go

视图创建之后的应用:

从理论上说,增删改查都可以通过视图操作,操作视图就是操作表

在创建视图时,给列名重命名:

if exists(select name from sysobjects  where name='v_student'

   and  xtype='v')

drop view v_student

go

create view v_student

as

select sid as 学号,sname 姓名

from student

go

给数据库对象命名(以表中列重命名为例):sp_rename

对表jobs重命名:

execute sp_rename 'jobs','工作表'

go

此时要获取表信息,需要使用:

select * from [工作表]

go

修改表的中的列名称

execute sp_rename '工作表.job_id','编号','column'

go

给数据库重命名:sp_renamedb (自己测试)

查找pubs.dbo.jobs中的第4到第6行记录:

select * from jobs

where job_id between 4 and 6

go

不包含行号列的数据

select  au_id,au_lname,au_fname,phone,address,city,state,zip,contract

from

(select row_number() over(order by  au_id)  as rowid,*

from authors) as temp

where

rowid between  4 and 6

go

sql语言通常都会提供存储过程的技术,mysql,sqlserver,oracle中,存储过程都是一个重要技术,作为一个程序开发人员,在数据库方面都是必须要掌握的。

在sqlserver中,它是一种特殊类型的函数

用函数的角度来看Sqlserver中的存储过程,它的功能还要大于java中的方法。同样,从函数的角度来看,它可有可无参数,可有可无返回值。

sqlserver中的存储过程分为系统存储过程和用户存储过程。

系统存储过程以sp_xp_打头;

sp system procedure

xp:  xtends procedure

用户定义的存储过程

它也是一类数据库对象,信息保存在系统对象表SysobjectS中,格式为p

一个简单的存储过程的创建,功能是显示表item表的信息。

if exists(select name from sysobjects  where name='show_item'

   and  xtype='p')

drop procedure show_item

go

create procedure show_item

as

begin

   select * from item

end

go

存储过程的调用,使用可执行关键字:execute

execute show_item

go

继续深化上面的存储过程,传递一个表名作参数,用来显示表信息。

if exists(select name from sysobjects  where name='show'

   and  xtype='p')

drop procedure show

go

create procedure show @tbname  nvarchar(30)

as

begin

   declare  @str nvarchar(200);

   set  @str='select * from '+@tbname

   execute  (@str)

end

go

执行存储过程show:

execute show sales

go

这篇关于视图,存储过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

python运用requests模拟浏览器发送请求过程

《python运用requests模拟浏览器发送请求过程》模拟浏览器请求可选用requests处理静态内容,selenium应对动态页面,playwright支持高级自动化,设置代理和超时参数,根据需... 目录使用requests库模拟浏览器请求使用selenium自动化浏览器操作使用playwright

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

java内存泄漏排查过程及解决

《java内存泄漏排查过程及解决》公司某服务内存持续增长,疑似内存泄漏,未触发OOM,排查方法包括检查JVM配置、分析GC执行状态、导出堆内存快照并用IDEAProfiler工具定位大对象及代码... 目录内存泄漏内存问题排查1.查看JVM内存配置2.分析gc是否正常执行3.导出 dump 各种工具分析4.

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

SpringBoot3.X 整合 MinIO 存储原生方案

《SpringBoot3.X整合MinIO存储原生方案》本文详细介绍了SpringBoot3.X整合MinIO的原生方案,从环境搭建到核心功能实现,涵盖了文件上传、下载、删除等常用操作,并补充了... 目录SpringBoot3.X整合MinIO存储原生方案:从环境搭建到实战开发一、前言:为什么选择MinI

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于