‘壹’ linq groupby动态分组 ,比如根据用户选择的产品型号,产品分类,入库仓库进行动太分组
var q =
from p in 表
group p by p.要分组的字段 into g
where 加条件,要什么自己加
select new {
g.Key,
NumProcts = g.Count() //求数量,或求和都可以
};
‘贰’ linq to sql类可以动态创建吗
using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows.Controls;
using System.Windows.Documents;
using System.Xml.Linq;
using System.Data.Linq.Mapping;
using System.Data.Linq;
using System.Data.SqlClient;
[Table(Name = "student")]
public class Student
{
//如果数据库字段名,和Name指定的一样,可以不用写Name属性
//类型和数据库字段类型,请保持一致
[Column(IsPrimaryKey = true, Name = "ID")]
public int ID { get; set; }
[Column(Name = "Name")]
public string Name { get; set; }
[Column(Name = "Sex")]
public string Sex { get; set; }
[Column(Name = "Age")]
public byte Age { get; set; }
[Column(Name = "Address")]
public string Address { get; set; }
}
public void ToSql1()
{
string connectsql = "server=.\\SQLEXPRESS;database=test;uid=zy;pwd=zy;";//sql 验证
string connectwin = "server=.\\sqlexpress;database=test;integrated security=true;";//windows 验证
DataContext d = new DataContext(connectwin);
Table<Student> std = d.GetTable<Student>();
//根据地区分组查询
var val = from s in std group s by s.Address into g select g;
foreach (var s in val)
{
txtPrint.AppendText(s.First().Address, ":");
foreach (var s1 in s)
{
txtPrint.AppendText(s1.Name, new string[] { s1.Sex, s1.Age.S() });
}
txtPrint.AppendText("\r\n");
}
}
‘叁’ sql语句中的groupby是什么意思
一、sql语句中的groupby是:GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组。
二、sql语句group by的高级语法:
1、写上一个创建表的 sql语句. 当然,我们也可以用设计图创建;
‘肆’ 求总结linq与sql语法比较
linq是面向对象的sql。也就是说,sql是向关系型数据库的查询,而linq实际上是对内存里的数据的查询。
虽然linq原来是对象查询,但经过ms的努力,可以通过表达式分析与实体到关系的映射(linq to sql),把linq转换为sql语句或是对xml的查询(linq to xml)。
因此,这种技术就成了对象到数据库记录的一个方便的映射、转化与操作的工具,你再也不必去去根据不同的情况用字符串拼接的办法生成sql,而是专心于对象模型的处理即可,你对于对象的修改最终都会被转换为对应的update, insert, delete等sql语句,在你submit时全部提交到数据库中。
综尔言之,linq to sql是一个数据库到对象结构的一个中间层, 他把对关系数据的管理转变为对象的操作,屏蔽了麻烦的sql,而且,还可以得到vs强大的智能感知功能的帮助。
LINQ,语言集成查询(Language INtegrated Query)是一组用于c#和Visual Basic语言的扩展。它允许编写C#或者Visual Basic代码以查询数据库相同的方式操作内存数据。
基本概念
从技术角度而言,LINQ定义了大约40个查询操作符,如select、from、in、where以及orderby(C#)中。试用这些操作可以编写查询语句。不过,这些查询还可以基于很多类型的数据,每个数据类型都需要一个单独的LINQ类型。 经过了最近 20 年,面向对象编程技术( object-oriented (OO) programming technologies )在工业领域的应用已经进入了一个稳定的发展阶段。程序员现在都已经认同像 类(classes)、对象(objects)、方法(methods)这样的语言特性。考察现在和下一代的技术,一个新的编程技术的重大挑战开始呈现出来,即面向对象技术诞生以来并没有解决降低访问和整合信息数据( accessing and integrating information )的复杂度的问题。其中两个最主要访问的数据源与数据库( database )和 XML 相关。 LINQ 提供了一条更常规的途径即给 .Net Framework 添加一些可以应用于所有信息源( all sources of information )的具有多种用途( general-purpose )的语法查询特性( query facilities ),这是比向开发语言和运行时( runtime )添加一些关系数据( relational )特性或者类似 XML 特性( XML-specific )更好的方式。这些语法特性就叫做 .NET Language Integrated Query (LINQ) 。 包含 DLinq 和 XLinq
基础知识
1. LINQ的读法:(1)lin k (2)lin q 2. LINQ的关键词:from, select, in, where, group by, order by … 3. LINQ的注意点:必须以select或者是group by 结束。 4. LINQ的语义: from 临时变量 in 集合对象或数据库对象 where 条件表达式 [order by条件] select 临时变量中被查询的值 [group by 条件] LINQ的查询返回值的类型是临时变量的类型,可能是一个对象也可能是一个集合。并且LINQ的查询表达式是在最近一次创建对象时才被编译的。LINQ的查询一般跟var关键字一起联用 (什么是var?匿名对象) 。 5. LINQ的全称:Language-Integrated Query 6. LINQ的分类:LINQ to Object, LINQ to XML, LINQ to SQL, LINQ to ADO.NET 7. 命名空间:System.Linq; 注意:Linq是在.NET Framework 3.5 中出现的技术,所以在创建新项目的时候必须要选3.5或者更高版本,否则无法使用。 选择3.5或更高版本的.NET Framework之后,创建的新项目中会自动包含System.Linq的命名空间。
语法实例
C#3.0 LINQ 查询语法 首先来看一个很简单的LINQ查询例子,查询一个int 数组中小于5的数字,并按照大小顺序排列: class Program { static void Main(string[] args) { int[] arr = new int[] { 8, 5, 89, 3, 56, 4, 1, 58 }; var m = from n in arr where n < 5 orderby n select n; foreach (var n in m) { Console.WriteLine(n); } Console.ReadLine(); } } 上述代码除了LINQ查询语法外,其他都是我们所熟悉的语法,而LINQ查询语法跟SQL查询语法很相似,除了先后顺序。 Q:为何 LINQ 查询语法是以 from 关键字开头的,而不是以 select 关键字开头的?select 开头这种写法跟SQL的写法更接近,更易懂呀? A:简单来说,为了IDE的智能感知(Intelisence)这个功能,select 关键字放在后面了。 编程语言以 select 开头写LINQ查询语法不是没出现过,你如果使用过2005年的VB9 CTP 版本,那时候VB9的LINQ查询语法就是 select 关键字在前面,但是 select 关键字在前面,在做智能感知(Intelisence)时候就很头大。经过微软IDE组的权衡,确定了把 from 关键字放在最前面。 那时候 VB9 LINQ的查询语法还是 select 参数在最前面。不过后来 VB9 测试版改成了跟 C# 一样的做法, from 关键字放在最前面了。 更详细的解释,来自装配脑袋 假设你要书写这样的代码:Select p.Name, p.Age From p In persons Where xxx ,代码是一个个字符输入的。 我们在写到 p in persons 之前,p 的类型是无法推测的,所以写 Select p. 的时候,Name之类的属性不会弹出智能提示来。 这样就需要先去写 From 这句,再回来写 Select。 微软IDE组经过反复考虑决定,还不如就把 Select 写到后面了。于是编程语言中的写法就确定这样来写了。 VB9 的这个变化可以参看这篇博客: Select/From vs. From/Select revisited... 我们再来看一个稍稍复杂的LINQ查询: 在我们罗列的语言字符串中,我们希望按照字符长短,分类罗列出来,实现代码如下: static void Main(string[] args) { string [] languages = {"Java","C#","C++","Delphi","VB.net","VC.net","C++ Builder","Kylix","Perl","Python"}; var query = from item in languages orderby item group item by item.Length into lengthGroups orderby lengthGroups.Key descending select lengthGroups; foreach (var item in query) { Console.WriteLine("strings of length {0}",item.Key); foreach (var val in item) { Console.WriteLine(val); } } Console.ReadLine(); } 其中的 into 关键字表示 将前一个查询的结果视为后续查询的生成器,这里是跟 group by 一起使用的。 LINQ中的Group by不要跟 SQL 中的Group by 混淆,SQL 由于是二维结构,Group by 的一些逻辑受二维结构的约束,无法像 LINQ 中的Group by 这么灵活。
Linq的内部执行原理浅析
LINQ(Language Integrated Query)是Visual Studio 2008中的领军人物。借助于LINQ技术,我们可以使用一种类似SQL的语法来查询任何形式的数据。目前为止LINQ所支持的数据源有SQL Server、XML以及内存中的数据集合。开发人员也可以使用其提供的扩展框架添加更多的数据源,例如MySQL、Amazon甚至是Google Desktop。 一般来讲,这类查询语句的一个重要特点就是可以并行化执行。虽然有些情况下并行可能会带来一些问题,但这种情况非常少见。这样也就水到渠成地引出了PLINQ这个并行处理的LINQ类库。 PLINQ原名为Parallel LINQ,支持XML和内存中的数据集合。执行于远程服务器上的查询语句(例如LINQ to SQL)显然无法实现这个功能。 将LINQ语句转换为PLINQ语句极为简单——只需要在查询语句中From子句所指定的数据源的最后添加.AsParallel()即可。随后Where、OrderBy和Select子句将自动改为调用这个并行的LINQ版本。 据MSDN Magazine介绍,PLINQ可以以三种方式执行。第一种是管道处理:一个线程用来读取数据源,而其他的线程则用来处理查询语句,二者同步进行——虽然这个单一的消费线程可能并不那么容易与多个生产线程同步。不过若是能够仔细配置好负载平衡的话,仍然会极大地减少内存占用。 第二种模式叫做“stop and go”,用于处理结果集需要被一次返回时(例如调用ToList、ToArray或对结果排序)的情况。在这种模式下,将依次完成各个处理过程,并将结果统一返回给消费线程。这个模式在性能上将优于第一种模式,因为它省去了用来保持线程同步所花费的开销。 最后一种方法叫做“inverted enumeration”。该方法并不需要实现收集到所有的输出,然后在单一的线程中处理,而是将最终调用的函数通过ForAll扩展传递到每个线程中。这是目前为止最快的一种处理模式,不过这需要传递到ForAll中的函数是线程安全的,且最好不包含任何lock之类的互斥语句。 若是PLINQ中任意的一个线程抛出异常,那么所有的其他线程将会被终止。若是抛出了多个异常,那么这些异常将被组合成一个MultipleFailuresException类型的异常,但每个异常的调用堆栈仍会被保留。 关于LINQ的技巧从大的方面来看它能给开发团队带来的好处: 1、无需复杂学习过程即可上手 2、编写更少代码即可创建完整应用。 3、更快开发错误更少的应用程序。 4、无需求助奇怪的编程技巧就可合并数据源。 5、让新开发者开发效率更高。
‘伍’ linq 左连接并group by,请问该怎么写
linq 中group by的具体用法如下:
1.计数
语句描述:Linq使用Group By和Count得到每个CategoryID中产品的数量。
说明:先按CategoryID归类,取出CategoryID值和各个分类产品的数量。
2.带条件计数
语句描述:Linq使用Group By和Count得到每个CategoryID中断货产品的数量。
说明:先按CategoryID归类,取出CategoryID值和各个分类产品的断货数量。 Count函数里,使用了Lambda表达式,Lambda表达式中的p,代表这个组里的一个元素或对象,即某一个产品。
3.Where限制
语句描述:根据产品的―ID分组,查询产品数量大于10的ID和产品数量。这个示例在Group By子句后使用Where子句查找所有至少有10种产品的类别。
说明:在翻译成SQL语句时,在最外层嵌套了Where条件。
4.多列(Multiple Columns)
‘陆’ sql语句中的group by什么意思
一、sql语句中的groupby是:GROUP
BY
语句用于结合合计函数,根据一个或多个列对结果集进行分组。
二、sql语句group
by的高级语法:
1、写上一个创建表的
sql语句.
当然,我们也可以用设计图创建;
2、select
*
from
student,我们输入一条查询语句,显示出我们刚刚插入的所有数据;
3、select
stuname,COUNT(*)
from
student
group
by
stuname。从上面的结果我们不难看出,我们根据学生姓名进行了分组,另一种说法其实就是把重复的过滤了,把学生表中的姓名那一列用group
by分组,并且利用聚合函数(count) 统计每个姓名出现的次数。
Sql语句中有很多技巧,一般除了我们初学时的增删改查,还有其他很多。安装的时候也一定要记得看一下自己的操作系统是多少位.你是32位操作系统的就安装32位的Sqlserver
版本不限制,2005、2012都可以。
‘柒’ 请教一个 LINQ TO SQL 的GROUP BY 问题
用一个新变量赋值就好了,你这GroupBy前后的数据类型是不一样的
‘捌’ linq to sql左连接没有效果
真够复杂的,不过你没用ef吗?ef的导航属性查询可以代替join,方便的多。
‘玖’ linq 中如何group by sum怎么写
SQL:select * from A,B where A.cpID=B.cpID and A.cbID=B.cbID
LINQ:var p = from t1 in a
from t2 in b
from t3 in c
where t1.cpid equal t2.cpid and t1.cbid equal t3.cbid
select new
{
t1,
t2.cpid
}
linq 也能实现 sum、groupby 的效果的,网络上很多介绍,去看看就明白了,不过还是推荐做视图来处理
‘拾’ 求助!! linq to sql 和lambda表达式的转变。
转的具体代码受限于你的上下文,因此是不可能给你写出来你直接运行的。但原则都是相同的。要用到的有join,匿名类型(select的那些),entitiyfunction(如果你用entitiy framework)或者sqlmethods(如果你用了linq to sql)。