SQL Server 应用开发 --- SQL SERVER 2000 数据查询综合实例
SQL SERVER 2000 数据 查询 综合 实例 实例 1:更新用户卡信息 1、描述: 某公司印了一批充值卡,卡的密码是随机生成的,现在出现这个问题:卡里的"O"和"0","i"和"1",用户反映说看不清楚,公司决定,把存储在 数据 库中的密码中所有的"O"都改成"0",把所有
SQL SERVER 2000 数据查询综合实例
实例1:更新用户卡信息
1、描述:
某公司印了一批充值卡,卡的密码是随机生成的,现在出现这个问题:卡里的"O"和"0","i"和"1",用户反映说看不清楚,公司决定,把存储在数据库中的密码中所有的"O"都改成"0",把所有的"i"都改成"1"。
2、实现:
declare @Card table ([password] varchar(8)) -- 创建数据表
insert into @Card
select 'abcdefgh' union
select 'ijklmnop' union
select 'qrstuvwx'
select * from @Card
update @Card set [password] = replace(replace([password],'o','0'),'i','1')
select * from @Card
go
实例2:特殊排序
1、描述:
在数据库表中有以下字符数据,如: 13-1、13-2、13-3、13-4、13-100、13-108、13-18、13-11、13-15、14-1、14-2, 现在希望通过SQL语句进行排序,并道德要按前半部份数字进行排序,然后再按后半部分的数字进行排序,输出要排成这样: 13-1、13-2、13-3、13-10、13-11、13-15、13-18、13-100、13-108、14-1、14-2
2、实现:
declare @SellRecord table (listNumber varchar(10)) -- 创建数据表
insert into @SellRecord
select '13-1' union
select '13-2' union
select '13-3' union
select '13-4' union
select '13-100' union
select '13-108' union
select '13-18' union
select '13-11' union
select '13-15' union
select '14-1' union
select '14-2'
select * from @SellRecord
select * from @SellRecord order by convert(int,left(listNumber,charindex('-',listNumber)-1)),convert(int,stuff(listNumber,1,charindex('-',listNumber),' '))
实例3:查询一张表中的奇数行和偶数行
1、描述:
某单位中要根据奇数行和偶数行的数据来汇总,并在这个汇总的基础上再得到一个数值
2、实现:
-- 创建数据表
use pubs
go
if exists (select * from sysobjects where name = 'tbl') drop table tbl
go
create table tbl
(
idKey int identity(1,1) not null,
a int
)
go
insert into tbl (a) values (1)
insert into tbl (a) values (2)
insert into tbl (a) values (3)
insert into tbl (a) values (4)
insert into tbl (a) values (5)
delete from tbl where idKey = 2
go
select * from tbl
go
-- 进行查询
select identity(int,1,1) as [id], a
into tempTbl
from tbl
go
select * from tempTbl
select sum(a) from tempTbl where [id]%2 != 0
select sum(a) from tempTbl where [id]%2 = 0
go
实例4:银行卡恢复
1、描述: 一家银行发行了新的信用卡,刚开始的时候推广很好。但是逐渐地废卡越来越多,卡上的余额少于2元,并且用户长时间不使用该卡,因此银行在二月份把这些少于2元的卡的用户信息备份后就都从数据库表中删除了,但是很快问题就来了,用户发现他的卡再也不能使用而投拆,因此只能再把这些卡恢复。
2、实现:
use pubs
go
if exists (select * from sysobjects where name = 'S') drop table S
go
if exists (select * from sysobjects where name = 'M') drop table M
go
create table M
(
CardID int primary key not null,
UserName varchar(20) not null
)
go
create table S
(
CountID int identity(1,1) primary key, -- 帐户ID
CardID int foreign key references M (CardID), -- 卡号
Score float -- 余额
)
go
insert into M (CardID,UserName) values (16,'张三')
insert into M (CardID,UserName) values (23,'李四')
insert into M (CardID,UserName) values (25,'王五')
insert into M (CardID,UserName) values (29,'刘六')
insert into M (CardID,UserName) values (30,'杨七')
insert into S (CardID,Score) values (16,34.5)
insert into S (CardID,Score) values (25,300)
insert into S (CardID,Score) values (29,1.5)
go
select * from M
select * from S
go
-- 恢复
insert into S (CardID,Score) select M.CardID,2 from M left join S on M.CardID = S.CardID where S.CardID is null
go
select * from S
go
实例5:
1、描述:
有如下二个表,将其中的数据进行合并,并按照学号进行分组,求出总分与平均分
2、实现:
-- 创建数据表
use pubs
go
if exists (select * from sysobjects where name = 'A') drop table A
go
if exists (select * from sysobjects where name = 'B') drop table B
go
create table A -- 数学成绩表
(
[id] int primary key,
score int
)
go
create table B -- 语言成绩表
(
[id] int primary key,
score int
)
go
insert into A values (16,66)
insert into A values (23,56)
insert into A values (25,67)
insert into A values (29,45)
insert into B values (23,80)
insert into B values (25,90)
insert into B values (29,59)
insert into B values (30,84)
go
select * from A
select * from B
go
-- 建立一个临时表并数据进行合并,并进行相关操作
if exists (select * from sysobjects where name = 'C') drop table C
go
create table C -- 数学成绩表
(
[id] int,
score int
)
go
insert into C (id,score)
select A.id, A.score from A union
select B.id, B.score from B
go
select id as 学号, sum(score) as 总分, avg(score) as 平均分 from C group by id
go
实例6:
1、描述:
有表ABC,其中有字段A、B和C,并且都是字符数据,其中A列存储了从A到Z之间的单个字母,查询出A列中字符在A到P之间的所有数据行
2、实现:
-- 创建数据表
use pubs
go
if exists (select * from sysobjects where name = 'ABC') drop table ABC
go
create table ABC ( id varchar(1) )
go
-- 以5个字符为例
insert into ABC values ('A')
insert into ABC values ('B')
insert into ABC values ('C')
insert into ABC values ('D')
insert into ABC values ('E')
go
select * from ABC where id between 'A' and 'C'
go
实例7:
1、描述:
有学生成绩表,数据如下,查询出每门课都大于80分的学生姓名
2、实现:
-- 创建数据表
use pubs
go
if exists (select * from sysobjects where name = 'tb') drop table tb
go
create table tb ( stuName varchar(20), course varchar(20), score int )
go
insert into tb values ('张千','语文',80)
insert into tb values ('张千','数学',77)
insert into tb values ('李万','语文',66)
insert into tb values ('李万','数学',91)
insert into tb values ('王亿','语文',84)
insert into tb values ('王亿','数学',100)
insert into tb values ('王亿','英语',90)
insert into tb values ('杨兆','英语',86)
insert into tb values ('杨兆','数学',93)
go
select * from tb
go
-- 查询数据
select stuName from tb group by stuName having min(score) >= 80
go
实例8:
1、描述:
合并用户表,有3个表GameWOW,GameDiablo,GameStarCraft结构如下,将这三个表中的数据合并到新表Game中,新表结构如下,对于新表中存在而源表中不存在的记录,用NULL表示
2、实现:
use pubs
go
if exists (select * from sysobjects where name = 'GameWOW') drop table GameWOW
go
if exists (select * from sysobjects where name = 'GameDiablo') drop table GameDiablo
go
if exists (select * from sysobjects where name = 'GameStarCraft') drop table GameStarCraft
go
if exists (select * from sysobjects where name = 'Game') drop table Game
go
create table GameWOW
(
SName varchar(10),
SPassWord varchar(10),
SBirthday smalldatetime,
SAddress varchar(10),
SEmail varchar(10)
)
go
insert into GameWOW values ('wow','wow',getdate(),'wow','wow')
go
create table GameDiablo
(
SName varchar(10),
SPassWord varchar(10),
SBirthday smalldatetime,
SSex bit,
SCardNumber varchar(10)
)
go
insert into GameDiablo values ('diablo','diablo',getdate(),1,'diablo')
go
create table GameStarCraft
(
SName varchar(10),
SPassWord varchar(10),
SBirthday smalldatetime,
SArea varchar(10),
SCode int
)
go
insert into GameStarCraft values ('starcraft','starcraft',getdate(),'starcraft',1)
go
create table Game
(
SName varchar(10),
SPassWord varchar(10),
SBirthday smalldatetime,
SAddress varchar(10),
SEmail varchar(10),
SSex bit,
SCardNumber varchar(10),
SArea varchar(10),
SCode int
)
go
-- 合并
insert into Game (SName,SPassWord,SBirthday,SAddress,SEmail,SSex,SCardNumber,SArea,SCode)
select SName,SPassWord,SBirthday,SAddress,SEmail,null,null,null,null
from GameWOW union
select SName,SPassWord,SBirthday,null,null,SSex,SCardNumber,null,null
from GameDiablo union
select SName,SPassWord,SBirthday,null,null,null,null,SArea,SCode
from GameStarCraft
go
select * from Game
实例9:
1、描述:
在论坛中采用一定的格式为主帖进行编号,格式为:版块编号_当前日期_四位随机数字
2、实现:
select 主贴编号 = '版块编号_' + convert(varchar(4),datepart(yyyy,getdate())) +
convert(varchar(2),datepart(mm,datepart(mm,getdate()))) +
convert(varchar(2),datepart(dd,datepart(dd,getdate()))) +
convert(varchar(4),right(rand(datepart(ms,getdate())*1000),4))

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

HQL和SQL在Hibernate框架中进行比较:HQL(1.面向对象语法,2.数据库无关的查询,3.类型安全),而SQL直接操作数据库(1.与数据库无关的标准,2.可执行复杂查询和数据操作)。

Oracle和DB2是两个常用的关系型数据库管理系统,它们都有自己独特的SQL语法和特点。本文将针对Oracle和DB2的SQL语法进行比较与区别,并提供具体的代码示例。数据库连接在Oracle中,使用以下语句连接数据库:CONNECTusername/password@database而在DB2中,连接数据库的语句如下:CONNECTTOdataba

《OracleSQL中除法运算的用法》在OracleSQL中,除法运算是常见的数学运算之一。在数据查询和处理过程中,除法运算可以帮助我们计算字段之间的比例或者得出特定数值的逻辑关系。本文将介绍OracleSQL中除法运算的用法,并提供具体的代码示例。一、OracleSQL中除法运算的两种方式在OracleSQL中,除法运算可以使用两种不同的方式进行

MyBatis动态SQL标签解读:Set标签用法详解MyBatis是一个优秀的持久层框架,它提供了丰富的动态SQL标签,可以灵活地构建数据库操作语句。其中,Set标签是用于生成UPDATE语句中SET子句的标签,在更新操作中非常常用。本文将详细解读MyBatis中Set标签的用法,以及通过具体的代码示例来演示其功能。什么是Set标签Set标签用于MyBati

SQL中的Identity是什么,需要具体代码示例在SQL中,Identity是一种用于生成自增数字的特殊数据类型,它常用于唯一标识表中的每一行数据。Identity列通常与主键列配合使用,可以确保每条记录都有一个独一无二的标识符。本文将详细介绍Identity的使用方式以及一些实际的代码示例。Identity的基本使用方式在创建表时,可以使用Identit

WindowsServerBackup是WindowsServer操作系统自带的一个功能,旨在帮助用户保护重要数据和系统配置,并为中小型和企业级企业提供完整的备份和恢复解决方案。只有运行Server2022及更高版本的用户才能使用这一功能。在本文中,我们将介绍如何安装、卸载或重置WindowsServerBackup。如何重置Windows服务器备份如果您的服务器备份遇到问题,备份所需时间过长,或无法访问已存储的文件,那么您可以考虑重新设置WindowsServer备份设置。要重置Windows

解决办法:1、检查登录用户是否具有足够的权限来访问或操作该数据库,确保该用户具有正确的权限;2、检查SQL Server服务的帐户是否具有访问指定文件或文件夹的权限,确保该帐户具有足够的权限来读取和写入该文件或文件夹;3、检查指定的数据库文件是否已被其他进程打开或锁定,尝试关闭或释放该文件,并重新运行查询;4、尝试以管理员身份运行Management Studio等等。

数据库技术大比拼:Oracle和SQL的区别有哪些?在数据库领域中,Oracle和SQLServer是两种备受推崇的关系型数据库管理系统。尽管它们都属于关系型数据库的范畴,但两者之间存在着诸多不同之处。在本文中,我们将深入探讨Oracle和SQLServer之间的区别,以及它们在实际应用中的特点和优势。首先,Oracle和SQLServer在语法方面存
