我把区号数据库提前装载放到字典里, key=区号 value=城市名,这样做的好处是按区号查城市只要在内存里查就行了,不用每次都去数据库里查。 但这个表就只有两个字段,如果是字段多的数据库,比如有城市、区号、车牌号、邮编等字段,那应该怎么装载这个数据表呢?又该怎么样查询?
1
wwqgtxx 2016-12-31 16:53:52 +08:00 via iPhone
你可以研究一下 mongodb
|
2
bdbai 2016-12-31 16:53:54 +08:00 via Android
哈希表
|
5
wwqgtxx 2016-12-31 17:20:24 +08:00 via iPhone
@omg21 mongodb 算是近似于传统数据库和 nosql 的,他大量的使用内存映射,所以读取数据能接近于内存数据库的速度(前提是内存足够大,否则会被交换到 swap )。另外他的数据结构极度类似于 json ,而且可以对每一个 key (包括嵌套 dict )进行检索和修改
|
6
ihuotui 2016-12-31 17:50:03 +08:00
用缓存啊。。。。
|
7
phrack 2016-12-31 18:10:47 +08:00 via Android
这个数据量好像不大啊。。。直接放内存里呗。。。
|
9
zhg595105376 2016-12-31 19:00:22 +08:00
直接读数据库,常用查询放缓存,如 redis , key=查询条件, value=查询结果(可以保存为 jsonString )
|
10
Ouyangan 2016-12-31 20:27:25 +08:00
其实我想说,换个角度思考一下, 放数据库不是最正确的选择吗? 这种不经常更新的数据,加上索引会慢? 要是递归查询很慢,那好啊 , 前面加一层 redis/内存做缓存 .
多说一句,不要盲目的过早优化! |
11
loading 2016-12-31 20:31:36 +08:00 via Android
如果你习惯用 sql 数据库,试下 sqlite ,有内存模式。
|
13
Miy4mori 2016-12-31 21:54:26 +08:00 via Android
用 linq 吧
|
14
billlee 2016-12-31 22:23:36 +08:00
你想自己手动实现一个数据库吗?不要盲目做负优化
|