zoukankan      html  css  js  c++  java
  • Ununtu 15.04 安装MySql(Django连接Mysql)

    本文介绍Ubuntu 15.04下安装MySQL

    • ubuntu 15.04安装mysql
    • django项目连接mysql

    一.安装数据库

    1.sudo apt-get install mysql-server   

    2.apt-get install client

    3.sudo apt-get install libmysqlclient-dev

    安装过程中会提示输入用户密码,输入即可。

    sudo netstat -tap | grep mysql

    检查mysql是否安装成功,如下显示就是安装成功了。

    mingwei@mingwei:~$ sudo netstat -tap | grep mysql  
    [sudo] password for mingwei:   
    tcp        0      0 localhost:mysql         *:*                     LISTEN      23411/mysqld      
    mingwei@mingwei:~$   

    4.mysql -u root -p 

       进入数据库, -u是用户名,这里是root用户,-p是密码

    5.show databases;

       查看所有数据库  结尾出有 “;”

    6.use databasename

       使用制定的库文件  databasename是数据库名

    7.show tables;

       列出所有表  结尾出有 “;”

    8.create database databasename

       创建一个库,databasename是库名

    9.create database databasename default character set utf8 collate utf8_general_ci;

    CREATE DATABASE databasename CHARACTER SET utf8; (推荐用这条命令)

    创建一个库字符集编码为utf-8,databasename是库名

    10. mysqldump -uroot -proot -d mfor > mfor.sql

    将库导成.sql文件 -uroot 用户名 -proot密码 mfor 库的名字

    安装PyMysql 库

    在相应位置加入

    10.drop database databasename;

    删除数据库,databasename是库名

    11.use databasename;

         show tables;

         use使用某一个库,show tables为展示这个库里面所有的表,databasename是库名。

    12mac mysql error You must reset your password using ALTER USER statement before executing this statement. (mac下mysql错误)

    安装完mysql 之后,登陆以后,不管运行任何命令,总是提示这个

    step 1: SET PASSWORD = PASSWORD('your new password');

    step 2: ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;

    step 3: flush privileges;

    完成以上三步退出再登,使用新设置的密码就行了,以上除了红色的自己修改成新密码外,其他原样输入即可

    mac 登录mysql

    http://jingyan.baidu.com/article/48a42057e2b2b9a9242504a2.html

    创建好之后测试看库有没有,第二部分我们使用django来连接这个库试试。

    二.连接数据库

    接下来我们在web项目中测试连接mysql

    1.在django项目的app下的的models.py下编写项目的model,然后django自身的ORM会读取这些model,并在数据库中创建相应的表,字段。

    我们写的例子如下:

    from django.db import models  
      
    # Create your models here.  
    class blogPost(models.Model):  
        blog_title=models.CharField(max_length=150)  
        blog_body=models.TextField()  
        blog_timestamp=models.DateTimeField()  


    2.在web项目下的settings.py下面配置mysql数据库的连接参数

    DATABASES = {  
        'default': {  
            'ENGINE': 'django.db.backends.mysql',  #默认  
            'NAME': 'mysite',  #mysql的库名称
            'USER': 'root',   #用户名
            'PASSWORD': '123456', #密码  
            'HOST': '127.0.0.1',   #默认
            'PORT': '3306',   #默认
        }  
    }  

    3.测试连接数据库

    Python manage.py check

    如果是这样:数据库连接失败了,查看结尾的提示,No module named MySqldb,

    mingwei@mingwei:~/mysite$ python manage.py check  
    Traceback (most recent call last):  
      File "manage.py", line 10, in <module>  
        execute_from_command_line(sys.argv)  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/core/management/__init__.py", line 338, in execute_from_command_line  
        utility.execute()  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/core/management/__init__.py", line 312, in execute  
        django.setup()  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/__init__.py", line 18, in setup  
        apps.populate(settings.INSTALLED_APPS)  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/apps/registry.py", line 108, in populate  
        app_config.import_models(all_models)  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/apps/config.py", line 198, in import_models  
        self.models_module = import_module(models_module_name)  
      File "/usr/lib/python2.7/importlib/__init__.py", line 37, in import_module  
        __import__(name)  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/contrib/auth/models.py", line 41, in <module>  
        class Permission(models.Model):  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/db/models/base.py", line 139, in __new__  
        new_class.add_to_class('_meta', Options(meta, **kwargs))  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/db/models/base.py", line 324, in add_to_class  
        value.contribute_to_class(cls, name)  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/db/models/options.py", line 250, in contribute_to_class  
        self.db_table = truncate_name(self.db_table, connection.ops.max_name_length())  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/db/__init__.py", line 36, in __getattr__  
        return getattr(connections[DEFAULT_DB_ALIAS], item)  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/db/utils.py", line 240, in __getitem__  
        backend = load_backend(db['ENGINE'])  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/db/utils.py", line 111, in load_backend  
        return import_module('%s.base' % backend_name)  
      File "/usr/lib/python2.7/importlib/__init__.py", line 37, in import_module  
        __import__(name)  
      File "/home/mingwei/.local/lib/python2.7/site-packages/django/db/backends/mysql/base.py", line 27, in <module>  
        raise ImproperlyConfigured("Error loading MySQLdb module: %s" % e)  
    django.core.exceptions.ImproperlyConfigured: Error loading MySQLdb module: No module named MySQLdb  

    缺少python连接数据的库,我们需要安装一下:

    在虚拟环境下安装

    pip install python-mysqldb

    有可能在python3下提示安装pymysql==0.7.11

    pymysql的用法与MySQLdb完全相同,只要记得在新建项目下面的_init__.py文件中添加如下代码就可以了~:

    import pymysql
    pymysql.install_as_MySQLdb()

    安装完之后再测试,如果不报错就说明安装成功了。

    4.根据我我们编写的model来生成数据库

    python manage.py syncdb

    mingwei@mingwei:~/mysite$ python manage.py syncdb  
    /home/mingwei/.local/lib/python2.7/site-packages/django/core/management/commands/syncdb.py:24: RemovedInDjango19Warning: The syncdb command will be removed in Django 1.9  
      warnings.warn("The syncdb command will be removed in Django 1.9", RemovedInDjango19Warning)  
      
    Operations to perform:  
      Synchronize unmigrated apps: staticfiles, messages  
      Apply all migrations: admin, contenttypes, auth, sessions  
    Synchronizing apps without migrations:  
      Creating tables...  
        Running deferred SQL...  
      Installing custom SQL...  
    Running migrations:  
      Rendering model states... DONE  
      Applying contenttypes.0001_initial... OK  
      Applying auth.0001_initial... OK  
      Applying admin.0001_initial... OK  
      Applying contenttypes.0002_remove_content_type_name... OK  
      Applying auth.0002_alter_permission_name_max_length... OK  
      Applying auth.0003_alter_user_email_max_length... OK  
      Applying auth.0004_alter_user_username_opts... OK  
      Applying auth.0005_alter_user_last_login_null... OK  
      Applying auth.0006_require_contenttypes_0002... OK  
      Applying sessions.0001_initial... OK  
      
    You have installed Django's auth system, and don't have any superusers defined.  
    Would you like to create one now? (yes/no): yes  
    Username (leave blank to use 'mingwei'):   
    Email address:   
    Password:   
    Password (again):   
    Error: Blank passwords aren't allowed.  
    Password:   
    Password (again):   
    Superuser created successfully.  

    生成了一大堆的东西,并且下面有successfully我都以为成功了,然后跑到mysql下去看,看到的是这样的,

    mysite的库确实生成了,但是表并没有生成:

    mysql> show databases;  
    +--------------------+  
    | Database           |  
    +--------------------+  
    | information_schema |  
    | mysite             |  
    | mysql              |  
    | performance_schema |  


    use mysite 进入库下面:

    show tables;列出所有表,发现只有一些用户表:奇了怪了,说好的orm自动生成呢?

    mysql> show tables;  
    +----------------------------+  
    | Tables_in_mysite           |  
    +----------------------------+  
    | auth_group                 |  
    | auth_group_permissions     |  
    | auth_permission            |  
    | auth_user                  |  
    | auth_user_groups           |  
    | auth_user_user_permissions |  
    | django_admin_log           |  
    | django_content_type        |  
    | django_migrations          |  
    | django_session             |  
    +----------------------------+  

    然后发现了是这个原因导致的,删掉你app项目下的 migrations文件夹,重新python manage.py syncdb,  哇。。。数据库奇迹般的生成了,,,,,如下表:bolg_bolgpost

    mysql> show tables;  
    +----------------------------+  
    | Tables_in_mysite           |  
    +----------------------------+  
    | auth_group                 |  
    | auth_group_permissions     |  
    | auth_permission            |  
    | auth_user                  |  
    | auth_user_groups           |  
    | auth_user_user_permissions |  
    | blog_blogpost              |  
    | django_admin_log           |  
    | django_content_type        |  
    | django_migrations          |  
    | django_session             |  
    +----------------------------+  
    11 rows in set (0.00 sec)  
  • 相关阅读:
    C 语言中字符的输入输出
    C 语言 ctype.h 中系列字符处理函数
    C 语言中 for 循环的几种用法
    C 中优先级和关系运算符
    字符串和格式化输入/输出 [printf & scanf]
    C++中关于string类的一些API总结
    两大基本数据类型
    这些时候的总结
    PL/SQL 十进制数转任意进制
    复现题目[CISCN 2019 华东北赛区 Web2 WriteUp](https://www.zhaoj.in/read-6100.html)的一些东西
  • 原文地址:https://www.cnblogs.com/zhaoyingjie/p/6866073.html
Copyright © 2011-2022 走看看