这种绑定暂时支持单表,并且不支持主键自增长!保存,删除,查看,修改用框架现成的。

  1、先生成tb、bll、dal三个类。框架有生成工具,在debug文件里面有个叫CSFramework.Tools.ClassGenerator的应用程序。

tb类不需要修改什么,如下图:

数据库如果连接不成功,在debug文件里有个连接数据库的工具先连接一下。

  按照图中这样设置好之后,点击生成类。一种是静态类,一种是实体类。区别在于保存的时候有一段代码不一样。一般生成静态类就可以了。

复制生成的类名作为保存文件的名字。

bll图:

点击生成基础数据BLL代码

dal图:

  

2、把生成的文件放到对应的项目文件里面:

tb文件放到CSFramework3.Models里面

bll文件放到CSFramework3.Business里面

dal文件放到CSFramework3.Server.DataAccess里面
3、创建实现数据库接口的方法类。找到CSFramework3.Interfaces这个项目。创建一个类似  IBridge_demo 这样的接口类。里面创建几个方法。当然接口可以共用。

  如果业务需求一样,只是数据不一样就可以共用接口。只要创建实现接口类指向不同的查询类就可以了。我这里就创建新接口了。如果出现红色波浪线,右键看看是不是缺少引用。

代码例子:

public interface IBridge_demo
{
//模糊查询测试数据
DataTable SearchBy(string CustomerFrom, string CustomerTo, string Name, string Attribute);

//类别获取查询数据
DataTable GetCustomerByAttributeCodes(string attributeCodes, bool nameWithCode);

//模糊查询
DataTable FuzzySearch(string content);

//模糊查询
DataTable FuzzySearch(string attributeCodes, string content);
}

4、然后打开生成的BLL文件,加入这句代码:

public class blltest : bllBaseDataDict
{
private IBridge_Test _MyBridge; //桥接/策略接口

  注销这句//_DAL = new daldemo(Loginer.CurrentUser);//数据层的实例

换成

_DataDictBridge = BridgeFactory.CreateDataDictBridge(typeof(tb_demo));//由ORM自动查询DAL类
_MyBridge = this.CreateBridge();

加完引用还有报错暂时别管,因为这个时候还没有实现接口的方法。选择我们去实现接口的方法。

5、找到CSFramework3.Bridge这个项目,创建一个实现之前接口的实现类。(这次是创建类不是接口、窗口)类似  demo_IBridge 这样的类。

为了减少操作直接替换下面的引用:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using CSFramework3.Interfaces;
using CSFramework.Core;
using CSFramework.Common;
using System.Data;
using System.ServiceModel;
using CSFramework3.WebServiceReference;
using CSFramework3.Server.DataAccess.DAL_DataDict;
using CSFramework3.WebServiceReference.WCF_DataDictService;
using CSFramework3.Interfaces.Interfaces_Bridge;
using CSFramework3.Server.DataAccess;

//引用下面所有代码:

namespace CSFramework3.Bridge.DataDictModule
{
public class demo_IBridge
{
//数据层实例,实现桥接口IBridge_Document
private IBridge_demo _DAL_Demo = null;
//构造器
public ADODirect_demo()
{
_DAL_Demo = new daldemo(Loginer.CurrentUser);
}

//获取桥接功能实例
public IBridge_demo GetInstance()
{
return _DAL_Demo;
}
}
/// <summary>
/// 测试管理WebService桥接功能
/// </summary>
public class WebService_Demo : IBridge_demo
{

public WebService_Demo()
{
}

#region IBridge_demo 成员

public DataTable SearchBy(string CustomerFrom, string CustomerTo, string Name, string Attribute)
{
using (DataDictServiceClient client = SoapClientFactory.CreateDataDictClient())
{
byte[] loginTicket = WebServiceSecurity.EncryptLoginer(Loginer.CurrentUser);
byte[] receivedData = client.FuzzySearchCustomer(loginTicket, CustomerFrom, CustomerTo, Name, Attribute);
return ZipTools.DecompressionDataSet(receivedData).Tables[0];
}
}

public DataTable GetCustomerByAttributeCodes(string attributeCodes, bool nameWithCode)
{
using (DataDictServiceClient client = SoapClientFactory.CreateDataDictClient())
{
byte[] loginTicket = WebServiceSecurity.EncryptLoginer(Loginer.CurrentUser);
byte[] receivedData = client.GetCustomerByAttributeCodes(loginTicket, attributeCodes, nameWithCode);
return ZipTools.DecompressionDataSet(receivedData).Tables[0];
}
}

public DataTable FuzzySearch(string content)
{
using (DataDictServiceClient client = SoapClientFactory.CreateDataDictClient())
{
byte[] loginTicket = WebServiceSecurity.EncryptLoginer(Loginer.CurrentUser);
byte[] receivedData = client.FuzzySearchCustomerByContent(loginTicket, content);
return ZipTools.DecompressionDataSet(receivedData).Tables[0];
}
}

public DataTable FuzzySearch(string attributeCodes, string content)
{
using (DataDictServiceClient client = SoapClientFactory.CreateDataDictClient())
{
byte[] loginTicket = WebServiceSecurity.EncryptLoginer(Loginer.CurrentUser);
byte[] receivedData = client.FuzzySearchCustomerByAttributes(loginTicket, attributeCodes, content);
return ZipTools.DecompressionDataSet(receivedData).Tables[0];
}
}

#endregion
}
}

正常情况下代码中红色部分会报错,因为指向的dal类中还没有实现它的方法。下面我们去dal中实现它的方法。

6、找到CSFramework3.Server.DataAccess这个项目中的daldemo这个类打开,报错的地方右键添加引用。

在类中的这个地方加入红色代码:

//a、

[DefaultORM_UpdateMode(typeof(tb_demo), true)]
public class daldemo : dalBaseDataDict, IBridge_demo
{

//b、

return new GenerateSqlCmdByTableFields(ORM);
}
public DataTable SearchBy(string CustomerFrom, string CustomerTo, string Name, string Attribute)
{
StringBuilder sb = new StringBuilder();
sb.Append("SELECT * FROM demo WHERE name LIKE '%" + CustomerFrom + "%'");
sb.Append(" ORDER BY ID;");
SqlCommandBase cmd = SqlBuilder.BuildSqlCommandBase(sb.ToString());
return DataProvider.Instance.GetTable(_Loginer.DBName, cmd.SqlCommand, tb_demo.__TableName);
}
public DataTable GetCustomerByAttributeCodes(string attributeCodes, bool nameWithCode)
{
throw new NotImplementedException();
}
public DataTable FuzzySearch(string content)
{
throw new NotImplementedException();
}
public DataTable FuzzySearch(string attributeCodes, string content)
{
throw new NotImplementedException();
}

可以联系QQ:78474580 一起研究

关于C/S框架网单表绑定,查询的更多相关文章

  1. Django框架之单表操作

    一.添加表记录 对于单表有两种方式 # 添加数据的两种方式 # 方式一:实例化对象就是一条表记录 Frank_obj = models.Student(name ="海东",cou ...

  2. python 之 Django框架(orm单表查询、orm多表查询、聚合查询、分组查询、F查询、 Q查询、事务、Django ORM执行原生SQL)

    12.329 orm单表查询 import os if __name__ == '__main__': # 指定当前py脚本需要加载的Django项目配置信息 os.environ.setdefaul ...

  3. Ajax省市区无刷新单表联动查询

    方法一: 在很多时候都需要用到无刷新级联查询,本文将以省市区的级联查询作为例子.注:此为单表三级联动 环境:Vistual Studio 2015 .MSSQL 1.首先下载AjaxControlTo ...

  4. MySQL--详细查询操作(单表记录查询、多表记录查询(连表查询)、子查询)

    一.单表查询 1.完整的语法顺序(可以不写完整,其次顺序要对) (不分组,且当前表使用聚合函数: 当前表为一组,显示统计结果 ) select distinct [*,查询字段1,查询字段2,表达式, ...

  5. MR案例:单表关联查询

    "单表关联"这个实例要求从给出的数据中寻找所关心的数据,它是对原始数据所包含信息的挖掘. 需求:实例中给出 child-parent(孩子—父母)表,要求输出 grandchild ...

  6. python开发mysql:表关系&单表简单查询

    一 一对多,多对一 1.1 建立多对一 ,一对多的关系需要注意 先建立被关联的表,被关联的字段必须保证时唯一的 在创建关联的表,关联的字段一定是可以重复的 1.2 示例: 出版社 多对一,多个老师可能 ...

  7. MySQL单表数据查询(DQL)

    数据准备工作: CREATE TABLE student( sid INT PRIMARY KEY AUTO_INCREMENT, sname ), age TINYINT, city ), scor ...

  8. 前端框架VUE----表单输入绑定

    vue的核心:声明式的指令和数据的双向绑定. 那么声明式的指令,已经给大家介绍完了.接下来我们来研究一下什么是数据的双向绑定? 另外,大家一定要知道vue的设计模式:MVVM M是Model的简写,V ...

  9. Django框架ORM单表删除表记录_模型层

    此方法依赖的表是之前创建的过的一张表 参考链接:https://www.cnblogs.com/apollo1616/p/9840354.html 1.删除方法就是delete(),它运行时立即删除对 ...

随机推荐

  1. 序列化和Json

    实现了python与python程序之间内存的交互 常用场景: 1 把内存的数据写到磁盘 2 socket只能传字符串,二进制,通过序列化 ============================== ...

  2. 爬虫_vs_反爬虫

    爬虫中有哪些专业术语? 爬虫:自动获取网站数据的程序,关键是批量的获取 反爬虫:使用技术手段防止爬虫程序的方法 误伤:反爬虫技术将普通用户识别为爬虫,效果再好也不能用(禁止ip) 成本:反爬虫需要人力 ...

  3. 摘-BMC自动化解决方案产品概览

    以下内容摘自BMC解决方案白皮书 BMC 解决方案助力您的企业快速享受自动化带来的快速效益,并随时间推移实现这些优势的最大化. BMC 自动化技术可帮助您优化敏捷性,同时保持必要的治理和合规性控制.无 ...

  4. JAVA中获取文件MD5值的四种方法

    JAVA中获取文件MD5值的四种方法其实都很类似,因为核心都是通过JAVA自带的MessageDigest类来实现.获取文件MD5值主要分为三个步骤,第一步获取文件的byte信息,第二步通过Messa ...

  5. Hibernate (一)

    1 JDBC的优缺点 优点: 直接底层操作,提供了简单.便捷的访问数据库的方法,跨平台比较强. 灵活性比较强,可以写复杂的SQL. 缺点: JDBC没有做到面向对象的编程,使得程序员的思考还停留在SQ ...

  6. shell第二篇

    第二篇知道shell是什么,再来了解一下shell的分类及相关历史 参考百度百科:shell 1.shell概念(计算机壳层) 在计算机科学中,Shell俗称壳(用来区别于核),是指"提供使 ...

  7. 【转】5 Best Place to Learn Linux – Linux Tutorial Sites

    Linux have amazed every tech guy and make them curious to hands on Linux. Many of us not feel Linux ...

  8. typedef和#define的简单比较

    1.通常说typedef比#define要好,尤其在有指针的情况下 typedef char* pStr1; #define pStr2 char* pStr1 s1,s2; pStr2 s3,s4; ...

  9. Linux 下定时备份数据库以及删除缓存

    一.定时备份数据库 1.在根目录下创建备份文件夹 #mkdir backup 2.进入到该目录下,创建backup.sh文件 3.赋予文件权限让其变成可执行文件 4.在backup.sh中写备份的脚本 ...

  10. Oracle 12cR1 RAC 在VMware Workstation上安装(下)—静默安装

    Oracle 12cR1 RAC 在VMware Workstation上安装(下)—静默安装 1.1  静默安装 1.1.1  静默安装grid 安装之前使用脚本进行校验,确保所有的failed选项 ...