查询
SubSonic2.1版本 – 例出3种查询。
Product product = new Select().From<Product>()
.Where(Product.ProductIDColumn).IsEqualTo()
.ExecuteSingle<Product>();
Product product = DB.Select().From<Product>()
.Where("ProductID").IsEqualTo()
.ExecuteSingle<Product>();
Query query = new Query(Product.Schema);
query.WHERE("ProductID=4").ORDER_BY("ProductID asc");
IDataReader dr = Product.FetchByQuery(query);
DataSet product = new Query(Product.Schema).WHERE("ProductID=4").
ORDER_BY("Prod uctID asc").ExecuteDataSet(); 关联查询
DataSet product = new Select(
Product.ProductNameColumn,
Category.CategoryNameColumn
).From<Product>()
.InnerJoin(Category.CategoryIDColumn, Product.CategoryIDColumn)
.Where(Category.CategoryIDColumn).IsGreaterThan()
.ExecuteDataSet();
注意. InnerJoin(f2, f1) 的使用方法。
分页查询
List<Product> products = new Select().From<Product>()
.Where(Product.ProductIDColumn).IsEqualTo()
.Paged(, )
.ExecuteTypedList<Product>();
分组
SubSonic.SqlQuery query = DB.Select(Aggregate.GroupBy("CompanyName"))
.From("Customers")
.LeftOuterJoin("Orders"); 查询—返回对象
ExecuteReader(); 返回DataReader
ExecuteScalar(); 返回对象
ExecuteScalar<string>(); 返回泛型对象
ExecuteSingle<Product>(); 返回表实体对象
ExecuteTypedList<Product>(); 返回泛型表实休数据集
ExecuteDataSet(); 返回DataSet
ExecuteJoinedDataSet<强数型数据集>(); 返回关联查询 DataSet
Execute(); 返回执行后,数据更新条数 SQL关键词
IsEqualTo(obj) // 等于 value
IsBetweenAnd(obj1, obj2) // [字段1] BETWEEN 值1 AND 值2
StartsWith // LIEK '1%‘
EndsWith // LIEK '%1‘
IsGreaterThan // [字段1] > 值1
IsGreaterThanOrEqualToIsGreaterThan // [字段1] >= 值1
IsLessThan // [字段1] < 值1
IsLessThanOrEqualToIsLessThan // [字段1] <= 值1
WhereExpression / AndExpression // Expression 表示括号
C#:
.Where("").IsGreaterThan()
.And("").IsGreaterThanOrEqualTo()
.AndExpression("").IsLessThan()
.AndExpression("").IsLessThanOrEqualTo().And("").StartsWith("")
.AndExpression("").EndsWith("")
.ExecuteSingle<Product>();
SQL:WHERE > @1AND >= @ AND ( < @) AND ( <= @ AND LIKE @) AND ( LIKE @) 修改
Product product = new Product();
product.ProductName = "amo";
product.Save();
int i = new Update(Product.Schema)
.Set(Product.ProductNameColumn).EqualTo("Chai -- Amo")
.Where(Product.ProductIdColumn).IsEqualTo()
.Execute(); 添加
Product product = new Product();
product.ProductName = "my xiaoli";
product.SupplierID = ;
product.CategoryID = ;
product.Discontinued = true;
//............
product.Save();
int i = new Insert().Into(Product.Schema,
"ProductName",
"SupplierID",
"CategoryID",
"Discontinued“
)
.Values("my amo", , , ).Execute(); 删除
int i = new Delete ().From<Product>()
.Where(Product.ProductIDColumn). IsEqualTo()
.Execute();
//删除
Query qr = EaiSmsCustom.Query().AddWhere("age", ).AddWhere("name", );
qr.QueryType = QueryType.Delete;
qr.Execute(); 事务1
List<Insert> queries = new List<Insert>();
queries.Add(new Insert().Into(Product.Schema).Values("product1"));
queries.Add(new Insert().Into(Product.Schema).Values("product2"));
queries.Add(new Insert().Into(Product.Schema).Values("product3"));
queries.Add(new Insert().Into(Product.Schema).Values("product4"));
queries.Add(new Insert().Into(Product.Schema).Values("product5"));
queries.Add(new Insert().Into(Product.Schema).Values("product6"));
queries.Add(new Insert().Into(Product.Schema).Values("product7"));
//execute in a transaction
SqlQuery.ExecuteTransaction(queries);
事务2
using (SharedDbConnectionScope sp = new SharedDbConnectionScope())
{
using (TransactionScope scope = new TransactionScope())
{
// coding....
scope.Complete();
}
} 减少对ActiveRecord的依赖
MyProduct product = new Select(
Product.ProductNameColumn,
Category.CategoryNameColumn
).From<Product>()
.InnerJoin(Category.CategoryIDColumn, Product.CategoryIDColumn)
.Where(Category.CategoryIDColumn).IsGreaterThan()
.ExecuteSingle<MyProduct>();
string cname = product.CategoryName;
string pname = product.ProductName; 自定义MyProduct实体类
public class MyProduct : ActiveRecord<MyProduct> {
public string CategoryName {
get { return GetColumnValue<string>(Category.Columns.CategoryName); }
set { SetColumnValue(Category.Columns.CategoryName, value); }
}
public string ProductName {
get { return GetColumnValue<string>(Product.Columns.ProductName); }
set { SetColumnValue(Product.Columns.ProductName, value); }
}
} string str=DB.Select(EaiService.NameColumn).Top("").From<EaiService>.Where(EaiService.NameColumn).IsEquealTo(name).ExecuteScalar<string>(); string str = DB.Select(Aggregate.Count(EaiUserMap.ApplicationColumn, "Count")).From<EaiUserMap>().ExecuteScalar<string>(); EaiService es = DB.Select().From<EaiService>()
.Where(EaiService.ApplicationColumn).IsEqualTo(title)
.ExecuteSingle<EaiService>();
if (es != null)
{
bt = es.ServiceNameS.ToString();
} //删除
Query qr = EaiSmsCustom.Query().AddWhere("age", ).AddWhere("name", );
qr.QueryType = QueryType.Delete;
qr.Execute(); 存储过程调用
以下是利用SubSonic2.0使用该存储过程的代码:
-----------------------------------代码开始------------------------------------
public static int GetRUID(string tblName)
{
StoredProcedure spd = new StoredProcedure("GenerateRUID");
spd.Command.AddParameter("@tblName", tblName);
spd.Command.AddOutputParameter("@currentnumber");
spd.Execute();
int currentnumber = int.Parse(spd.OutputValues[].ToString());
return currentnumber;
}
Subsonic的使用之基本语法、操作()
新增、修改:
Subsonic中的新增和修改可以共享一个方法(InsertOrUpdate):
user.InsertOrUpdate(); //其中user是传入的用户实体
return user.Fid;
当然它们也有自己独立的方法:
² 新增:
notice.Save();//其中notice是传入的公告实体
return NoticeId = notice.Fid;
² 修改
int i = new Update(CyReceiver.Schema)
.Set(CyReceiver.FStateColumn).EqualTo()
.Where(CyReceiver.FNoticeIDColumn).IsEqualTo(noticeId)
.And(CyReceiver.FUserIDColumn).IsEqualTo(userId).Execute();
删除:
DB.Delete().From(CyUser.Schema).Where(CyUser.FidColumn).IsEqualTo(id).Execute();
SQL关键词:
Select、Delete、Insert、Update、Form、Where这些和SQL一样的就不解释了
IsEqualTo:where条件中的“等于”
如:Where(CyReceiver.FNoticeIDColumn).IsEqualTo(noticeId)
IsNotEqualTo: where条件中的“不等于”
EqualTo:set语句中的“等于” 如: Set(CyReceiver.FStateColumn).EqualTo()
IsGreaterThan :where中的“大于”
IsGreaterThanOrEqualTo:大于等于
IsLessThan:where中的“小于”
IsLessThan OrEqualTo:小于等于
IsBetweenAnd:区间
如:Where(CyNotice.FBeginDateTimeColumn).IsBetweenAnd(beginDate, endDate)
OrderAsc:按某字段升序排序 如:OrderAsc(CyUser.Columns.FUsersSort)
OrderDesc: 按某字段降序序排序
And:逻辑中的“且”
Or: 逻辑中的“或”
Like:模糊查询关键词
如:And(CyNotice.FTitleColumn).Like("%" + model.Title + "%")
更常用的是:title=string.Format("%{0}%", model.Title);
And(CyNotice.FTitleColumn).Like(title);
LeftOuterJoin:左外连接 (当然还有RightOuterJoin、Joins、LeftInnerJoin等等)
如:From(CyNotice.Schema)
.LeftOuterJoin(CyUser.FidColumn, CyNotice.FUserIDColumn)
简单的Update使用save方法 没有用到update:
Product product =new Product("Id",);
product.Name="Eason";
product.save();
复杂一点的,就要用到 Update :
Update product= new Update(product.Schema.TableName);
product.From(product.Schema.TableName);
product.Where(product.Columns.id).Like();
product.And(product.Columns.Name).Like(“Eason”);
product.Set(product.Columns.Name).EqualTo(“Hanson Eason”);
product.Execute();

Subsonic的使用之基本语法、操作(2)的更多相关文章

  1. HiSql 实现case语法操作 新一代无实体ORM框架

    HiSql 实现case语法操作 在SqlServer,Oralce,Hana,PostGreSql,MySql 这些数据都支持SQL case语法,平常在实现业务开发中也会常用到,那么HiSql对于 ...

  2. mysql常用语法操作

    一.用户管理: 1.新建用户: >CREATE USER name IDENTIFIED BY 'ssapdrow'; 2.更改密码: >SET PASSWORD FOR name=PAS ...

  3. 关于SQL2005备份和还原的语法操作

    原数据库:restore database 练习版 from disk='D:\db-recovery\@@@.BAK' WITH REPLACE/WITH NORECOVERY备份数据库:backu ...

  4. 【其他-小技巧-Uipath】VB语法操作DataTable分组并求和

    需要对DataTable分组求和的语法:VB.net 和C#中还有点不太一样.最后试了好多方法,要这么写 我的dataTabel数据: (From p In dataTabel.AsEnumerabl ...

  5. 2017年9月19日 JavaScript语法操作

    关于JavaScript个人还是觉得比较有意思的 {在</html>后面写或者在</body>前面写(必须紧贴</body>)} <script> va ...

  6. OC:属性、点语法、KVC

    //属性的属性 属性定义在一个 .h文件里,在这个.h文件里可以定义实例变量(就是这个类的特征),也可以通过   @protery(属性约束关键字) 属性名字类型 属性名 来定义一些属性,在prope ...

  7. C文件操作之写入字符串到指定文件并在屏幕显示

  8. 超出区域文字显示为省略号或者剪切效果——CSS的生僻操作

    每门语言总有那么一些不太常用,却又不可或缺的语法操作.下面说一下,在HTML文件中,如何设置用 "省略号" 和 "剪切" 代替大量文字的效果. 以下是HTML的 ...

  9. js导读,js引入,js选择器,事件,操作页面文档,计算后样式,数据类型

    js导读 ''' js属于编写运行在浏览器上的脚本语言 js采用ECMAScript语法 操作BOM:浏览器对象模型 eg:浏览器上下滑动,浏览器历史记录 操作DOM:文档对象模型 ''' js引入 ...

随机推荐

  1. Linux 内核数据结构:双向链表

    Linux 内核提供一套双向链表的实现,你可以在 include/linux/list.h 中找到.我们以双向链表着手开始介绍 Linux 内核中的数据结构 ,因为这个是在 Linux 内核中使用最为 ...

  2. <<< commons-fileupload 和 ajaxfileupload 实现局部上传

    最近弄了一个上传,要求实现页面的局部刷新,Java的上传组件大多还是用的 commons-fileupload,网上搜索了好多的教程,太麻烦了,看到了ajaxfileupload这个插件,不错,实现简 ...

  3. 10月28日下午MySQL数据库的增加、删除、查询(匹配数据库登录和可以增、删、查的显示数据库内容的页面))

    一.匹配数据库登录 步骤: 1.做一个普通的登录界面,注意提交方式为post. <!--登录界面--> <form action="chuli.php" meth ...

  4. echarts统计图使用

    网址:http://echarts.baidu.com  提示:不需要导入Jquery.js 使用: 1.导入js,echarts.js 2.创建容器 <!-- 为ECharts准备一个具备大小 ...

  5. 数据库大数据处理---复制(SQLServer)

    复制? 复制起初并不是用于作为高可用性功能而设计的,实际上复制的概念就像其名称一样,用于复制数据.比如将某个库中的数据“复制”到另一个库,到另一个实例中,由OLTP复制到OLAP环境中,由某数据中心复 ...

  6. socket编程热身程序

    /*server.c*/ #include <stdio.h> #include <arpa/inet.h> #include <sys/types.h> /* S ...

  7. UIScrollView和delegate的通信

    在OC中,发送消息的意思就是调用方法 因此UIScrollView和delegate的通信可以理解为下图所示 再精确一点,UIScrollView和delegate的通信应该为下图所示 可以看出,要想 ...

  8. Total Commander 集成、调用 Beyond Compare比较文件

    1.打开wincmd.ini文件 2.在[Configuration]节下加入 Comparetool=d:\Program Files\小工具\Beyond Compare 3\BCompare.e ...

  9. Spring面试题

    69道Spring面试题和答案 原文地址    译者:深海(1422207401@qq.com)  校对:方腾飞 目录 Spring 概述 依赖注入 Spring beans Spring注解 Spr ...

  10. 支持向量机SVM

    SVM(Support Vector Machine)有监督的机器学习方法,可以做分类也可以做回归.SVM把分类问题转化为寻找分类平面的问题,并通过最大化分类边界点距离分类平面的距离来实现分类. 有好 ...