|
|
|
|
 大家帮我看看这段代码有什么问题? - syncon [ 2005-08-17 18:45 | 1,072 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - limodou [ 2005-08-17 19:03 | 211 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - syncon [ 2005-08-17 19:09 | 152 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - limodou [ 2005-08-17 19:22 | 647 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - syncon [ 2005-08-17 20:25 | 2,342 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - limodou [ 2005-08-17 20:59 | 20 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - syncon [ 2005-08-17 21:53 | 812 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - limodou [ 2005-08-18 08:38 | 232 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - syncon [ 2005-08-18 12:17 | 391 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - syncon [ 2005-08-18 13:05 | 204 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - limodou [ 2005-08-18 21:11 | 706 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - syncon [ 2005-08-18 00:46 | 20 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - syncon [ 2005-08-17 18:55 | 128 byte(s)]
 Re: 大家帮我看看这段代码有什么问题? - limodou [ 2005-08-17 18:54 | 14 byte(s)]
|
|
|
|
[Original]
[Print]
[Top]
|
#! /usr/bin/python
import MySQLdb
import time
conn = MySQLdb.connect (host = "localhost",
user = "root",
passwd = "888888",
db = "test")
cursor = conn.cursor ()
cursor.execute ("SELECT login_name,last_date FROM customer")
rows = cursor.fetchall ()
cursor.execute ("SELECT login_name FROM usergroup")
rows2 = cursor.fetchall ()
if rows2 is None:
for row in rows:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
else:
for row2 in rows2:
for row in rows:
if row[0] != row2[0]:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
cursor.close ()
conn.close ()
|
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
因为你的判断是:
if rows2 is None:
而使用fetchall()返回无记录时应为 [ ]
因此判断不正确。将上面的语句改为:
if not rows2:
试试
|
|
----
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
|
多谢指点,还有个问题,就是执行结果,我的目的是要重customer中查找并写入到usergroup,如果在usergroup中已经有login_name存在,则不插入,可现在的结果不对了!
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
for row2 in rows2:
for row in rows:
if row[0] != row2[0]:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
这段判断有问题。你应该首先对rows进行循环,然后对于每个row判断
是否在rows2中即可,而不是一个个比较。
改为:
for row in rows:
if row not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
另外在选择customer表时可以加上distinct关键字去掉重复值。
|
|
|
----
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
初始状态:
mysql> select * from customer;
+--------+------------+--------------+
| status | last_date | login_name |
+--------+------------+--------------+
| OK | 2006-07-01 | nj0251234567 |
| OK | 2006-05-02 | nj0257654321 |
| OK | 2005-07-24 | njuf201 |
+--------+------------+--------------+
mysql> select * from usergroup;
Empty set (0.00 sec)
代码:
#! /usr/bin/python
import MySQLdb
import time
conn = MySQLdb.connect (host = "localhost",
user = "root",
passwd = "888888",
db = "test")
cursor = conn.cursor ()
cursor.execute ("SELECT login_name,last_date FROM customer")
rows = cursor.fetchall ()
cursor.execute ("SELECT login_name FROM usergroup")
rows2 = cursor.fetchall ()
if not rows2:
for row in rows:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
else:
for row in rows:
if row[0] not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
cursor.close ()
conn.close ()
第一次执行之后:
mysql> select * from usergroup;
+--------------+------+
| login_name | type |
+--------------+------+
| nj0251234567 | YES |
| nj0257654321 | YES |
| njuf201 | YES |
+--------------+------+
3 rows in set (0.00 sec)
如果再执行一次,结果:
mysql> select * from usergroup;
+--------------+------+
| login_name | type |
+--------------+------+
| nj0251234567 | YES |
| nj0257654321 | YES |
| njuf201 | YES |
| nj0251234567 | YES |
| nj0257654321 | YES |
| njuf201 | YES |
+--------------+------+
6 rows in set (0.00 sec)
这就达不到要求了!
|
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
现在的问题是这样:
如果查询语句改成:
cursor.execute ("SELECT login_name FROM customer")
rows = cursor.fetchall ()
cursor.execute ("SELECT login_name FROM usergroup")
rows2 = cursor.fetchall ()
那么用
for row in rows:
if row not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
就可以达到目的。
而我的两条查询语句查询的内容不同:
cursor.execute ("SELECT login_name,last_date FROM customer")
rows = cursor.fetchall ()
cursor.execute ("SELECT login_name FROM usergroup")
rows2 = cursor.fetchall ()
所以就不行了,不知道有什么好的方法?
|
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
那就把for row in rows:改为:
for row, date in rows:
...
后面的照旧。
东西要活学呀。其实你提的问题就是怎么把名字和日期分别取出来。
|
|
----
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
for row,date in rows:
if row not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row)
和
for row in rows:
if row[0] not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
不是一样的嘛,结果还是一样,郁闷...
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
好像这样可以解决:
for row in rows:
if (row[0],) not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
呵呵,我再测试一下
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
这就是你自已的问题了,你的原话:
而我的两条查询语句查询的内容不同:
cursor.execute ("SELECT login_name,last_date FROM customer")
rows = cursor.fetchall ()
cursor.execute ("SELECT login_name FROM usergroup")
rows2 = cursor.fetchall ()
可见rows中的数据,一条记录返回两个元素,rows2一条记录返回一个元素。
所以你这样根本就是反的呀:
好像这样可以解决:
for row in rows:
if (row[0],) not in rows2:
cursor.execute ("INSERT into usergroup values(%s,'YES')",row[0])
呵呵,我再测试一下
而我的写法按你的说明应该是对的。
|
|
|
----
|
|
[Original]
[Print]
[Top]
|
|
|