http://blog.sina.com.cn/s/blog_56fd66a70100hxjf.html

http://timke.blog.163.com/blog/#m=0

环境:MFC  Dialog  UNICODE

1 寻找包含某个字符的字段值并将符合条件的记录取出 ,like语句

_ConnectionPtr m_pCon; 

_RecordsetPtr m_pRs;

 try{

CString sql=SELECT * FROM 表 WHERE 字段 LIKE  '%'

HRESULT hr=m_pRs->Open((_variant_t)sql,m_pCon.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);

 if (SUCCEEDED(hr))

 {

 

  while (!m_pRs->EndOfFile)

  {

  

   vFieldValue=m_pRs->GetCollect(字段名称);

   MessageBox((_bstr_t)vFieldValue);

   m_pRs->MoveNext();

  

  }

  hr=m_pRs->Close();//关闭记录集

 }

}

catch(_com_error e)

 {

  MessageBox(e.Description());

 }

2  获取符合条件记录的个数,并将获取到的个数取出 count语句

_ConnectionPtr m_pCon; 

_RecordsetPtr m_pRs;

 try{

  CString sql=_T("SELECT COUNT(*) FROM 表名 WHERE 字段名='字段值'");

  _variant_t RecordsAffected;

  m_pRs=m_pCon->Execute((_bstr_t)sql,&RecordsAffected,adCmdText); 

  _variant_t vIndex = (long)0;

  _variant_t vCount = m_pRs->GetCollect(vIndex);

  MessageBox(_bstr_t( vCount),_T("获取符合条件的记录的个数"),MB_OK);

  m_pRs->Close();///关闭记录集

 }

 catch(_com_error e)

 {

  MessageBox(e.Description());

 }

3  取出某个符合条件的不重复字段 distinct语句

_ConnectionPtr m_pCon; 

_RecordsetPtr m_pRs;

try{

  _variant_t vFieldValue;

  CString sql=_T("SELECT DISTINCT 需要取出的字段 FROM 表名 WHERE 字段='字段值'");

  _variant_t RecordsAffected;

  m_pRs=m_pCon->Execute((_bstr_t)sql,&RecordsAffected,adCmdText);

while (!m_pRs->EndOfFile)

  {

  

   vFieldValue=m_pRs->GetCollect(_T("需要取出的字段"));

                        MessageBox(_bstr_t(vFieldValue));

   m_pRs->MoveNext();

}

m_pRs->Close();

 }

 catch(_com_error e)

 {

  MessageBox(e.Description());

 }

4 操作表过程中的一些问题

4(1)打开表返回的记录数总是-1

_RecordsetPtr m_pRs;

m_pRs->RecordCount返回值总是-1

解决方法:

设置游标的类型为客户端类型

m_pRs->CursorLocation=adUseClient;

然后打开表

4(2)移动不了记录指针

_RecordsetPtr m_pRs;

m_pRs->MoveNext();语句不起作用

解决方案:采用静态方式打开

下面的sql是一个sql语句

m_pRs->Open((_variant_t)sql,m_pCon.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);

更改为

m_pRs->Open((_variant_t)sql,m_pCon.GetInterfacePtr(),adOpenStatic,adLockOptimistic,adCmdText);

以上程序在VC++2005 MFC Unicode下调试通过

VC++2005下的ADO SQL语句(like,count,distinct)和操作(转)的更多相关文章

  1. SQL语句中count(1)count(*)count(字段)用法的区别

    SQL语句中count(1)count(*)count(字段)用法的区别 在SQL语句中count函数是最常用的函数之一,count函数是用来统计表中记录数的一个函数, 一. count(1)和cou ...

  2. sql 语句中count()有条件的时候为什么要加上or null

    参考:https://blog.csdn.net/qq_32719287/article/details/79513164 1.sql 语句中count()有条件的时候为什么要加上or null. 如 ...

  3. SQL语句中count(1)count(*)count(字段)用法的区别(转)

    SQL语句中count(1)count(*)count(字段)用法的区别 在SQL语句中count函数是最常用的函数之一,count函数是用来统计表中记录数的一个函数, 一. count(1)和cou ...

  4. pandas pivot_table或者groupby实现sql 中的count distinct 功能

    pandas pivot_table或者groupby实现sql 中的count distinct 功能 import pandas as pd import numpy as np data = p ...

  5. 4.5 .net core下直接执行SQL语句并生成DataTable

    .net core可以执行SQL语句,但是只能生成强类型的返回结果.例如var blogs = context.Blogs.FromSql("SELECT * FROM dbo.Blogs& ...

  6. mysql row日志格式下 查看binlog sql语句

    有时候我们需要使用row作为binlog的日志格式,即配置文件使用了binlog_format= row 参数 这样以来,我们在查看数据库binlog内容时候,就看不到增删改查的具体语句了,在数据库恢 ...

  7. .net core下直接执行SQL语句并生成DataTable

    .net core可以执行SQL语句,但是只能生成强类型的返回结果.例如var blogs = context.Blogs.FromSql("SELECT * FROM dbo.Blogs& ...

  8. LINQ to SQL语句之Select/Distinct和Count/Sum/Min/Max/Avg (转)

    Select/Distinct操作符 适用场景:o(∩_∩)o… 查询呗. 说明:和SQL命令中的select作用相似但位置不同,查询表达式中的select及所接子句是放在表达式最后并把子句中的变量也 ...

  9. MySQL常用sql语句-----数据表的查询操作

    常用的sql语句如下,应对工作足以 1.查询指定字段 select c_id,c_age,c_name from t_student; select c_id as 编号,c_name as 姓名,c ...

随机推荐

  1. 剑指offer系列45---和为s的两个数字

    [题目]输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S, package com.exe9.offer; /** * [题目]输入一个递增排序的数组和一个数字S,在数组中 ...

  2. Makefile所有内嵌函数

    一.文本处理函数以下是GNU make内嵌的文本(字符串)处理函数.1       $(subst FROM,TO,TEXT) 函数名称:字符串替换函数—subst. 函数功能:把字串“TEXT”中的 ...

  3. html元素背景样式大小调整

    定义元素背景设置 background-size属性cover自适应填充背景,background-size: 100% 100%; background-size: 左右比例  上下比例: 再介绍几 ...

  4. yarn的调度策略

    一. yarn的资源分配模型 无论先进先出调度器,容量调度器,还是公平调度器,他们的核心:资源分配模型是一样的. 调度器维护着多个队列的信息,用户可以向任意一个或多个队列提交job.每次NodeMan ...

  5. PLSQL_查询已执行SQL的绑定参数(案例)

    2014-12-19 Created By BaoXinjian

  6. JavaScript面向对象编程指南

    引言 面向对象程序设计 基本数据类型.数组.循环及条件表达式 基本数据类型 函数 函数Function 预定义函数 变量的作用域 函数也是数据 闭包 对象 原型 原型 继承 原型链 浅拷贝与深拷贝 原 ...

  7. js 神代码

    eval(z='p="<"+"pre>"/* ,.oq#+ ,._, */;for(y in n="zw24l6k\ 4e3t4jnt4q ...

  8. UCOS-消息队列(学习笔记)

    消息队列的核心是一个消息的指针数组,UCOS系统初始化时根据OS_CONFI.h中的最大队列个数定义这么多个消息队列(队列的结构)并将他们串联成空的链表,创建消息队列时从空链表中抽出一个并用指针数组的 ...

  9. keil中的串口调试:

    keil中串口的虚拟调试信息在通过View-serial windows-#usart1/2/3/4/debug(printf)可以看到.当然也可以通过虚拟串口VSPD+串口调试助手在外部实现,方法如 ...

  10. redmine后台运行命令

    nohup ruby script/rails server webrick -e production & redmine 3 后台运行命令: nohup  bundle exec rail ...