【技术博客】MySQL和Django常用操作

MySQL和Django是搭建网站常用的配置之一,在此记录一下在Windows系统搭建网站时MySQL以及Django常用的操作。

MySQL

MySQL的SQL语句不区分大小写,推荐将保留字大写,数据库名、表名、字段名等小写。

每条SQL语句必须以';'结尾,MySQL支持多行输入,直到识别到';'开始执行。

MySQL中table第一行行号为0。

系统操作

  • 启动服务

    net start mysql

    安装后MySQL只需启动一次即可

  • 登录

    在cmd中执行

    mysql -u root -p
  • 用户相关操作

    select host,user,authentication_string from mysql.user;//查询所有用户
    create user "username"@"host" identified by "password";//新建用户

databases相关操作

  • 显示所有数据库

    SHOW databases;
  • 创建数据库

    CREATE database xxx;
  • 删除数据库

    DROP database xxx;
  • 选择数据库,进入tables层级

    USE xxx;

tables相关操作

  • 显示所有table

    SHOW tables;
  • 新建table

    CREATE TABLE table_name(column1_name int NOT NULL AUTO_INCREMENT, column2_name char(50) NULL DEFAULT 1, PRIMARY KEY(column1_name))ENGINE=InnoDB;

    每个字段可以选择类型、是否可以为空、自增、默认值、是否为主键等。表格可以选择引擎。

  • 显示table数据

    SELECT * FROM table_name;//显示一个table内所有数据
    SELECT column1_name, column2_name FROM table_name;//显示某几列
    SELECT * FROM table_name ORDER BY column1_name, column2_name;//以某几列为顺序展示table
    SELECT * FROM table_name ORDER BY column1_name DESC,column2_name;//以某几列为倒序展示table
    SELECT DISTINCT column1_name FROM table_name;//对某列去重后输出
    SELECT * FROM table_name (ORDER BY column1_name) LIMIT a, b;//排序后展示第a+1行开始的b行
    SELECCT * FROM table_name WHERE column1_name=a AND (column2_name<=3 OR column3_name IN (3,4,5));//查找第一列为a,第二列小于等于3或第三列为3或4或5的词
    SELECT column1_name FROM table_name WHERE column1_name LIKE 'xyz%';//某列中以xyz开头词
    SELECT column1_name FROM table_name WHERE column1_name LIKE 'xyz_';//某列中以xyz开头+1个字符的词
    SELECT column1_name FROM table_name WHERE column1_name REGEXP '.000';//REGEXP后加正则
  • 计算字段

    SELECT Concnt(column1_name, '(', column2_name, ')') FROM table_name ORDER BY column1_name;//拼接a(b)的形式
    SELECT Concnt(column1_name, '(', RTrim(column2_name), ')') FROM table_name ORDER BY column1_name;//删除最右边所有空格,LTrim()删除最左边所有空格
    SELECT Concnt(column1_name, '(', Upper(column2_name), ')') FROM table_name ORDER BY column1_name;//全部大写
  • 数据汇总

    SELECT AVG(column1_name) FROM table_name AS name;//获取一列平均值
    SELECT COUNT(*) FORM table_name;//统计行数
    SELECT AVG(column1_name) AS name1, MIN(column2_name) AS name2 FROM table_name;//最小值
  • 连接表

    SELECT column1_name, column2_name, column3_name FROM table1_name, table2_name WHERE table1_name.column1_name = table2_name.column1_name';
  • 更新

    INSERT INTO table_name[(column1_name, column2_name…… )] VALUES(1,2……),(3,4……);
    INSERT INTO table_name(column1_name, column2_name……) SELECT column3_name, column4_name…… FROM table2_name;//插入行
    
    ALTER TABLE table_name ADD column1_name int;//增加列
    
    ALTER TABLE table_name DROP COLUMN column1_name;//删除列
    
    UPDATE table_name SET column1_name=word, column2_name=word WHERE column3_name=word;//更新数据
    
    DELETE FROM table_name WHRER column1_name = word;//删除行
    
    TRUNCATE table_name;//清空
  • 索引和视图

    CREATE [UNIQUE][CLUSTER] INDEX index_name ON talbe_name(column1_name ASC, column2_name DESC);//创建索引
    
    DROP INDEX index_name;//删除索引
    
    CREATE VIEW view_name AS SELECT * FROM table_name WHERE what;//创建视图
    
    DROP VIEW view_name;//删除视图

Django

Django是基于Python的高级Web开发框架,支持python2.7及以上。一般使用Django2.0以上。

Django采用MTV模式,即models、templetes、views,分别控制模型(即数据库),模板(即前端),视图(即后端逻辑)。

创建项目和应用

  • 创建项目

    django-admin startproject xxx

    项目文件:

    manage.py:项目管理器

    wsgi.py:服务器网关接口

    urls.py:URL配置文件

    settings.py:总配置文件,可更换数据库

    __init__.py:声明模块

  • 创建应用

    python manage.py startapp xxx
    
    //在settings.py中的INSTALLED_APPS添加应用xxx

    应用文件:

    migrations:数据迁移模块

    admin.py:后台管理系统配置文件

    apps.py:当前应用配置

    models.py:数据模块

    test.py:自动化测试模块

    views.py:执行响应的逻辑代码

创建响应

//编辑views.py
from django.http import HttpResponse
def xxx(request):
    return HttpResponse("xxxx")

//编辑根urls.py
from django.urls import include
//添加path('xxx/', include('xxx.urls'))

//新建应用的urls.py
from django.urls import path
from . import views
urlpatterns = [
    path('xxx/', views.xxx)
]

编辑模板

//在app下创建templates文件夹,其下创建app名文件夹

//在内层文件夹下创建xxx.html

//在views.py中创建渲染函数
def xxx(request):
    return render(request, 'xxx.html', {'key':'value'})
//其中value可在html中用{{key}}方式显示,传递该字典类型的DTL到前端

连接MySQL

//在MySQL中建立database,推荐database名和项目名相同

//修改settings.py
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'database_name',
        'HOST': 'localhost',
        'PORT': '3306',
        'USER': 'root',
        'PASSWORD': 'xxx',
    }
}

//迁移数据,在cmd中执行
python manage.py makemigrations
python manage.py migrate

//修改项目__init__.py
import pymysql
pymysql.install_as_MySQLdb()

Django中操纵MySQL

//编辑views.py
from . import models

models.Article.objects.create(title=title) # 插入方法一

cur_ticket = models.ticket(title=title)
cur_ticket.save() # 插入方法二,此方法可以获得自增主键cur_ticket.id

article = models.Article.objects.get(title='') # 查询一个,在找不到或找到一个以上时会报错,可用try except判断
article = models.Article.objects.get(~Q(title=''))# 不等于
articles = models.Article.objects.filter(title='')# 查询多个,返回一个列表,通过[]取到
articles = models.Article.objects.filter(title__in='')# 查询结果为多个,且查询条件为列表
article = models.Article.objects.get(pk='') # 根据主码查询
articles = models.Article.objects.all() # 查询所有

models.Article.objects.filter(title='').update(content='a') # 更新

models.Article.objects.get(title='').delete() # 删除
models.Article.objects.all().delete() # 删除所有

常用指令

  • 启动项目

    python manage.py runserver [xxxx]端口可选,缺省默认8000
  • 增加admin管理员

    python manage.py createsuperuser
    
    //修改settings.py中LANGUAGE_CODE='zh_Hans'
    
    //修改admin.py
    from . import models
    admin.site.register(models.Article)
    
    访问localhost:8000/admin
  • 删除数据库

    migrations文件夹只留__init__.py
    
    //删除mysql里的database,创建空database:
    drop database xxx;
    create database xxx;
    
    //在django中重新迁移数据
    python manage.py makemigrations
    python manage.py migrate

转载于:https://www.cnblogs.com/stupidRJGC/p/10843910.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Django是一个开源的Web应用框架,使用Python语言开发。它简化了Web应用开发的过程,提供了许多便捷的功能和模块,使得开发人员能够更快速、高效地开发出符合需求的Web应用。 从入门到实践,学习Django开发需要掌握以下几个方面: 1. 环境搭建:首先需要安装PythonDjango的开发环境。可以通过pip命令安装Django,并搭建一个虚拟环境来管理项目。 2. 项目创建:使用Django的命令行工具创建一个新的Django项目。这将生成项目的基本结构和文件,包括配置文件和应用程序。 3. 数据库配置:在Django中使用数据库,需要在配置文件中设置数据库连接信息。可以选择常用的关系型数据库,如MySQL或SQLite。 4. URL配置:Django使用URL映射来处理用户的请求。在项目的URL配置文件中,将URL和对应的处理视图函数进行绑定。 5. 视图函数:Django的视图函数负责处理请求,并返回相应的响应。可以在视图函数中编写逻辑代码和业务逻辑。 6. 模板引擎:Django内置了强大的模板引擎,用于生成动态的HTML页面。可以在模板中使用Django提供的模板语法,包括变量、标签和过滤器等。 7. 表单处理:Django提供了方便的表单处理功能,可以用于处理用户输入的数据。可以根据需求创建自定义的表单类,并进行表单验证和处理。 8. 中间件:Django的中间件是位于请求和响应之间的处理组件,可以在请求处理过程中进行一些自定义操作,如身份验证、请求记录和缓存等。 9. 数据库操作Django提供了ORM(对象关系映射)工具,可以通过Python代码进行数据库操作,而不用直接编写SQL语句。 10. 部署上线:当开发完成后,需要将项目部署到生产环境中。可以选择合适的服务器和Web服务器,如Nginx和Apache,进行部署和配置。 通过学习以上内容,我们可以掌握Django的开发流程和常用模块的使用。通过实际的项目开发,可以深入理解Django的各个方面,并逐渐掌握高级的开发技术和扩展功能。 ### 回答2: Django是一个开源的Web应用框架,使用Python语言编写。它通过提供一组强大的工具和接口,帮助开发者快速构建高效、可扩展的Web应用程序。 从入门到实践,首先我们需要掌握Python语言的基础知识,了解Python的语法和常用库函数等。接着,我们可以开始学习Django框架的使用。 在学习过程中,我们需要熟悉Django的核心概念和组件,例如模型(Model)、视图(View)和模板(Template)等。模型用于定义数据结构,视图处理用户请求并返回响应,模板用于渲染动态页面。掌握这些基本概念后,我们可以开始进行实践。 实践中,我们可以开发一个典型的Web应用,如博客网站。首先,我们需要定义博客的数据结构,例如文章、作者和评论等。然后,我们可以创建相应的模型,并通过Django提供的数据库迁移工具生成数据库表格。 接着,我们可以编写视图函数来处理用户请求。例如,当用户访问博客首页时,我们可以查询数据库获取最新的文章列表,并通过模板渲染页面后返回给用户。当用户点击某篇文章时,我们可以根据文章的ID查询数据库,获取文章的详细内容并显示在页面上。 在开发过程中,我们可能还需要创建用户注册、登录和退出等功能。这时,我们可以使用Django提供的用户认证和管理模块,轻松实现这些功能。 最后,我们还可以通过Django的后台管理功能方便地管理数据。Django提供了一个自动生成的管理界面,我们可以通过简单的配置即可实现对数据的增删改查操作,而无需编写额外的代码。 总之,通过从入门到实践的学习和实践,我们可以掌握Django的开发技巧和典型模块的使用,从而能够快速开发出高效、可扩展的Python Django Web应用程序。 ### 回答3: Django是一个开放源代码的Python Web应用程序框架,它通过提供一个简单方便的开发环境,帮助开发人员快速构建高质量的Web应用程序。 从入门到实践,首先需要掌握一些基本的Python编程知识。Python具有简单易学的语法和丰富的标准库,对于初学者来说,上手较为容易。接下来,了解Django框架的设计理念和基本概念是必不可少的。Django采用了MVC(模型-视图-控制器)的架构模式,其中模型负责数据处理和存储,视图负责处理用户请求和渲染HTML模板,控制器负责协调模型和视图之间的交互。 在开发过程中,使用Django提供的典型模块是非常常见的。其中最重要的模块之一是ORM(对象关系映射),它能够将数据库中的数据映射为Python对象,并提供了一种直观的方式来操作数据库。ORM能够简化数据库操作,并提供了一致的API,使得开发更加高效和可维护。另外,Django的表单模块也是非常重要的,它能够帮助我们在Web应用程序中处理用户输入,并进行验证和数据清洗。表单模块提供了丰富的字段类型和验证器,使得表单开发更加简单和高效。 除了ORM和表单模块,Django还提供了许多其他有用的模块,例如身份认证和授权模块、缓存模块、国际化和本地化模块等等。这些模块能够帮助我们快速构建功能强大的Web应用程序。 在实践中,我们可以通过参考Django官方文档、教程和案例来学习开发技巧和最佳实践。同时,参与开源项目和与其他开发者交流也是非常重要的,可以提升自己的开发能力和不断学习新技术。 总之,通过学习Python编程基础、掌握Django框架的基本概念和典型模块,以及不断实践和参与开发社区,我们可以逐步提升自己的Django开发技能,从而构建出高质量的Web应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值