大可山博客[十年一日, GDI+,WPF, .Net图形图像]

WPF,WinForms,asp.net开发,图形图像处理系统研究 (Johnson Blog) [信奉:凡事靠自己] MSN:a3news(at)hotmail.com http://www.brawdraw.com

用户操作
[即时聊天] [发私信] [加为好友]
大可山(Johnson)ID:johnsuna
424324次访问,排名113好友60人,关注者103
深圳报业集团问工网,技术总监
johnsuna的文章
原创 258 篇
翻译 1 篇
转载 44 篇
评论 467 篇
大可山(Johnson)的公告

MSN:a3news(at)hotmail.com,从2007年8月8日起笔名改为:大可山(以前叫阿山Net)
Q:329325120
[这段时间忙,尽量少问我问题。见谅!]
引用本人原作,请注明出处。
最近评论
chenende61802408:现在很我需要,我正在做一个图书管理系统需要像你做的时钟控件.请发邮箱给我啊.急!谢谢!418966563@qq.com 谢谢啊!
zhtqt:给我发一份,可以吗? 谢谢您了!
zhtqt@qq.com
somboy:额滴神啊~~~给我一份吧。。
示例和下载都不能用了。
ayhncn#163.com
谢谢哦~~~
somboy:额滴神啊~~~给我一份吧。。
示例和下载都不能用了。
ayhncn#163.com
谢谢哦~~~
devas:呵呵,向博主请教一下,在grid中定义了 <Grid.RowDefinitions>
<Grid.ColumnDefinitions>
后, 内部的 Border 就没有效果了.
请问要如何在显式定义 row和column 的情况下,改变grid的形状呢?
文章分类
收藏
相册
Chinaphotoshop.Net
报业大厦外摄
程序截图
美丽的深圳
世界之窗
软件开发
你的灯亮着吗?(RSS)
图书出版
大溪水的博客(RSS)
图形图像
C#新型报表工具 XDesigner(RSS)
存档
软件项目交易
订阅我的博客
XML聚合  FeedSky
订阅到鲜果
订阅到Google
订阅到抓虾
订阅到BlogLines
订阅到Yahoo
订阅到GouGou
订阅到飞鸽
订阅到Rojo
订阅到newsgator
订阅到netvibes

原创 使用一条SQL语句删除表中重复记录收藏

新一篇: 关于WINFORM中输入法的设置 | 旧一篇: 发布一个很COOL的图片验证码程序[含源码]

数据库结构的脚本:
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[TempA]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[TempA]
GO

CREATE TABLE [dbo].[TempA] (
 [id] [int] IDENTITY (1, 1) NOT NULL ,
 [PositionName] [varchar] (256) COLLATE Chinese_PRC_CI_AS NULL ,
 [EnglishPositionName] [varchar] (256) COLLATE Chinese_PRC_CI_AS NULL
) ON [PRIMARY]
GO

ALTER TABLE [dbo].[TempA] ADD
 CONSTRAINT [PK_TempA] PRIMARY KEY  CLUSTERED
 (
  [id]
 )  ON [PRIMARY]
GO

TempA表中有三个字段,id唯一且为主键,自动增长; PositionName,EnglishPositionName中有重复的记录,比如:
id      PositionName        EnglishPositionName
20     其他                           Others
21     质量工程师               QC Engineer
22     其他                           Others
.......
100  质量工程师               QC Engineer
需要剔除重复的"其他","质量工程师"等记录。

采用的SQL语句:
Delete from TempA where id not in (
        select max(t1.id) from TempA t1 group by
         t1.PositionName,t1.EnglishPositionName)

说明:
(1)需要剔除那几个用于判断重复的字段,则将它们放在group by语句之后。
(2)max(t1.id) 也可以改成:min(t1.id)

发表于 @ 2007年06月06日 17:00:00|评论(loading...)|编辑

新一篇: 关于WINFORM中输入法的设置 | 旧一篇: 发布一个很COOL的图片验证码程序[含源码]

评论

#johnsuna 发表于2007-06-27 13:26:45  IP: 58.251.18.*
靠!
居然有人在此做广告!

我发达了,哈哈!:)
#zhangleiDotNet 发表于2007-07-25 11:02:35  IP: 125.47.195.*
为什么要 max(t1.id)呢?我不明白,能讲下吗?
#johnsuna 发表于2007-07-25 11:53:50  IP: 58.251.18.*
取一条记录而已
#issa_0 发表于2007-07-26 13:18:12  IP: 222.88.72.*
参详中
能否告诉小弟那个T1是什么意思,怎么个用法?
直接换成表名不行么???
谢谢!!!
#johnsuna 发表于2007-07-26 14:34:16  IP: 58.251.18.*
首先,t1是别名,为了简洁,另取一个比较好记或易写的名字。
如:select u.TrueName, u.UserName, u.Password, c.CompanyName from User u, Company c where u.CompanyId = c.id
其中,u就是User的别名, c是Company的别名。
如果不取别名就需要这样写SQL语句:
select User.TrueName, User.UserName, User.Password, Company.CompanyName from User, Company where User.CompanyId = Company.id
特别地,当用户表名特别长或SQL语句特别长时,使用别名是比较简洁的。

其次,直接换成表名也可以,比如这样:
Delete from TempA where id not in (select max(TempA.id) from TempA group by TempA.PositionName,TempA.EnglishPositionName)
发表评论  


当前用户设置只有注册用户才能发表评论。如果你没有登录,请点击登录
Csdn Blog version 3.1a
Copyright © 大可山(Johnson)