zoukankan      html  css  js  c++  java
  • 孤荷凌寒自学python第五十七天初次尝试使用python来连接远端MongoDb数据库

    孤荷凌寒自学python第五十七天初次尝试使用python来连接远端MongoDb数据库

    (完整学习过程屏幕记录视频地址在文末)

    今天是学习mongoDB数据库的第三天。感觉这个东西学习起来还是那么困难,今天是第一次尝试使用Python代码来连接远端数据库,然而今天并没有成功。

    一、首先下载安装Python需要的第三方库:

    pip install pymongo

    在windows的命令行窗口中输入以上命令即可。

    二、然后通过引用此模块,就可以进行连接

    我今天的测试如下(没有成功)

    ```

    from pymongo import MongoClient

    import _mty

    import _mf

    import _mre

    import _cl

    def msgbox(info,titletext='孤荷凌寒的对话框QQ578652607',style=0,isShowErrMsg=False):

        return _mty.msgboxGhlh(info,titletext,style,isShowErrMsg)

    def firstConnect():

        #--指明数据库服务器的地址与端口号:

        strhost='cluster0-zr7xj.mongodb.net'

        intport=27017

        #--建立连接

        client=MongoClient(strhost)

        #--获取连接中的数据库(通过数据库的命名空间获取)

        db=client['admin']

        #-- 准备当前命名空间对应的数据库的权限用户名和对应授权密码

        stru=_mf.readAllTextFromTxtFileGhlh('u.txt')

        strp=_mf.readAllTextFromTxtFileGhlh('p.txt')

        db2=client['ghlhfirst']

        #--登录数据库

        db2.authenticate(stru,strp)

        #--获取其中的一个集合对象

        jh=db2['ghlhone']

        #--获取其中的文档

        #--获取全部文档

        docall=jh.find()

        msgbox(str(docall))

    firstConnect()

    ```

    运行报错:

    Traceback (most recent call last):

      File "i:MAKEAPPpythonPython365边学习边测试文件夹自学PYTHON部分057第五十七天访问mongodb数据库3 rymongodbfirst.py", line 34, in <module>

        firstConnect()

      File "i:MAKEAPPpythonPython365边学习边测试文件夹自学PYTHON部分057第五十七天访问mongodb数据库3 rymongodbfirst.py", line 26, in firstConnect

        db2.authenticate(stru,strp,mechanism='MONGODB-CR')

      File "G:w10_1pythonpython365libsite-packagespymongodatabase.py", line 1274, in authenticate

        connect=True)

      File "G:w10_1pythonpython365libsite-packagespymongomongo_client.py", line 609, in _cache_credentials

        writable_preferred_server_selector)

      File "G:w10_1pythonpython365libsite-packagespymongo opology.py", line 224, in select_server

        address))

      File "G:w10_1pythonpython365libsite-packagespymongo opology.py", line 183, in select_servers

        selector, server_timeout, address)

      File "G:w10_1pythonpython365libsite-packagespymongo opology.py", line 199, in _select_servers_loop

        self._error_message(selector))

    pymongo.errors.ServerSelectionTimeoutError: cluster0-zr7xj.mongodb.net:27017: [Errno 11001] getaddrinfo failed

    PS I:MAKEAPPpythonPython365边学习边测试文件夹自学PYTHON部分057第五十七天访问mongodb数据库3> cd 'i:MAKEAPPpythonPython365边学习边测试文件夹自学PYTHON部分057第五十七天访问mongodb数据库3'; ${env:PYTHONIOENCODING}='UTF-8'; ${env:PYTHONUNBUFFERED}='1'; & 'G:w10_1pythonpython365python.exe' 'c:Userspw.vscodeextensionsms-python.python-2018.7.1pythonFilesPythonToolsvisualstudio_py_launcher.py' 'i:MAKEAPPpythonPython365边学习边测试文件夹自学PYTHON部分057第五十七天访问mongodb数据库3' '56500' '34806ad9-833a-4524-8cd6-18ca4aa74f14' 'RedirectOutput,RedirectOutput' 'i:MAKEAPPpythonPython365边学习边测试文件夹自学PYTHON部分057第五十七天

    访问mongodb数据库3 rymongodbfirst.py'

    Traceback (most recent call last):

      File "i:MAKEAPPpythonPython365边学习边测试文件夹自学PYTHON部分057第五十七天访问mongodb数据库3 rymongodbfirst.py", line 34, in <module>

        firstConnect()

      File "i:MAKEAPPpythonPython365边学习边测试文件夹自学PYTHON部分057第五十七天访问mongodb数据库3 rymongodbfirst.py", line 26, in firstConnect

        db2.authenticate(stru,strp)

      File "G:w10_1pythonpython365libsite-packagespymongodatabase.py", line 1274, in authenticate

        connect=True)

      File "G:w10_1pythonpython365libsite-packagespymongomongo_client.py", line 609, in _cache_credentials

        writable_preferred_server_selector)

      File "G:w10_1pythonpython365libsite-packagespymongo opology.py", line 224, in select_server

        address))

      File "G:w10_1pythonpython365libsite-packagespymongo opology.py", line 183, in select_servers

        selector, server_timeout, address)

      File "G:w10_1pythonpython365libsite-packagespymongo opology.py", line 199, in _select_servers_loop

        self._error_message(selector))

    pymongo.errors.ServerSelectionTimeoutError: cluster0-zr7xj.mongodb.net:27017: [Errno 11001] getaddrinfo failed

    经过近一个小时反复搜索查找资料,还是没有成功,而同样的情况下,通过compass客户端却能够连接上。

    因为学习时间有限,今天的学习只能搁到这儿,还恳请高手能够指点迷津,万分感激。

    ——————————

    今天整理的学习笔记完成,最后例行说明下我的自学思路:

    根据过去多年我自学各种编程语言的经历,认为只有真正体验式,解决实际问题式的学习才会有真正的效果,即让学习实际发生。在2004年的时候我开始在一个乡村小学自学电脑 并学习vb6编程语言,没有学习同伴,也没有高师在上,甚至电脑都是孤岛(乡村那时还没有网络),有的只是一本旧书,在痛苦的自学摸索中,我找到适应自己零基础的学习方法:首先是每读书的一小节就作相应的手写笔记,第二步就是上机测试每一个笔记内容是否实现,其中会发现书中讲的其实有出入或错误,第三步就是在上机测试之后,将笔记改为电子版,形成最终的修订好的正确无误的学习笔记 。

    通过反复尝试错误,在那个没有分享与交流的黑暗时期我摸黑学会了VB6,尔后接触了其它语言,也曾听过付费视频课程,结果发现也许自己学历果然太低,就算是零基础的入门课程,其实也难以跟上进度,讲师的教学多数出现对初学者的实际情况并不了解的情况,况且学习者的个体也存在差异呢?当然更可怕的是收费课程的价格往往是自己难以承受的。

    于是我的所有编程学习都改为了自学,继续自己的三步学习笔记法的学习之路。

    当然自学的最大问题是会走那么多的弯路,没有导师直接输入式的教学来得直接,好在网络给我们带来无限搜索的机会,大家在网络上的学习日志带给我们共享交流的机会,而QQ群等交流平台、网络社区的成立,我们可以一起自学,互相批评交流,也可以获得更有效,更自主的自学成果。

    于是我以人生已过半的年龄,决定继续我的编程自学之路,开始学习python,只希望与大家共同交流,一个人的独行是可怕的,只有一群人的共同前进才是有希望的。

    诚挚期待您的交流分享批评指点!欢迎联系我加入从零开始的自学联盟。

    这个时代互联网成为了一种基础设施的存在,于是本来在孤独学习之路上的我们变得不再孤独,因为网络就是一个新的客厅,我们时刻都可以进行沙龙活动。

    非常乐意能与大家一起交流自己自学心得和发现,更希望大家能够对我学习过程中的错误给予指点——是的,这样我就能有许多免费的高师了——这也是分享时代,社区时代带来的好福利,我相信大家会的,是吧!

    根据完全共享的精神,开源互助的理念,我的个人自学录制过程是全部按4K高清视频录制的,从手写笔记到验证手写笔记的上机操作过程全程录制,但因为4K高清文件太大均超过5G以上,所以无法上传至网络,如有需要可联系我QQ578652607对传,乐意分享。上传分享到百度网盘的只是压缩后的720P的视频。

    我的学习过程录像百度盘地址分享如下:(清晰度:1280x720)

    链接:https://pan.baidu.com/s/1DSXmIRCkyW05R9viASFWYw

    提取码:e1we 

    欢迎大家添加我为好友: QQ: 578652607
  • 相关阅读:
    CDH 2、Cloudera Manager的安装
    204 01 Android 零基础入门 03 Java常用工具类 04 Java集合 04 Map集合 01 Map概述
    203 01 Android 零基础入门 03 Java常用工具类 04 Java集合 03 Set集合 07 删除宠物猫信息数据(引入泛型知识点)
    202 01 Android 零基础入门 03 Java常用工具类 04 Java集合 03 Set集合 06 查找宠物猫信息数据
    201 01 Android 零基础入门 03 Java常用工具类 04 Java集合 03 Set集合 05 添加重复的宠物猫信息数据
    200 01 Android 零基础入门 03 Java常用工具类 04 Java集合 03 Set集合 04 添加和显式宠物猫信息
    199 01 Android 零基础入门 03 Java常用工具类 04 Java集合 03 Set集合 03 宠物猫信息管理概述
    198 01 Android 零基础入门 03 Java常用工具类 04 Java集合 03 Set集合 02 案例:在集合中插入字符串
    197 01 Android 零基础入门 03 Java常用工具类 04 Java集合 03 Set集合 01 Set概述
    196 01 Android 零基础入门 03 Java常用工具类 04 Java集合 02 List集合 05 案例:公告的删除和修改
  • 原文地址:https://www.cnblogs.com/lhghroom/p/10217325.html
Copyright © 2011-2022 走看看