DBMNG数据库管理与应用

书籍是全世界的营养品。生活里没有书籍,就好像没有阳光;智慧里没有书籍,就好像鸟儿没有翅膀。
当前位置:首页 > PostgreSQL > 应用案例

PostgreSQL数据库创建多字段表以及插入多行数据

  今天开始记录做毕设遇到的一些问题,毕设做一个C/S架构的音乐播放器,主要特点是实现音乐推荐功能,前段时间做了一点了,从今天开始记。

  今天的小任务是创建一个数据库表musicdata,记录用户对音乐的打分,作为推荐系统计算的数据来源。

  表是这样的:

userid song1 song2 ......
user1      
user2      
...      

  以前没有用过像样的数据库,只在学习Python时用过sqlite,关系数据库目前同学中貌似用Mysql的比较多,图书馆资料也比较多,Google一下据说PostgreSQL比MySQL更好,就用这个吧。

  毕业设计不要做的多好,暂定系统里有1000首音乐,于是这个表要有1001个字段,看起来静态语言SQL命令是不太合适,由于以前没接触过动态SQL语句,一看就头大,找了一个小时也没找到合适的资料。用Python写个脚本,生成部分静态SQL命令,再放到大象的鼻子(PgAdminⅢ)里,一个1001个字段的表就建成了。

  Python代码:

1 file=open(rD:\hello.txt,w) 2 for i in range(1000): 3 s=song+str(i+1)+ float,+\n 4  file.write(s) 5 file.close()

  这个脚本很简单,但是Python就是拿来帮我们简单的完成一些简单的任务,比如这个毕业设计,哈哈。

  第一个问题解决了,第二个问题就是插入数据了。表中一个用户占一行,userid是key,后面对应的是该user_i对song_j的打分。毕设嘛,简单点,先弄1000个用户,只要insert1000下就好,这有点麻烦。一查,可以COPY,从文本文档中将数据copy到数据表里。现在问题就是用Python把数据存到txt里。

  这里数据用随机数表示吧,还没找真实数据。

 1 import random  2  3 def blankReplace(a):  4 s=str(a)[1:-1]  5 while(s.find( )!=-1):  6 s=s.replace( ,‘‘)  7 return s  8  9 file=open(rE:\rand_data.txt,w) 10 for j in range(1000): 11 data=[random.randint(0,3) for i in range(1000)] 12 strdata=blankReplace(data) 13 file.write(user+str(j+1)+,+strdata+\n) 14 file.close()

  这样数据就跑到rand_data.txt里去了,只要使用SQL COPY语句就可以把数据COPY到表里去。

1 COPY musicdata FROM E:\rand_data.txt DELIMITER ,;

  PostgreSQL据说是个极好的关系型数据库,但是用在像我毕业设计这种小问题上的时候我感觉不是特别方便,尤其是动态SQL语句实在是麻烦。在查资料的时候我粗略看了一下最近有点火的NoSQL,我觉得基于Key-Value的数据结构可以很好的应用在我的问题上,于是我决定做完毕设之后要学习一种NoSQL,Redis或者MongoDB吧。

  今天的任务就是这些,看上去相当简单,但是在过程中还是有些收获的。至少我更爱Python了一点,还有我决定暑假学习NoSQL。

本站文章内容,部分来自于互联网,若侵犯了您的权益,请致邮件chuanghui423#sohu.com(请将#换为@)联系,我们会尽快核实后删除。
Copyright © 2006-2023 DBMNG.COM All Rights Reserved. Powered by DEVSOARTECH            豫ICP备11002312号-2

豫公网安备 41010502002439号