-
50个常用sql语句网上流行的学生选课表的例子
50个常用sql语句Student(S#,Sname,Sage,Ssex)学生表Course(C#,Cname,T#)课程表SC(S#,C#,score)成绩表Teacher(T#,Tname)教师表问题:1、查询“001”课程比“002”课程成绩高的所有学生的学号;selecta.S#from(selects#,scorefromSCwhereC#='001')a,(selects#,scorefromSCwhereC#='002')bwherea.score>b.scoreanda.s#=b.s#;2、查询平均成绩大于60分的同学的学号和平均成绩;selectS#,avg(score)fromscgroupbyS#havingavg(score)>60;3、查询所有同学的学号、姓名、选课数、总成绩;selectStudent.S#,Student.Sname,count(SC.C#),sum(score)fromStudentleftOuterjoinSConStudent.S#=SC.S#groupbyStudent.S#,Sname4、查询姓“李”的老师的个数;se...
数据库操作教程 2022-09-23 17:13:21 -
PL/SQLDEVELOPER使用的一些技巧
1,登录后默认自动选中MyObjects默认情况下,PLSQLDeveloper登录后,Brower里会选择Allobjects,如果你登录的用户是dba,要展开tables目录,正常情况都需要Wait几秒钟,而选择MyObjects后响应速率则是以毫秒计算的。Tools菜单-->ObjectBrowerFilters,会打开BrowerFolders的定单窗口,把“MyObjects”设为默认即可...
数据库操作教程 2022-09-23 17:13:11 -
通过sql存储过程发送邮件的方法
SQLServer怎样配置发送电子邮件通常大家都知道:SQLServer与MicrosoftExchangeServer集成性很好,关于这方面的配置,在SQLServer的联机帮助里有详细的说明,在此不再赘述。然而我们更关心的问题是:在没有ExchangeServer的情况下,如何配置SQLServer利用Internet邮件服务器发送邮件? 笔者曾为这问题伤透了脑筋,搜遍了互联网上的相关资料,发现仅有的几篇资料中有的是一笔带过,有的虽然介绍了操作步骤,可按照步骤一步一步操作下来,结果总是失败...
数据库操作教程 2022-09-23 17:10:42 -
关于SQL存储过程入门基础(流程控制)
这里我们讲一下存储过程的流程控制,ifelse,case,while,这里没有for循环的,这些跟c,c++,c#等语言都差不过的。一,首先来看if else使用复制代码代码如下:if条件beginsql语句endelsebeginsql语句end看个简单例子复制代码代码如下:declare@idint --声明个变量set@id=5 --设置厨初始值if(@id=1) begin print'right' endelseif(@id=0) begin &nb...
数据库操作教程 2022-09-23 17:10:40 -
Sql学习第一天——SQL将变量定义为Table类型(虚拟表)
SQL将变量定义为Table类型在平时定义sql语句中的变量时通常我们定义的都是像char,varchar,nvarchar,int........,那如何让变量作为一个像虚拟表一样呢,其实很简单。基本语法:复制代码代码如下: declare@ttable(列名1列的数据类型1,列名2列的数据类型2,...............) insertinto@t(列名1,列名2,...............)values(...............)[code]或者[code] insertinto@t(列名1,列名2,...............)(select....from....)实验用表一(PeopleInfo): id name phone XC1 李某 123333333 XC2 小小 785555555例如: 复制代码代码如下: declare@ttable(idnvarchar(3),[name]nvarchar(10))insertinto@t(id,[name])(selectid,[name]fromPeopleInfowher...
数据库操作教程 2022-09-23 17:10:36 -
SQLServer复制需要有实际的服务器名称才能连接到服务器
今天在做sqlServer2005的实验的时候碰到的问题,问题描述很清楚,怀疑是我以前给计算机修改了名称而导致的.可以用select@@servername和selectserverproperty('servername')对照一下,两个的结果是否一样,不一样就会出现问题,以下给出解决的SQL脚本复制代码代码如下:ifserverproperty('servername')<>@@servernamebegindeclare@serversysnameset@server=@@servernameexecsp_dropserver@server=@serverset@server=cast(serverproperty('servername')assysname)execsp_addserver@server=@server,@local='LOCAL'end执行之后,重新sql即可解决这个问题...
数据库操作教程 2022-09-23 17:10:31 -
sqlserverbcp(数据导入导出工具)一般用法与命令详解
bcp是SQLServer中负责导入导出数据的一个命令行工具,它是基于DB-Library的,并且能以并行的方式高效地导入导出大批量的数据。bcp可以将数据库的表或视图直接导出,也能通过SELECTFROM语句对表或视图进行过滤后导出...
数据库操作教程 2022-09-23 17:10:27 -
T-SQL问题解决集锦数据加解密全集
以下代码已经在SQLServer2008上的示例数据库测试通过问题一:如何为数据进行加密与解密,避免使用者窃取机密数据?对于一些敏感数据,如密码、卡号,一般不能使用正常数值来存储。否则会有安全隐患...
数据库操作教程 2022-09-23 17:10:23 -
sqlserver主键设计的注意点
在设计主键的时候往往需要考虑以下几点:1.无意义性:此处无意义是从用户的角度来定义的。这种无意义在一定程度上也会减少数据库的信息冗余...
数据库操作教程 2022-09-23 17:10:16 -
SQLServer设置主键自增长列(使用sql语句实现)
1.新建一数据表,里面有字段id,将id设为为主键复制代码代码如下:createtabletb(idint,constraintpkidprimarykey(id))createtabletb(idintprimarykey)2...
数据库操作教程 2022-09-23 17:10:15 -
SQL行号排序和分页(SQL查询中插入行号自定义分页的另类实现)
(一)行号显示和排序1.SQLServer的行号A.SQL2000使用identity(int,1,1)和临时表,可以显示行号SELECTidentity(int,1,1)ASROWNUM,[DataID]INTO#1FROMDATASorderbyDataID;SELECT*FROM#1B.SQL2005提供一个很好用的函数row_number(),可以直接用来显示行号,当然也可以使用SQL2000的identitySELECTrow_number()over(ORDERBYDataID)ASROWNUM,[DataID]FROMDATAS;这里如果添加排序功能,则先排序再添加行号2.ORACLE的行号显示使用ROWNUMSELECTROWNUM,[DataID]FROMDATASorderbyDataID注意:先加行号再排序,如果想排序好再加行号就要使用子查询3.取前n条数据A.SQL版selecttopn[DataID]fromDATASB.ORACLE版SELECT[DataID]FROMDATASwhereROWNUM<=n其中,n>=1ORACLE的ROWNUM...
数据库操作教程 2022-09-23 17:10:11 -
SQLServer数据库索引其索引的小技巧
一、什么是索引减少磁盘I/O和逻辑读次数的最佳方法之一就是使用【索引】索引允许SQLServer在表中查找数据而不需要扫描整个表。1.1、索引的好处:当表没有聚集索引时,成为【堆或堆表】【堆】是一堆未加工的数据,以行标识符作为指向存储位置的指针...
数据库操作教程 2022-09-23 17:10:11