Heim Datenbank MySQL-Tutorial sqlserver利用存储过程去除重复行的sql语句

sqlserver利用存储过程去除重复行的sql语句

Jun 07, 2016 pm 06:00 PM
存储过程

以前弄过类似,去除相同信息的方法,现在找不到了,不过今天又花一些时间给弄出来了,记录一下

还是先上代码吧 ,可以先看
代码如下:
ALTER procedure [dbo].[PROC_ITEMMASTER_GETUNIQUE] @PAGEINDEX INT,@uid int,@itemnumber varchar(50)
AS
begin tran --开始事务
drop table [ItemMaster].[dbo].[testim] --删除表
--把不重复记录转存到testim中
select * into [ItemMaster].[dbo].[testim] from [ItemMaster].[dbo].[dat_item_master] where item_uid in(select min(item_uid) as item_uid from [ItemMaster].[dbo].[dat_item_master] group by item_number) and status=0
select top 10 * from [ItemMaster].[dbo].[testim] where item_uid not in (select top (10*(@PAGEINDEX-1)) item_uid from [ItemMaster].[dbo].[testim])
and owneruid=@uid and item_number like @itemnumber+'%'

--判断是否出错
if @@error0
begin
rollback tran --出错则回滚
end
else
begin --否则提前事务
commit tran
end

我的数据是这样的:因为item_uid是标识列,item_number有重复的,

我想过滤成这样:

顺带说几个在编程的时候遇到的小问题

1.程序 出现 Could not find stored procedure 找不到这个存储过程

因为我的程序数据库有四个,而默认连接是A,但实际要执行B库里的存储过程,导致出错,

解决办法1:可在A里面建个一样的存储过程2:在执行连接的时候,替换下数据库就行了

2. asp.net/C# 将存储过程中返回的数据集,填充到dataset/datatable


代码如下:
SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["SolutionSQLServer"].ToString());
SqlCommand cmd = new SqlCommand("Test",conn);
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add("@MaxId", SqlDbType.Int).Value = 12000;

SqlDataAdapter sda = new SqlDataAdapter(cmd);
DataTable dt = new DataTable();
sda.Fill(dt);


在这感谢 http://www.cnblogs.com/liujuncm5/archive/2009/08/31/1557569.html

3.在存储过程里面,写SQL语句不能动态不加order by 功能

比如

代码如下:
--·@new_orderby 是传入参数,不能这样写
select top (10*(2-1)) item_uid from testim order by @new_orderby


--执行这个的时候,SQL会出现 The SELECT item identified by the ORDER BY number 1 contains a variable as part
of the expression identifying a column position. Variables are only allowed when
ordering by an expression referencing a column name.

不过我找到解决办法,不过很麻烦,

(第二个回答用 ' sql '进行连接)

(用case end 也行)

4. select into 和 insert into select 两种复制文句 (这里感谢)

  1.

语句形式为:

  2.

语句形式为:

5.顺便复习下常用的SQL方法语句
代码如下:
declare @name varchar(200) --声明变量
set @name='abcd;def' --赋值
print 'exec len :'+Convert(varchar(10),Len(@name)) --convert(type,value)转换,Len(value)获取大小
print 'exec charindex:'+Convert(varchar(10),CharIndex('e',@name))--CharIndex(find,value) 在value中查找find的位置
print 'not replace:'+@name
print 'exec replace:'+Replace(@name,';','') --用replace替换
print 'exec substring:'+Substring(@name,0,3)--用substring截取
print @@RowCount --返回上一行代码受影响的行数

作者:

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Schritte und Vorsichtsmaßnahmen für die Implementierung von Batch-Updates mithilfe gespeicherter Oracle-Prozeduren Schritte und Vorsichtsmaßnahmen für die Implementierung von Batch-Updates mithilfe gespeicherter Oracle-Prozeduren Mar 08, 2024 pm 04:12 PM

Titel: Schritte und Vorsichtsmaßnahmen für die Implementierung von Stapelaktualisierungen durch gespeicherte Oracle-Prozeduren. In Oracle-Datenbanken handelt es sich bei gespeicherten Prozeduren um eine Reihe von SQL-Anweisungen, die dazu dienen, die Datenbankleistung zu verbessern, Code wiederzuverwenden und die Sicherheit zu erhöhen. Gespeicherte Prozeduren können zum Aktualisieren von Daten in Stapeln verwendet werden. In diesem Artikel wird erläutert, wie gespeicherte Oracle-Prozeduren zum Implementieren von Batch-Updates verwendet werden, und es werden spezifische Codebeispiele bereitgestellt. Schritt 1: Erstellen Sie eine gespeicherte Prozedur. Zuerst müssen wir eine gespeicherte Prozedur erstellen, um Stapelaktualisierungsvorgänge zu implementieren. Im Folgenden erfahren Sie, wie Sie eine gespeicherte Prozedur erstellen

So löschen Sie eine gespeicherte Prozedur in MySQL So löschen Sie eine gespeicherte Prozedur in MySQL Sep 05, 2023 am 10:25 AM

Zu den MySQL-Methoden zum Löschen gespeicherter Prozeduren gehören die Verwendung der DROP PROCEDURE-Anweisung, die Verwendung von MySQL Workbench und die Verwendung von Befehlszeilentools. Detaillierte Einführung: 1. Verwenden Sie die DROP PROCEDURE-Anweisung. Die Schritte bestehen darin, zuerst den MySQL-Client zu öffnen oder ein beliebiges Tool zu verwenden, das MySQL unterstützt, dann eine Verbindung zu Ihrer MySQL-Datenbank herzustellen und schließlich die folgende SQL-Anweisung auszuführen, um die gespeicherte Prozedur zu löschen. Verwenden Sie MySQL Workbench, um gespeicherte Prozeduren usw. zu löschen.

Gespeicherte Oracle-Prozedur: Implementierungsmethode zur Bestimmung, ob eine Tabelle vorhanden ist Gespeicherte Oracle-Prozedur: Implementierungsmethode zur Bestimmung, ob eine Tabelle vorhanden ist Mar 08, 2024 pm 09:18 PM

Gespeicherte Prozeduren in Oracle-Datenbanken sind eine bestimmte Art von gespeicherten Prozeduren, die zum Ausführen einer Reihe von SQL-Anweisungen und Datenoperationen in der Datenbank verwendet werden. Bei der tatsächlichen Datenbankentwicklung müssen wir manchmal feststellen, ob eine bestimmte Tabelle in der Datenbank vorhanden ist, damit wir im gespeicherten Prozess eine gewisse Beurteilung und logische Verarbeitung vornehmen können. Im Folgenden stellen wir vor, wie Sie die Methode zur Bestimmung, ob eine Tabelle in der Oracle-Datenbank vorhanden ist, implementieren und stellen spezifische Codebeispiele bereit. Erstens können wir die Systemtabelle user_tables oder all_t verwenden

Implementierungsprinzipien und Anwendungen gespeicherter Golang-Prozeduren Implementierungsprinzipien und Anwendungen gespeicherter Golang-Prozeduren Feb 22, 2024 pm 04:57 PM

Implementierungsprinzipien und Anwendungen gespeicherter Golang-Prozeduren Eine gespeicherte Prozedur ist ein vorkompiliertes Programm, das in einer relationalen Datenbank gespeichert ist und von einer Anwendung aufgerufen werden kann. Sie kann die Kosten für die Netzwerkübertragung von Daten effektiv senken und die Ausführungseffizienz der Datenbank verbessern. Obwohl Golang gespeicherte Prozeduren nicht direkt unterstützt, können Sie die Funktionen gespeicherter Prozeduren mithilfe von SQL-Anweisungen simulieren. In diesem Artikel werden die Prinzipien und Anwendungen der Implementierung gespeicherter Prozeduren in Golang vorgestellt und spezifische Codebeispiele bereitgestellt. 1. Das Implementierungsprinzip der gespeicherten Golang-Prozedur ist in Gol

Detaillierter Vergleich und Vorteilsanalyse von gespeicherten Oracle-Prozeduren und -Funktionen Detaillierter Vergleich und Vorteilsanalyse von gespeicherten Oracle-Prozeduren und -Funktionen Mar 03, 2024 am 10:24 AM

Titel: Detaillierter Vergleich und Vorteilsanalyse von gespeicherten Oracle-Prozeduren und -Funktionen. In Oracle-Datenbanken sind gespeicherte Prozeduren und Funktionen zwei wichtige Datenbankobjekte. Sie können zur Kapselung einer Reihe von SQL-Anweisungen und Logik verwendet werden, um die Effizienz und Komplexität von Daten zu verbessern Benutzerfreundlichkeit. In diesem Artikel werden die Eigenschaften der gespeicherten Oracle-Prozeduren und -Funktionen sowie ihre jeweiligen Vorteile im Detail verglichen und spezifische Codebeispiele bereitgestellt. Gespeicherte Prozedur Eine gespeicherte Prozedur ist eine Reihe von SQL-Anweisungen und PL/SQL-Codelogik, die vorab geschrieben und in der Datenbank gespeichert werden.

Leistungsoptimierungsstrategie für Oracle Stored Procedure Batch Update Leistungsoptimierungsstrategie für Oracle Stored Procedure Batch Update Mar 08, 2024 pm 09:36 PM

Strategien zur Leistungsoptimierung für Stapelaktualisierungen von gespeicherten Oracle-Prozeduren In Oracle-Datenbanken ist eine gespeicherte Prozedur ein Datenbankobjekt, das zum Verarbeiten von Datenlogik oder zum Ausführen bestimmter Aufgaben verwendet wird. Sie kann bestimmte Strategien zur Leistungsoptimierung bereitstellen, insbesondere bei der Aktualisierung von Daten in Stapeln. Das Aktualisieren von Daten in Stapeln erfordert normalerweise eine große Anzahl von Vorgängen auf Zeilenebene. Um die Leistung und Effizienz zu verbessern, können wir einige Strategien und Techniken anwenden, um die Leistung gespeicherter Prozeduren zu optimieren. Im Folgenden werden einige Strategien zur Leistungsoptimierung für Stapelaktualisierungen gespeicherter Oracle-Prozeduren vorgestellt und spezifische Codebeispiele bereitgestellt.

So schreiben Sie effiziente gespeicherte Prozeduren mit Golang So schreiben Sie effiziente gespeicherte Prozeduren mit Golang Mar 22, 2023 pm 02:24 PM

Golang ist eine leistungsstarke Programmiersprache, die gespeicherte Prozeduren einfach implementieren kann. In diesem Artikel stellen wir vor, wie Sie mit Golang effiziente gespeicherte Prozeduren schreiben und welche Vorteile ihre Verwendung in Ihren Projekten bietet.

Schreiben Sie einfach zu wartende gespeicherte Golang-Prozeduren Schreiben Sie einfach zu wartende gespeicherte Golang-Prozeduren Feb 24, 2024 pm 08:27 PM

So schreiben Sie wartbare gespeicherte Prozeduren in Golang Wenn Sie in Golang wartbare gespeicherte Prozeduren schreiben möchten, müssen Sie zunächst das Konzept gespeicherter Prozeduren verstehen und wissen, wie Sie diese in Golang implementieren. Eine gespeicherte Prozedur ist ein wiederverwendbarer Codeblock, der in einer Datenbank gespeichert ist und eine Reihe von SQL-Anweisungen enthält. Gespeicherte Prozeduren vereinfachen den Code, verbessern die Leistung und kapseln die Geschäftslogik. In diesem Artikel wird erläutert, wie wartbare gespeicherte Prozeduren in Golang geschrieben werden, und es werden spezifische Codebeispiele bereitgestellt. 1. Stellen Sie zunächst eine Verbindung zur Datenbank her

See all articles