数据库组件 Hxj.Data (十三) (子查询)

查询条件的值来自另外一次查询。

例如  sqlserver sql:

select * from products where categoryid=(select top 1 categoryid from categories where categoryname=’produce’)

这条sql的实现代码如下:

DbSession.Default.From<Products>()
         .Where(Products._.CategoryID
         .SubQueryEqual(DbSession.Default.From<Categories>().Where(Categories._.CategoryName ==  "Produce").Select(Categories._.CategoryID).Top(1)))
         .ToList();

对比一下组件生成的sql

Text:
SELECT * FROM [Products]
WHERE [Products].[CategoryID] = ( SELECT TOP 1 [Categories].[CategoryID] FROM [Categories] WHERE [Categories]. [CategoryName] = @174b5c8999e2480594cdc08ab4d8e5bd)
Parameters:
@174b5c8999e2480594cdc08ab4d8e5bd[String] = Produce

子查询方法对应sql表如下:

方法名称 sql
SubQueryEqual =
SubQueryNotEqual <>
SubQueryLess <
SubQueryLessOrEqual <=
SubQueryGreater >
SubQueryGreaterOrEqual >=
SubQueryIn in
SubQueryNotIn not in

再写一个例子

DbSession.Default.From<Products>()
         .Where(Products._.CategoryID
         .SubQueryNotIn(DbSession.Default.From<Categories>().Where(Categories._.CategoryName ==  "Produce").Select(Categories._.CategoryID)))
         .ToList();

生成的sql如下

Text:
SELECT * FROM [Products]
WHERE [Products].[CategoryID]
NOT IN ( SELECT [Categories].[CategoryID] FROM [Categories] WHERE [Categories].[CategoryName] =  @32365a219b864e5fbeb7959a6071d4c8)
Parameters:
@32365a219b864e5fbeb7959a6071d4c8[String] = Produce

子查询是不是也变的很简单的呢了。

下一节将讲述联合查询。

时间: 2025-01-26 18:49:28

数据库组件 Hxj.Data (十三) (子查询)的相关文章

数据库组件 Hxj.Data (二十八)

数据库组件 Hxj.Data (二十八)(事务中的查询,查询字段字中的子查询,WhereClip的隐式转换) 本节讲述新版本中新加的功能,以及如何使用. 事务中的查询 应用场景,有时我们需要事务更新.添加.删除表的操作,在提交事务又需要对这些进行查询(不想 降低事务级别让其他连接查询事务中的数据变动),在事务内部进行的查询. 其实只是在DbTrans中增加了FromSection方法. 示例代码如下: using (DbTrans trans = DbSession.Default.BeginT

数据库组件 Hxj.Data (三)(查询操作篇)

Hxj.Data使用入口在Hxj.Data.DbSession,DbSession类封装常用的操作,比如: From<T>,Insert<T>,Update<T>,Delete<T>等常用方法. DbSession.Default是一个默认的DbSession.在默认情况下会自动读取web.config/app.config配置文件中connectionStrings节点的最后一 个配置. 可以通过条用DbSession的SetDefault方法来修改这个D

数据库组件 Hxj.Data (十二) (模糊查询、简单的in,not in查询)

条件的生成都是通过对表中字段进行的. 比如: Products._.UnitPrice > 1 Products._.CategoryID == 2 这些是简单的比较. 下面来介绍通过like 模糊查询该怎么做. 先上代码, Products._.ProductName.Contain("apple") 这句等效sql就是(sqlserver) productname like '%apple%' 就是完全模糊搜索. Products._.ProductName.BeginWit

数据库组件 Hxj.Data (三十一)(MySQL篇)

组件V1.7版本增加对MySQL的支持(测试了MySQL 5.1版本). 下面来演示如何使用. 首先添加Connectionstring <add name="MySQLConnectionString" connectionString="server=192.168.1.175;user id=root; password=huxj; Port=3306;database=test;" providerName="Hxj.Data.MySql&q

数据库组件 Hxj.Data (二十五)(数据库连接配置

本节补充讲述connectionStrings的设置. 组件读取connectionStrings节点的配置的时候会根据providerName来判断是哪个数据库. 数据库 providerName Sql server 2000 1.System.Data.SqlClient 2.Hxj.Data.SqlServer Sql server 2005 Hxj.Data.SqlServer9 MS Access Hxj.Data.MsAccess Sqlite 1.System.Data.SQLi

数据库组件 Hxj.Data (二十四)(Sqlite数据库)

Hxj.Data(V1.3)组件增加了对Sqlite数据库的支持. 以及实体生成工具也同时发布(V1.3)版本支持Sqlite数据库的实体生成. 使用Sqlite数据库开发,需要引用Hxj.Data.Hxj.Data.Sqlite.System.Data.SQLite这三个DLL. config配置数据库连接例如: <add name="SqliteConnectionString" connectionString="Data Source=C:\sqldb.db&q

数据库组件 Hxj.Data (二十二) (缓存)

首先我是做web开发的,所以很多会偏向web的,组件使用的缓存是System.Web.HttpRuntime.Cache. 组件在默认情况下是关闭缓存的. 所以要开启缓存查询要做一下配置. 先看一下例子配置: <configSections> <section name="HxjCacheConfig" type="Hxj.Data.CacheConfiguration,Hxj.Data"/> </configSections>

数据库组件 Hxj.Data (一)(介绍篇)

Hxj.Data经过几个月的开发,终于发布了一个版本,并同时发布实体生成工具.在开发过程参考了多个ORM框架,特别是NBear,MySoft等. 吸取了他们的一些精华,加入自己的新思想. 目前支持Sql2000\2005,MsAccess,Oracle三个数据库,如有需要可再扩展. 数据库实体生成的代码Northwind数据库中Products表: //------------------------------------------------------------------------

数据库组件 Hxj.Data (二十七)(字段组合更新)

Hxj.Data V1.5.1版本开始支持字段组合更新. 例如:update table set a=b+c update table set a=a+1 (+.-.*./.%)依次类推. 下面将举具体的例子.(例子只是为了测试效果,没有实际意义) 例一. DbSession.Default.Update<Products>(Products._.UnitPrice, Products._.ReorderLevel + Products._.UnitPrice, Products._.Prod