云图网络书签收藏分类管理

2024-08-22 15:18

本文主要是介绍云图网络书签收藏分类管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

随着书签越来越多,查找起来费劲,做小网站来管理。下面就详细讲下我在做这个小案例的时候遇到的一些问题以及如何搭建的环境。

项目第一节:数据库设计

数据库设计,设想的方式有三种:范式设计 、 反范式设计 、文本搜索引擎lucen设计。

一.范式设计

考虑数据库设计中,有三张表:

                    网页信息表:id 、 网页名 、网页地址 、网页描述

                    标签表:标签id 、 标签名 、 标签下网页数量

                    多对多关系映射表: 映射表id 、 标签表 id 、 网页信息表id

表结构:


create table website(wid varchar(20) primary key,wname varchar(50),whref varchar(100),wdesc varchar(1000)
);create table tag(tid varchar(20) primary key,tagname varchar(50),tcount int(100)
);create table tagweb(twid varchar(20) primary key,tid varchar(20),wid varchar(20)
);
添加主外键约束:

alter table tagweb add constraint FK_Reference_tw_1 foreign key (tid)references tag (tid) on delete restrict on update restrict;
alter table tagweb add constraint FK_Reference_tw_2 foreign key (wid)references website (wid) on delete restrict on update restrict;


二 、反范式设计

考虑数据库设计中有两张表:

                   网页信息表: id 、 网页名称 、网页地址 、网页描述 、网页标签名称

                   标签表:标签id 、 标签名 、 标签下网页的数量

三 、lucent设计方案(单独开一篇再写这个)

项目第二节:环境搭建

在环境搭建中,采用的是maven来管理项目。本项目打算用spring+mybatis+strus2来完成。因此搭建环境就需要多多注意配置文件等等一系列的问题。


在环境搭建中。主要分为三部分:

                                               1 、由mybatis来处理的数据层

                                               2 、有Struts2来完成整合的web层

                                               3 、以及由spring来充当大管家管理AOP切面等的一些处理部分。


一 、mybatis的配置。

 采用mybatis框架主要分为dao包和mapper层。这之间需要用一个配置文件来进行连接。

首先在dao包中,基本的一些语句例如:

public String getWebsiteInfo(String wid){
String result="";
try {
SqlSession session = MybatisUtils.getSqlSession();
result = session.selectOne("精确到配置mapper中方法id", wid);
} catch (IOException e) {
e.printStackTrace();
}
return result;
}
其中封装了一个取sqlsession的mybatis的帮助类:

/*** mybatis的帮助类*/
public class MybatisUtils {private static SqlSessionFactory factory;/*** 获取联接工厂* @return* @throws IOException*/public static SqlSessionFactory getFactory() {try {System.out.println("----------------------");if(factory==null){String config="mybatis-config.xml";//流的操作(读取)InputStream iis=Resources.getResourceAsStream(config );//使用xml解析   ,  解析出  mybatis-config.xml中的  数据库的配置项  ,创建数据联接池factory= new SqlSessionFactoryBuilder().build(  iis );//二级缓存是共用了SQLSessionFactory}System.out.println(factory);} catch (IOException e) {e.printStackTrace();}return factory;}public static SqlSession getSqlSession() throws IOException{return getFactory().openSession();}public static SqlSession getSqlSession( boolean isAutoCommit) throws IOException{return getFactory().openSession(isAutoCommit);}
}

在mapper中的查询如下:

<mapper namespace="com.cloud.dao.mapper.WebsiteMapper"><!-- 查信息 --><select id="" parameterType=""resultType=""></select>

在dao与mapper之间的连接配置部分如下:

<properties resource="db.properties"></properties><environments default="development"><environment id="development"><!-- 表示事务管理机制: jdbc --><transactionManager type="JDBC" /><dataSource type="POOLED"><property name="driver" value="${driver}" /><property name="url" value="${url}" /><property name="username" value="${username}" /><property name="password" value="${password}" /></dataSource></environment></environments><mappers><mapper resource="com/cloud/dao/mapper/WebsiteMapper.xml" /></mappers>

在此数据层环境就全部搭建完成,其余配置在响应操作时在进行搭建。

这篇关于云图网络书签收藏分类管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1096637

相关文章

Linux网络配置之网桥和虚拟网络的配置指南

《Linux网络配置之网桥和虚拟网络的配置指南》这篇文章主要为大家详细介绍了Linux中配置网桥和虚拟网络的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、网桥的配置在linux系统中配置一个新的网桥主要涉及以下几个步骤:1.为yum仓库做准备,安装组件epel-re

Python对PDF书签进行添加,修改提取和删除操作

《Python对PDF书签进行添加,修改提取和删除操作》PDF书签是PDF文件中的导航工具,通常包含一个标题和一个跳转位置,本教程将详细介绍如何使用Python对PDF文件中的书签进行操作... 目录简介使用工具python 向 PDF 添加书签添加书签添加嵌套书签Python 修改 PDF 书签Pytho

python如何下载网络文件到本地指定文件夹

《python如何下载网络文件到本地指定文件夹》这篇文章主要为大家详细介绍了python如何实现下载网络文件到本地指定文件夹,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下...  在python中下载文件到本地指定文件夹可以通过以下步骤实现,使用requests库处理HTTP请求,并结合o

Linux高并发场景下的网络参数调优实战指南

《Linux高并发场景下的网络参数调优实战指南》在高并发网络服务场景中,Linux内核的默认网络参数往往无法满足需求,导致性能瓶颈、连接超时甚至服务崩溃,本文基于真实案例分析,从参数解读、问题诊断到优... 目录一、问题背景:当并发连接遇上性能瓶颈1.1 案例环境1.2 初始参数分析二、深度诊断:连接状态与

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解