数据库语句大全!!要举一反三!

2024-02-18 11:48

本文主要是介绍数据库语句大全!!要举一反三!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

                Sunny个人整理!(sunny我的英文名)

 

创建数据库

create database student

on

(name=student_data,

 filename='c:/data/student_data.mdf',

 size=3,

 filegrowth=1,

 )

log on

(name=stu_log,

 filename='c:/../stu_log.ldf',

 size=1,

 maxsize=20,

filegrowth=10%)

--创建数据库,及数据文件和日志文件

 

创建表

create table stu_grade

(stu_id  char(10) not null,

--stu_id  char(10) not null primary key,--其他表直接定义主键]

 

 course_id  char(3)  not null,

 grade  int,

 

 constraint     pk_no1    primary key(stu_id ,course_id),

 constraint  fk_stu_id     foreign key (stu_id ) references stu_info(stu_id ),

 constraint  fk_course_id  foreign key (course_id ) references course_info(course_id ),)

--创建表及主键外键

--修改表

alter table stu——info

add code char(18)

 

alter table stu——info

add constraint RM unique (code)--RM 是约束的名字

 

alter table stu——info

drop constraint RM

 

alter table stu——info

add constraint RM check (grade between 0 and 100)

 

alter table stu——info

drop constraint RM foreign key (course_id ) references course_info(course_id )

--删除表先删除约束

alter table stu_grade

drop constraint fk_stu_id

 

drop table stu_info

 

insert into stu_info

values('20081300408','张山','1988-01-26','f','河南郑州',.......

       '..',' ..', .....

       )

--插入数据

 

update stu_info

set sdept='会计学院'

where stu_id ='20081300408'

--更新表

 

 

delete from stu_info

where sex is null--必须是 is null 而不能是 =null

--删除数据

 

 

数据查询

select ....from  表名

where......

--简单查询

 

select s.stu_id ,name,c.course_name, g.grade

from stu_info s join stu_grade g on s.stu_id=g.stu_id

     join course_info c on c.course_id=g.course_id

--多表查询语句

 

select name from stu_info

where adddress like '%%'

--模糊查询

 

select stu_id, name,sdept from stu_info

where stu_id not in /in (select stu_id from stu_grade where course_id =001)

--查询没有选修001 这门课的学生

 

select avg(mark) from stu_info where sdept='信息学院'--平均成绩

 

select max(mark),min(mark) from stu_info--最大成绩,最小成绩

 

select sdept,sex ,count(*) from stu_info  where sdept='信息学院' and sex=''

group by sdept ,sex--信息学院女生人数

创建索引

create nonclustered index 索引名SY on course_infor (course_name)--非聚焦索引

 

create nonclustered index SY on stu_grade (stu_id,course_id )--创建复合索引

 

drop index stu_grade.SY--删除索引 (表名.索引名)!

 

create unique index SY on course_info(course_name)--修改 sy 为唯一索引

 

sp_helpindex course_info --查看 SY索引 信息

 

创建视图

create view view_name as select ....from.....where..group by..

--创建视图

 

create view view_name

as

select sdept ,count(*) '总人数' from stu_info

where sdept='信息学院'

group by sdept

--创建视图显示信息学院的总人数

 

alter view view_name with encrypion

as

select sdept ,count(*) '总人数' from stu_info

where sdept='信息学院'

group by sdept

--修改为加密视图

 

drop view view_name--删除视图

 

创建存储过程

create procedure pro_name @xh char(10)

as

select count(*) from stu_gread

where grade<60 and stu_id=@xh

--创建存储过程pro_name

 

drop procedure pro_name--删除存储过程

 

pro_name '200707001'--调用存储过程

触发器

create trigger tr1

on stu_info

after delete

as

delete from stu_grade where stu_id=(select stu_id from deleted)

--级联删除

 

create trigger tr2

on stu_info

after update

as

update stu_grade set stu_id=(select stu_id from insered )

where  stu_id=(select stu_id from deleted)

--级联更新

 

select * into xs2 from stu_info where 1=2--创建表xs2作为储存开除学生的表

 

create trigger tr3

on stu_grade

for update ,insert

as

declare @m int

select @m=count(*) from stu_grade

where grade<60 and stu_id =(select stu_id from inserted )

if (@m>4)

insert into xs2 select *  from stu_info

where stu_id =(select stu_id from inserted)

--forafter为后触发器)

 

drop trigger tr3--删除触发器

 

数据库安全

sp_addlogin 'login_name','密码','默认数据库'--创建登录账户

 

sp_droplogin 'login_name'--删除登录账户

 

sp_addrole 'role_name'--创建数据库角色

 

sp_droprole 'role_name'--删除角色

 

backup database stu_info to sale_student--备份数据库

 

restore database stu_info from sale_student--还原数据库

这篇关于数据库语句大全!!要举一反三!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

IDEA如何切换数据库版本mysql5或mysql8

《IDEA如何切换数据库版本mysql5或mysql8》本文介绍了如何将IntelliJIDEA从MySQL5切换到MySQL8的详细步骤,包括下载MySQL8、安装、配置、停止旧服务、启动新服务以及... 目录问题描述解决方案第一步第二步第三步第四步第五步总结问题描述最近想开发一个新应用,想使用mysq

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

Java读取InfluxDB数据库的方法详解

《Java读取InfluxDB数据库的方法详解》本文介绍基于Java语言,读取InfluxDB数据库的方法,包括读取InfluxDB的所有数据库,以及指定数据库中的measurement、field、... 首先,创建一个Java项目,用于撰写代码。接下来,配置所需要的依赖;这里我们就选择可用于与Infl

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

C#实现文件读写到SQLite数据库

《C#实现文件读写到SQLite数据库》这篇文章主要为大家详细介绍了使用C#将文件读写到SQLite数据库的几种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录1. 使用 BLOB 存储文件2. 存储文件路径3. 分块存储文件《文件读写到SQLite数据库China编程的方法》博客中,介绍了文

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

SQL Server数据库磁盘满了的解决办法

《SQLServer数据库磁盘满了的解决办法》系统再正常运行,我还在操作中,突然发现接口报错,后续所有接口都报错了,一查日志发现说是数据库磁盘满了,所以本文记录了SQLServer数据库磁盘满了的解... 目录问题解决方法删除数据库日志设置数据库日志大小问题今http://www.chinasem.cn天发

Oracle数据库执行计划的查看与分析技巧

《Oracle数据库执行计划的查看与分析技巧》在Oracle数据库中,执行计划能够帮助我们深入了解SQL语句在数据库内部的执行细节,进而优化查询性能、提升系统效率,执行计划是Oracle数据库优化器为... 目录一、什么是执行计划二、查看执行计划的方法(一)使用 EXPLAIN PLAN 命令(二)通过 S

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica