欢迎投稿

今日深度:

使用Python创建MySQL数据库实现字段动态增加以及动

使用Python创建MySQL数据库实现字段动态增加以及动态的插入数据,pythonmysql


应用场景:

我们需要设计一个数据库来保存多个文档中每个文档的关键字。假如我们每个文档字符都超过了1000,取其中出现频率最大的为我们的关键字。

假设每个文档的关键字都超过了300,每一个文件的0-299号存储的是我们的关键字。那我们要建这样一个数据库,手动输入这样的一个表是不现实的,我们只有通过程序来帮我实现这个重复枯燥的操作。


具体的示意图如下所示:

首先图1是我们的原始表格:

        

                                         图1

这个时候我们需要程序来帮我们完成自动字段的创建和数据的插入。

                  

                                                 图2

上图是我们整个表的概况。下面我们就用程序来总结出这样的一个表格是怎么实现的。

'''
function description : Add the fields and data dynamicly.

data : 2014-08-04

author : Chicho

running : python addfileds.py

'''

import MySQLdb
#connect the database
#the argvs based on the database you set.
#Generally speaking, you should change the No. of the port 3306 , because it's easy to be  attack
#localhost = 127.0.0.1
conn = MySQLdb.connect(host = 'localhost', port = 3306, user = 'root', passwd = '*****')
curs = conn.cursor()

# create a database named addtest
#Ensure the program can run multiple times,we should use try...exception
try:
    curs.execute('create database addtest')
except:
    print 'Database addtest exists!'

conn.select_db('addtest')

# create a table named addfields
try:
    curs.execute('create table addfields(id int PRIMARY KEY NOT NULL,name text)')
except:
    print('The table addfields exists!')


# add the fileds
try:
    for i in range(1):
        sql = "alter table addfields add key%s text" %i
        curs.execute(sql)
except Exception,e:
    print e


for i in range(4): #insert 5 lines
    sql = "insert into addfields set id=%s" %i
    curs.execute(sql)
    sql = "update addfields set name = 'hello%s' where id= %s"%(i,i)
    curs.execute(sql)
    for j in range(5):
        sql = "update addfields set key%s = 'world%s%s' where id=%s"%(j,i,j,i)
        curs.execute(sql)

#this is very important
conn.commit()
curs.close()
conn.close()

    

记住最后一定要记得最后三行这个语句,否则你的操作不会写入到数据库中。

最后就可以得到我们的结果,如下图所示:


程序的大体实现就是这样。



参考文献:

http://www.cnblogs.com/rollenholt/archive/2012/05/29/2524327.html

http://www.blogjava.net/alpha/archive/2007/07/23/131912.html

http://database.51cto.com/art/200811/97974_all.htm

感谢楼上几位博主的无私奉献精神,博主是在没有MySQL 的基础上参照这些blog实现的。如有什么地方不足欢迎提出

批评和建议。对你的意见我在此表示由衷的感谢。



彩蛋:

1.操作数据库出现的一些错误总结

如果你长时间为队数据库进行操作,再次进行操作的时候可能会出现以下错误:

    raise errorclass, errorvalue
OperationalError: (2006, 'MySQL server has gone away')

这个时候对于MySQL server 你要做的就是执行一下下面这个命令

connect your_database

对于在python中的IDLE你需要执行:

conn = MySQLdb.connect(host = 'localhost', port = 3306, user = 'root', passwd = '****')
curs = conn.cursor()
conn.select_db('addtest')
密码输入你自己数据库中设置的。


2UnicodeEncodeError: 'latin-1' codec can't encode characters in position 

出现上述这个错误的时候可以采用下面这个方法就可以解决。
 conn.set_character_set('utf8')
    curs.execute('set names utf8')
    curs.execute('SET CHARACTER SET utf8;')
    curs.execute('SET character_set_connection=utf8;')
conn,curs和本文中参数设置是一样的。







Python连接MySQL创建数据库创建表插入数据在程序里面也可以查询出来插入的数据,但是在数据库里表为空

因为你插入数据没有commit、在程序里面也可以查询出来插入的数据是从缓存中查的。
 

mysql数据库设置了一个id字段是自增的,但是插入数据时还是要手动插入id,不插入id就会出错

成功的执行例子如下,仅供参考.

mysql> CREATE TABLE test_create_tab2 (
-> id INT AUTO_INCREMENT,
-> val VARCHAR(10),
-> PRIMARY KEY (id)
-> );
Query OK, 0 rows affected (0.09 sec)

mysql> INSERT INTO test_create_tab2(val) VALUES ('NO id');
Query OK, 1 row affected (0.03 sec)

mysql> select last_insert_id() as id;
+----+
| id |
+----+
| 1 |
+----+
1 row in set (0.00 sec)

mysql> INSERT INTO test_create_tab2(val) VALUES ('NO id 2');
Query OK, 1 row affected (0.03 sec)

mysql> select last_insert_id() as id;
+----+
| id |
+----+
| 2 |
+----+
1 row in set (0.00 sec)

mysql> select * from test_create_tab2;
+----+---------+
| id | val |
+----+---------+
| 1 | NO id |
| 2 | NO id 2 |
+----+---------+
2 rows in set (0.00 sec)
 

www.htsjk.Com true http://www.htsjk.com/shujukunews/2590.html NewsArticle 使用Python创建MySQL数据库实现字段动态增加以及动态的插入数据,pythonmysql 应用场景: 我们需要设计一个数据库来保存多个文档中每个文档的关键字。假如我们每个文档字符都超过了...
评论暂时关闭