采用OGR读postgresql数据库
1.请问:采用OGR读postgresql数据库,为什么不成功呢?
int _tmain(int argc, _TCHAR* argv[])
{
int _tmain(int argc, _TCHAR* argv[])
{
CImportdata* temp=new CImportdata;
const char *filePath = “PG:dbname=bnudb host=localhost port=5432 user=postgres password=19690927”;
const char *driveName = “PostgreSQL”;
const char *pLayerName = “bou1_4l”;
OGRSFDriver *pDriver = NULL;
OGRLayer *pLayer = NULL;
OGRDataSource *pODS = NULL;
bool DoSuceedReadingPG=false;
DoSuceedReadingPG=temp->openPG(filePath,pLayerName);
return 0;
}
bool CImportdata::openPG(const char *para, const char *table)
{
poDS = OGRSFDriverRegistrar::Open(para, FALSE );
if (poDS == NULL)
{
fprintf(stderr, “[ERROR]:Open PostgreSQL database error!\nPlease check your parameter is correct!\n”);
return false;
}
//m_poLayer = poDS->ExecuteSQL(“select * from bigscalezongditu order by gid”,NULL,NULL);//通过SQL语句获取图层数据
m_poLayer = poDS->GetLayerByName(table); //通过数据表明获取图层
return true;
}
const char *filePath = “PG:dbname=bnudb host=localhost port=5432 user=postgres password=19690927”;
const char *driveName = “PostgreSQL”;
const char *pLayerName = “bou1_4l”;
OGRSFDriver *pDriver = NULL;
OGRLayer *pLayer = NULL;
OGRDataSource *pODS = NULL;
bool DoSuceedReadingPG=false;
DoSuceedReadingPG=temp->openPG(filePath,pLayerName);
return 0;
}
bool CImportdata::openPG(const char *para, const char *table)
{
poDS = OGRSFDriverRegistrar::Open(para, FALSE );
if (poDS == NULL)
{
fprintf(stderr, “[ERROR]:Open PostgreSQL database error!\nPlease check your parameter is correct!\n”);
return false;
}
//m_poLayer = poDS->ExecuteSQL(“select * from bigscalezongditu order by gid”,NULL,NULL);//通过SQL语句获取图层数据
m_poLayer = poDS->GetLayerByName(table); //通过数据表明获取图层
return true;
}
参考网址:http://blog.csdn.net/yangtrees/article/details/8773508
问题:为什么使用私有变量?
==================================================================================================
举个例子给你说明吧,比如现在你要做一个具有计算球的体积功能的类。 假如这个类我们已经写好了,它名为VClass。 那么我们现在要计算体积了 VClass VmyClass;//对象实力 float banjin = 2;//半径 VmyClass.SetBanJin(banjin);//调用类初始化半径 float Tiji = VmyClass.GetTiji();//得出该半径求的体积 前面调用到的两个函数,应该都必须是public的,因为别人要调用这两个函数去得到自己想要的体积。VClass类里面应该还有很多成员,打个比方吧,假如它有一个成员:float PI=3.141592653;请问我该把这个成员设成私有的还是公共的呢?答案肯定是私有的,因为这样更安全。如果设成公共的,那么我们在别的类里面就可以像这样调用 VmyClass.PI = 1;设想一下PI的值被随意改变后,VClass里面计算球面积的函数肯定会用到这个PI,那么计算出的结果,也就是球的体积肯定就有错误了对吧。这就是一个最简单的私有成员安全性。往往我们实际写代码的过程中函数很多,成员很多,务必要把公共和私有分清楚。要不然很容易造成这样的错误
参考网址:http://zhidao.baidu.com/link?url=DeVChFvqb3KAAAzwP6y-Ymek6U7uyIOs0vpNyz33lqwICmmJSkyBt9rXnuWAKzOW9x-HQkNi-MsANNBsbs3pJq
=========================================================================================
3.stdafx.h他的作用是什么?
预编译的一个文件,属于微软标准,不是C++的标准。
参考网址:http://blog.sina.com.cn/s/blog_8eee7fb601012kun.html、http://zhidao.baidu.com/link?url=Q2jTJn38BWjBYoVy8qMrcx0zfffmIzNDI5ILjxCoxr0XUMYoi6G1MPYbb5n6EjbjpKmqgrQXwlk4SPSlJiIXla
=================================================================================
4. int main(int
argc,char* argv[])详解
参考网址:http://www.cnblogs.com/avril/archive/2010/03/22/1691477.html
argc是命令行总的参数个数
argv[]是argc个参数,其中第0个参数是程序的全名,以后的参数
命令行后面跟的用户输入的参数,比如:
int main(int argc, char* argv[])
{
int i;
for (i = 0; i<argc; i++)
cout<<argv[i]<<endl;
cin>>i;
return 0;
}
执行时敲入
F:\MYDOCU~1\TEMPCODE\D1\DEBUG\D1.EXE aaaa bbb ccc ddd
输出如下:
F:\MYDOCU~1\TEMPCODE\D1\DEBUG\D1.EXE
aaaa
bbb
ccc
ddd
——————————————————————–
char *argv[]是一个字符数组,其大小是int argc,主要用于命令行参数 argv[] 参数,数组里每个元素代表一个参数;
比如你输入
test a.c b.c t.c
则
argc = 4
argv[0] = “test”
argv[1] = “a.c”
argv[2] = “b.c”
argv[3] = “t.c”
——————————————————————————————–
argc记录了用户在运行程序的命令行中输入的参数的个数。
arg[]指向的数组中至少有一个字符指针,即arg[0].他通常指向程序中的可执行文件的文件名。在有些版本的编译器中还包括程序
文件所在的路径。
————————————————————————-
在调用一个可执行程序时,某些情况下需要向程序传递参数。如我们可以在控制台中键入notepad.exe,
回车后将执行记事本程序。如果我们希望在打开notepad时同时打开一个文本文件,可以在notepad.exe
后面跟上文件的路径和名字,如notepad.exe example.txt(文件在当前路径)。
那么程序中如何能得到这些输入参数呢?这个工作是编译器帮我们完成的,编译器将输入参数的信息
放入main函数的参数列表中。
main函数的参数列表保存了输入参数的信息,第一个参数argc记录了输入参数的个数,
第二个参数是字符串数组的,字符串数组的每个单元是char*类型的,指向一个c风格字符串。
以notepad.exe example.txt为例
argc是2,就是说argv数组中有两个有效单元
第一单元指向的字符串是”notepad.exe”
第二单元指向的字符串是”example.txt”
argv数组中的第一个单元指向的字符串总是可执行程序的名字,以后的单元指向的字符串依次是程序调用时的参数。
这个赋值过程是编译器完成的,我们只需要读出数据就可以了。
—————————————————————————–
argv[]是argc个参数,其中第0个参数是程序的全名,以后的参数
命令行后面跟的用户输入的参数,比如:
int main(int argc, char* argv[])
{
int i;
for (i = 0; i<argc; i++)
cout<<argv[i]<<endl;
cin>>i;
return 0;
}
执行时敲入
F:\MYDOCU~1\TEMPCODE\D1\DEBUG\D1.EXE aaaa bbb ccc ddd
输出如下:
F:\MYDOCU~1\TEMPCODE\D1\DEBUG\D1.EXE
aaaa
bbb
ccc
ddd
——————————————————————–
char *argv[]是一个字符数组,其大小是int argc,主要用于命令行参数 argv[] 参数,数组里每个元素代表一个参数;
比如你输入
test a.c b.c t.c
则
argc = 4
argv[0] = “test”
argv[1] = “a.c”
argv[2] = “b.c”
argv[3] = “t.c”
——————————————————————————————–
argc记录了用户在运行程序的命令行中输入的参数的个数。
arg[]指向的数组中至少有一个字符指针,即arg[0].他通常指向程序中的可执行文件的文件名。在有些版本的编译器中还包括程序
文件所在的路径。
————————————————————————-
在调用一个可执行程序时,某些情况下需要向程序传递参数。如我们可以在控制台中键入notepad.exe,
回车后将执行记事本程序。如果我们希望在打开notepad时同时打开一个文本文件,可以在notepad.exe
后面跟上文件的路径和名字,如notepad.exe example.txt(文件在当前路径)。
那么程序中如何能得到这些输入参数呢?这个工作是编译器帮我们完成的,编译器将输入参数的信息
放入main函数的参数列表中。
main函数的参数列表保存了输入参数的信息,第一个参数argc记录了输入参数的个数,
第二个参数是字符串数组的,字符串数组的每个单元是char*类型的,指向一个c风格字符串。
以notepad.exe example.txt为例
argc是2,就是说argv数组中有两个有效单元
第一单元指向的字符串是”notepad.exe”
第二单元指向的字符串是”example.txt”
argv数组中的第一个单元指向的字符串总是可执行程序的名字,以后的单元指向的字符串依次是程序调用时的参数。
这个赋值过程是编译器完成的,我们只需要读出数据就可以了。
—————————————————————————–
转载自:https://blog.csdn.net/zhenxin066/article/details/20544347