1.SqlHelper文件
复制上一个实验的SqlHelper文件,更改命名空间为lesson3
2.创建数据实体类category、contentinfo
属性名与对应表中的字段相对应
从表中查询的数据使用该类对象进行存储
3.加载分类到树形
根据父id查询子类别
- 传入pid
- 根据pid在category表中查询对应的子类的tid,tname
- 实例化category对象model将获取的数据赋值给model,添加到集合list并返回
//根据指定的父Id查询当前的子类别
private List<Category> GetDataByParentId(int pid)
加载类别信息到treeview
- 通过循环加载list中的数据
- 添加节点,节点名为TName
- 递归继续调用上一个方法通过Tid查询下一级子类并且加载到tree
//加载类别信息到TreeView
private void LoadCategory(List<Category> listRoot, TreeNodeCollection treeNodeCollection)
在form1中显示
- 以pid为-1查询结果创建集合listroot
- 通过loadcategory方法加载数据
private void Form1_Load(object sender, EventArgs e)
4.加载文章名称
根据类别id查询对应文章标题
- 传入cateid
- 根据cateid在conteninfo表中查询对应文章的did,dname
- 实例化contentinfo对象model存储数据
private List<ContentInfo> GetContentInfoByCategoryId(int cateId)
选中时展示到listbox
- 进行清空操作
- 通过tag获取当前选中项的tid
- 通过tid调用getconteninfo方法获取集合list
- 循环集合list显示在listbox中,显示为DName
private void treeView1_AfterSelect(object sender, TreeViewEventArgs e)
5.显示文章内容
获取数据
private string GetContentByDid(int did)
双击内容显示
- 添加双击事件
- 根据选中项的Did,调用getcontent方法获取文章内容
- 通过selectitem将选中项转换为conteninfo类对象获取did
- 将获取的内容显示在textbox中
private void listBox1_MouseDoubleClick(object sender, MouseEventArgs e)