dapper关联关系查询小测试
测试实体类(表结构)
public class User
{
public int user_id { get; set; }
public string user_name { get; set; }
} public class Book
{
public int book_id { get; set; }
public string book_name { get; set; }
public int user_id { get; set; }
} //一对多关系
public class UserBooks : User
{
public List<Book> Books;
public UserBooks()
{
Books = new List<Book>();
}
} //一对一关系
public class UserBook : User
{
public Book MyBook;
}
测试程序
public static void TestOneToMany()
{
using (var con = new MySqlConnection("Server=182.180.57.3;Database=test;port=3306;user id=root;password=123;"))
{
Console.WriteLine("==========下面是一对多的Demo===========");
var userBooks = con.Query<UserBooks, Book, UserBooks>(@"SELECT a.user_name,a.user_id,b.user_id,b.book_id, b.book_name FROM tab_user a INNER JOIN tab_book b ON a.user_id=b.user_id"
, (user, book) =>
{
user.Books.Add(book);
return user;
}, null, null, true, "user_id");
foreach (UserBooks ub in userBooks)
{
Console.Write(ub.user_id + "\t" + ub.user_name + "\t");
foreach (Book book in ub.Books)
{
Console.Write(book.book_id + " " + book.book_name + "\n");
}
}
Console.WriteLine("==========下面是一对一的Demo===========");
var userBook = con.Query<UserBook, Book, UserBook>(@"SELECT a.user_name,a.user_id,b.user_id,b.book_id, b.book_name FROM tab_user a INNER JOIN tab_book b ON a.user_id=b.user_id where a.user_id=3"
, (user, book) =>
{
user.MyBook = book;
return user;
}, null, null, true, "user_id").First<UserBook>();
Console.WriteLine(userBook.user_id + "\t" + userBook.user_name + "\t" + userBook.MyBook.book_id + "\t" + userBook.MyBook.book_name);
Console.Read();
}
}
dapper关联关系查询小测试的更多相关文章
- myBatis 基础测试 表关联关系配置 集合 测试
myBatis 基础测试 表关联关系配置 集合 测试 测试myelipse项目源码 sql 下载 http://download.csdn.net/detail/liangrui1988/599388 ...
- 一道Oracle子查询小练习
一道Oracle子查询小练习 昨天晚上躺在床上看Oracle(最近在学习这个),室友说出个题目让我试试.题目如下: 有如下表结构,请选择出成绩为前三名的人的信息(如果成绩相同,则算并列),表名为t ...
- 用友yonsuite产品二开之简单的yonsql查询小工具
和以往的用友产品不同,yonsuite产品开发了低代码平台,满足客户的个性化开发需求.嗯~,一句话不知当讲不当讲,那就讲:所谓低代码平台就是开发不想用实施不会用系列.让我一个开发感受到了憋屈.
- Cad 二次开发关于SelectCrossingPolygon和SelectFence返回结果Status为error的小测试
CAD2008的二次开发,有个很奇怪的现象,只要你选择的点集不在当前视图上SelectCrossingPolygon和SelectFence返回结果Status就会为error,所以要获取正确的结果, ...
- sql之left join、right join、inner join的区别,连接自己时的查询结果测试
sql之left join.right join.inner join的区别 left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 right join(右联接) 返回包括 ...
- 左连接LEFT JOIN 连接自己时的查询结果测试
#左连接LEFT JOIN 连接自己时的查询结果测试 #左连接LEFT JOIN 连接自己时的查询结果(都会出现两个重复字段),两个表都有as后只能查询相等条件merchant_shop_id非nul ...
- thinkphp+dwz完成的一个号码查询小系统
基于网友的例子(http://www.thinkphp.cn/extend/450.html),改进完成一个电话号码查询管理系统.基于thinkphp+dwz完成的电话号码查询小系统,主要改进与功能如 ...
- python 程序小测试
python 程序小测试 对之前写的程序做简单的小测试 ... # -*- encoding:utf-8 -*- ''' 对所写程序做简单的测试 @author: bpf ''' def GameOv ...
- MySQL 表记录查询小练习
表记录查询小练习 查看岗位是teacher的员工姓名.年龄 查看岗位是teacher且年龄大于26岁的员工姓名.年龄 查看岗位是teacher且薪资在12000-16000范围内的员工姓名.年龄.薪资 ...
随机推荐
- 转载SSIS中的容器和数据流—数据转换(Transformations)续
数据挖掘请求 数据挖掘任务是SSIS中一个很重要的任务,它的思想来源于一些算法.数据挖掘请求运行数据挖掘请求,并将结果输出到数据流.它还可以添加一些预测新列,一些应用场合如下列举: 根据已知的一些列, ...
- 【Stage3D学习笔记续】山寨Starling(三):Starling核心渲染流程
这篇文章我们剔除Starling的Touch事件体系和动画体系,专门来看看Starling中的渲染流程实现,以及其搭建的显示列表结构. 由于Starling是模仿Flash的原生显示列表,所以我们可以 ...
- NSArrary和NSString间的转换
将string字符串转换为array数组 NSArray *array = [Str componentsSeparatedByString:@","]; // 注意:NSArr ...
- hdu1754线段树维护区间最大值
#include <iostream> #include <cstdio> using namespace std; #define MAXN 200005 int N,M; ...
- 创建性能监视器(logman)
在本地计算机上抓取性能信息 Logman.exe create counter Perf-1Second -f bincirc -max 500 -c "\Processor(*)\% Pr ...
- 金蝶K3 破解版
- 新浪旗下的SAE云服务入门
前言: 云服务已经火热很多年了,到了现在已经基本进入稳定期,稍微有实力的公司都会推出免费的云存储,像百度的还几个T,速度也不错.如果不担心数据安全问题,代替平时的U盘还是没有问题.而SAE是新浪在20 ...
- 几种sap增强的查找方法
***方法一**************************************** 通过SE30,运行TCODE后,点Evaluate后,查看运行时间分析评估:命中清单. 找以“exit”开 ...
- android124 zhihuibeijing 新闻中心-新闻 -北京页签 下拉刷新
缓存工具类:以url为key,json数据为value, package com.itheima.zhbj52.utils; import com.itheima.zhbj52.global.Glob ...
- 信号之abort函数
abort函数的功能是使异常程序终止. #include <stdlib.h> void abort(void); 此函数不返回 此函数将SIGABRT信号发送给调用进程(进程不应忽略此信 ...