[vox-tech] A complicated SQL question
Ken Bloom
kbloom at gmail.com
Thu Nov 9 14:25:32 PST 2006
On Thu, Nov 09, 2006 at 12:49:25PM -0800, Richard S. Crawford wrote:
> I have a number of rows in my database which look something like this:
>
>
> id | username | canonicalname | password
> ---+----------+---------------+-----------------------
> 01 | asmith | ART SMITH | md5 encrypted password
> 02 | asmith1 | ART SMITH | <NULL>
> 03 | bjones | BILL JONES | md5 encrypted password
> 04 | bjones12 | BILL JONES | <NULL>
> ---+----------+---------------+-----------------------
>
>
> There are something like 275 entries like these. I'm having a hell of a time
> finding a way to select rows like 02 and 04, where canonicalname is a
> duplicate of the same value in another row and the password is blank, and
> then deleting those rows. After executing my query, the table should look
> like this:
>
>
> id | username | canonicalname | password
> ---+----------+---------------+-----------------------
> 01 | asmith | ART SMITH | md5 encrypted password
> 03 | bjones | BILL JONES | md5 encrypted password
> ---+----------+---------------+-----------------------
>
>
> Is there a simple way to execute a single select query which would pull up all
> the rows I need?
Not in MySQL. It takes 2 (well technically 3) SQL statements;
create temporary table todelete
select a.id as id from THETABLE a, THETABLE b where
a.username=b.username AND a.canonicalname=b.canoncialname and
a.password is null and b.password is not null;
delete from THETABLE using todelete, THETABLE where
todelete.id=THETABLE.id;
drop temporary table todelete;
Maybe other DB's are more intelligent about self-joins in deletes, in
which case you can probably figure out how to combine all 3 of these
based on what I've posted.
--Ken
--
Ken Bloom. PhD candidate. Linguistic Cognition Laboratory.
Department of Computer Science. Illinois Institute of Technology.
http://www.iit.edu/~kbloom1/
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 189 bytes
Desc: Digital signature
Url : http://lists.lugod.org/pipermail/vox-tech/attachments/20061109/80e19776/attachment.pgp
More information about the vox-tech
mailing list