Maison base de données tutoriel mysql SQL Server 应用开发 --- SQL SERVER 2000 数据查询综合实例

SQL Server 应用开发 --- SQL SERVER 2000 数据查询综合实例

Jun 07, 2016 pm 03:09 PM
200 server sql 应用开发

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))

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quelle est la différence entre HQL et SQL dans le framework Hibernate ? Quelle est la différence entre HQL et SQL dans le framework Hibernate ? Apr 17, 2024 pm 02:57 PM

HQL et SQL sont comparés dans le framework Hibernate : HQL (1. Syntaxe orientée objet, 2. Requêtes indépendantes de la base de données, 3. Sécurité des types), tandis que SQL exploite directement la base de données (1. Normes indépendantes de la base de données, 2. Exécutable complexe requêtes et manipulation de données).

Utilisation de l'opération de division dans Oracle SQL Utilisation de l'opération de division dans Oracle SQL Mar 10, 2024 pm 03:06 PM

"Utilisation de l'opération de division dans OracleSQL" Dans OracleSQL, l'opération de division est l'une des opérations mathématiques courantes. Lors de l'interrogation et du traitement des données, les opérations de division peuvent nous aider à calculer le rapport entre les champs ou à dériver la relation logique entre des valeurs spécifiques. Cet article présentera l'utilisation de l'opération de division dans OracleSQL et fournira des exemples de code spécifiques. 1. Deux méthodes d'opérations de division dans OracleSQL Dans OracleSQL, les opérations de division peuvent être effectuées de deux manières différentes.

Comparaison et différences de syntaxe SQL entre Oracle et DB2 Comparaison et différences de syntaxe SQL entre Oracle et DB2 Mar 11, 2024 pm 12:09 PM

Oracle et DB2 sont deux systèmes de gestion de bases de données relationnelles couramment utilisés, chacun possédant sa propre syntaxe et ses propres caractéristiques SQL. Cet article comparera et différera la syntaxe SQL d'Oracle et de DB2, et fournira des exemples de code spécifiques. Connexion à la base de données Dans Oracle, utilisez l'instruction suivante pour vous connecter à la base de données : CONNECTusername/password@database Dans DB2, l'instruction pour vous connecter à la base de données est la suivante : CONNECTTOdataba.

Que signifie l'attribut d'identité dans SQL ? Que signifie l'attribut d'identité dans SQL ? Feb 19, 2024 am 11:24 AM

Qu'est-ce que l'identité en SQL ? Des exemples de code spécifiques sont nécessaires. En SQL, l'identité est un type de données spécial utilisé pour générer des nombres à incrémentation automatique. Il est souvent utilisé pour identifier de manière unique chaque ligne de données dans une table. La colonne Identité est souvent utilisée conjointement avec la colonne clé primaire pour garantir que chaque enregistrement possède un identifiant unique. Cet article détaillera comment utiliser Identity et quelques exemples de code pratiques. La manière de base d'utiliser Identity consiste à utiliser Identit lors de la création d'une table.

Explication détaillée de la fonction Définir la balise dans les balises SQL dynamiques MyBatis Explication détaillée de la fonction Définir la balise dans les balises SQL dynamiques MyBatis Feb 26, 2024 pm 07:48 PM

Interprétation des balises SQL dynamiques MyBatis : explication détaillée de l'utilisation des balises Set MyBatis est un excellent cadre de couche de persistance. Il fournit une multitude de balises SQL dynamiques et peut construire de manière flexible des instructions d'opération de base de données. Parmi elles, la balise Set est utilisée pour générer la clause SET dans l'instruction UPDATE, qui est très couramment utilisée dans les opérations de mise à jour. Cet article expliquera en détail l'utilisation de la balise Set dans MyBatis et démontrera ses fonctionnalités à travers des exemples de code spécifiques. Qu'est-ce que Set tag Set tag est utilisé dans MyBati

Yunshen lance le chien robot phare de l'application industrielle Jueying X30 Yunshen lance le chien robot phare de l'application industrielle Jueying X30 Oct 11, 2023 pm 09:45 PM

Le 9 octobre, Yunshen Technology a lancé le robot à quatre pattes « Jueying X30 ». En tant que nouvelle génération de produits de niveau industriel pour les applications industrielles, il est destiné aux centrales électriques, aux usines, aux inspections de galeries de canalisations, aux secours d'urgence, aux enquêtes sur les incendies et à l'avenir. recherche scientifique, etc. Les demandes fondamentales multi-domaines apportent les capacités industrielles de pointe au monde : capacités de détection intégrées originales, prenant la tête en Asie pour réaliser un franchissement rapide et stable des obstacles dans des environnements changeants, monter et descendre des escaliers industriels creux et une autonomie par tous les temps. inspections de jour comme de nuit, brisant davantage de restrictions de scène. Il peut répondre rapidement à des tâches inattendues ; pour la première fois en Asie, la plage de température de fonctionnement d'un robot quadrupède a été étendue de -20°C à 55°C, élargissant considérablement l'application. zones et saisons ; il dispose de son propre système de surveillance en temps réel et d’un système d’intervention d’urgence pour garantir des opérations plus intelligentes et efficaces. Dix-sept départements, dont le ministère de l'Industrie et des Technologies de l'information, ont publié le « Machine

Comment installer, désinstaller et réinitialiser la sauvegarde du serveur Windows Comment installer, désinstaller et réinitialiser la sauvegarde du serveur Windows Mar 06, 2024 am 10:37 AM

WindowsServerBackup est une fonction fournie avec le système d'exploitation WindowsServer, conçue pour aider les utilisateurs à protéger les données importantes et les configurations système, et à fournir des solutions complètes de sauvegarde et de récupération pour les petites, moyennes et grandes entreprises. Seuls les utilisateurs exécutant Server2022 et versions ultérieures peuvent utiliser cette fonctionnalité. Dans cet article, nous expliquerons comment installer, désinstaller ou réinitialiser WindowsServerBackup. Comment réinitialiser la sauvegarde de Windows Server Si vous rencontrez des problèmes avec la sauvegarde de votre serveur, si la sauvegarde prend trop de temps ou si vous ne parvenez pas à accéder aux fichiers stockés, vous pouvez envisager de réinitialiser vos paramètres de sauvegarde de Windows Server. Pour réinitialiser Windows

Comment résoudre l'erreur 5120 dans SQL Comment résoudre l'erreur 5120 dans SQL Mar 06, 2024 pm 04:33 PM

Solution : 1. Vérifiez si l'utilisateur connecté dispose des autorisations suffisantes pour accéder ou utiliser la base de données, et assurez-vous que l'utilisateur dispose des autorisations appropriées ; 2. Vérifiez si le compte du service SQL Server est autorisé à accéder au fichier spécifié ou ; dossier et assurez-vous que le compte dispose des autorisations suffisantes pour lire et écrire le fichier ou le dossier ; 3. Vérifiez si le fichier de base de données spécifié a été ouvert ou verrouillé par d'autres processus, essayez de fermer ou de libérer le fichier et réexécutez la requête ; . Essayez en tant qu'administrateur, exécutez Management Studio en tant que etc.

See all articles