VC驿站

 找回密码
 加入驿站

QQ登录

只需一步,快速开始

搜索
查看: 409|回复: 4

如何用C++操作sql server读csv文件

[复制链接]
57_avatar_middle
最佳答案
0 
在线会员 发表于 2019-9-3 23:01:46 | 显示全部楼层 |阅读模式
3驿站币
可以直接用C++让SQL SERVER把CSV文件读进去吗?还是先用C++读CSV再存进数据库里?

最佳答案

查看完整内容

可以直接导入,使用类似这种SQL脚本语句: 详情参考: https://stackoverflow.com/questions/18274129/how-to-upload-a-csv-file-to-sql-server-using-c?lq=1 https://stackoverflow.com/questions/18277243/upload-csv-to-sql-server-using-c




上一篇:关于基址和偏移量的问题
下一篇:请教AfxBeginThread的一个问题
51_avatar_middle
最佳答案
83 
online_admins 发表于 2019-9-3 23:01:47 | 显示全部楼层
可以直接导入,使用类似这种SQL脚本语句:
  1. BULK
  2. INSERT <<TABLE NAME>>
  3. FROM <<File name>>
  4. WITH (
  5. FIELDTERMINATOR = ','
  6. ROWTERMINATOR = '\n'
  7. )
复制代码


详情参考:
https://stackoverflow.com/questi ... server-using-c?lq=1
https://stackoverflow.com/questi ... -sql-server-using-c
57_avatar_middle
最佳答案
0 
ico_lz  楼主| 发表于 2019-9-21 22:46:51 | 显示全部楼层
本帖最后由 lyyyyyyan 于 2019-9-21 22:49 编辑
Syc 发表于 2019-9-3 23:01
可以直接导入,使用类似这种SQL脚本语句:

我想用下面的代码连接数据库再读入.CSV文件,但是会在创建数据表的环节出错,是权限的问题吗?如果是的话要怎么改呢?

#include <iostream>
#include <windows.h>
#include <string>
#include <sqlext.h>
#include <sqltypes.h>
#include <sql.h>
#include <time.h>
using namespace std;

void main()
{
        clock_t start = clock();

        SQLHANDLE sqlevent, sqlconnection, sqlstatement;

        if (SQL_SUCCESS != SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &sqlevent))
        {
                cout << "The sqlevent has failed to be created." << endl;
                system("pause");
                return;
        }


        if (SQL_SUCCESS != SQLSetEnvAttr(sqlevent, SQL_ATTR_ODBC_VERSION, (SQLPOINTER)SQL_OV_ODBC3, 0))
        {
                cout << "The sqlevent has failed to be initialized." << endl;
                system("pause");
                return;
        }

        if (SQL_SUCCESS != SQLAllocHandle(SQL_HANDLE_DBC, sqlevent, &sqlconnection))
        {
                cout << "The sqlconnection has failed to be created." << endl;
                system("pause");
                return;
        }
        
        SQLCHAR retstring[10000];
        SQLDriverConnect(sqlconnection, NULL, (SQLCHAR*)("DRIVER={SQL Server Native Client 10.0};SERVER=192.168.1.100;DATABASE=master;UID=sa;PWD=123456"), SQL_NTS, retstring, 10000, NULL, SQL_DRIVER_NOPROMPT);
        
        if (SQL_SUCCESS != SQLAllocHandle(SQL_HANDLE_STMT, sqlconnection, &sqlstatement))
        {
                cout << "The sqlstatement has failed to be created." << endl;
                system("pause");
                return;
        }

        string commandline;

        commandline = "CREATE TABLE NEW_TABLE ( NAME VARCHAR(20), AGE FLOAT, ID VARCHAR(10)) GO ";

        if (SQL_SUCCESS != SQLExecDirect(sqlstatement, (SQLCHAR*)(commandline.c_str()), SQL_NTS))
        {
                cout << "The create table sql command has failed to excute." << endl;
                system("pause");
                return;
        }

        commandline = "BULK INSERT NEW_TABLE FROM 'C:\\Users\\LiYanyan\\Desktop\\text.csv' WITH ( FIELDTERMINATOR = ',', ROWTERMINATOR = '\n') GO";

        if (SQL_SUCCESS != SQLExecDirect(sqlstatement, (SQLCHAR*)(commandline.c_str()), SQL_NTS))
        {
                cout << "The import sql command has failed to excute." << endl;
                system("pause");
                return;
        }

        clock_t end = clock();

        cout << "Import from .csv file to SQL Server costs " << ((end - start) / double(CLOCKS_PER_SEC)) << " seconds." << endl;

        system("pause");

        return;

}
51_avatar_middle
最佳答案
83 
online_admins 发表于 2019-9-21 22:53:14 | 显示全部楼层
lyyyyyyan 发表于 2019-9-21 22:46
我想用下面的代码连接数据库再读入.CSV文件,但是会在创建数据表的环节出错,是权限的问题吗?如果是的话 ...

一般这种 SQL 的操作都要加上 try-catch 捕获下异常,这样报错了之后也大概能知道是什么问题,不然真心不太好判断
84_avatar_middle
最佳答案
0 
在线会员 发表于 2019-9-22 17:30:20 | 显示全部楼层
Syc 发表于 2019-9-21 22:53
一般这种 SQL 的操作都要加上 try-catch 捕获下异常,这样报错了之后也大概能知道是什么问题,不然真心不 ...

老大,我问下,try-catch是什么东东,一直不理解为什么要存在这个东东,直接运行不行吗?为什么要try呢?catch又catch的什么啊
您需要登录后才可以回帖 登录 | 加入驿站 qq_login

本版积分规则

×【发帖 友情提示】
1、请回复有意义的内容,请勿恶意灌水;
2、纯数字、字母、表情等无意义的内容系统将自动删除;
3、若正常回复后帖子被自动删除,为系统误删的情况,请重新回复其他正常内容或等待管理员审核通过后会自动发布;
4、感谢您对VC驿站一如既往的支持,谢谢合作!

关闭

站长提醒上一条 /2 下一条

QQ|小黑屋|手机版|VC驿站 ( 辽ICP备09019393号 )|网站地图wx_jqr

GMT+8, 2020-12-1 11:08

Powered by CcTry.CoM

© 2009-2020 cctry.com

快速回复 返回顶部 返回列表