ジャンゴ構成モデルCRUD

ジャンゴ設定

静的な設定ファイル

  1. どのような静的ファイル:書き込みCSS、JS、サードパーティ製のフロントエンドモジュールに事前に使用、Webサイト、画像は静的リソースと呼ばれています

  2. デフォルトでは、すべてのHTMLファイルは、テンプレート上にあるフォルダ

  3. スタティックデフォルトファイルフォルダにあるすべてのWebサイトで使用される静的リソースファイル

    通常のように構築します別のフォルダ内の静的フォルダ:CSS、JS、フォント、IMG、ブートストラップ...

STATIC_URL = '/static/'  # 访问静态文件资源接口前缀  通常情况下接口前缀的名字也叫static
        # 手动开设静态文件访问资源
        STATICFILES_DIRS = [  # 静态资源所在的文件夹路径
            os.path.join(BASE_DIR,'static'),  # 将static文件里面所有的资源暴露给用户
            os.path.join(BASE_DIR,'static1'),  # 将static文件里面所有的资源暴露给用户
            # os.path.join(BASE_DIR,'static2'),  # 将static文件里面所有的资源暴露给用户
        ]
  1. 静的、動的バインディングファイル

    {% load static %}
         <link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}">
         <script src="{% static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script>

デフォルトでは、リクエストフォームフォームを取得することです

また、パラメータを運ぶことができるの要求を取得

http://127.0.0.1:8000/login/?username=jason&password=jason123
特点:url?xxx=xxx&yyy=yyy

1.携带的数据不安全
2.携带的数据大小有限制 最大好像应该差不多在4KB左右
3.通常只会携带一些不是很重要的数据

aciton

  1. 現在のアドレスに対するデフォルトの提出を書いてはいけません
  2. 書き込みのみ接尾辞/インデックス
  3. フルパスを書きます

前のケースの再提出要求が後端403に向かって表示され、設定ファイルの内容にラインアウトのコメントを取得する必要があります

# 中间件
        MIDDLEWARE = [
            'django.middleware.security.SecurityMiddleware',
            'django.contrib.sessions.middleware.SessionMiddleware',
            'django.middleware.common.CommonMiddleware',
            # 'django.middleware.csrf.CsrfViewMiddleware',
            'django.contrib.auth.middleware.AuthenticationMiddleware',
            'django.contrib.messages.middleware.MessageMiddleware',
            'django.middleware.clickjacking.XFrameOptionsMiddleware',
        ]
django后端的视图函数 默认处理的是get请求
        无论是发get请求还是post请求 都会执行视图函数

リクエストメソッドの知人

request.method:取得要求モード、および文字列を書くには、非常に純粋です

requesr.POST:取得ユーザーが要求データポストを提出します

ユーザデータを取得する方法

request.GET.get()#デフォルトでは、リストの最後の要素を取得します。

request.GET.getlist()#あなたが(GETLISTのリストを取得したい場合)

pycharmデータベース接続

MySQLへの接続ジャンゴ

二つの操作がなければなりません

1.配置文件配置
            DATABASES = {
                    'default': {
                        'ENGINE': 'django.db.backends.mysql',  # 指定数据库类型
                        'NAME': 'day49',  # 指定库的名字
                        'USER':'root',  # 注意 键必须是全大写
                        'PASSWORD':'123qwe',
                        'HOST':'127.0.0.1',
                        'PORT':3306,
                        'CHARSET':'utf8'
                    }
                }
2.主动告诉django 不要用默认的mysqldb连接 而是用pymysql
  你可以在项目名下的__init__.py中书写
  也可以在应用名下的__init__.py中书写
  pymysql.install_as_MySQLdb()

ジャンゴORMの紹介

orm 对象关系映射
        
        类           表
        
        对象         数据
        
        对象点属性   字段对应的值
        
        为什么使用orm
            能够让不会数据库操作的人也能够简单方便去操作数据库
        orm的缺点
            封装程度太高  有时候会出现查询效率偏低的问题
            所以工作中
                简单的用orm
                复杂的 追速度 需要你手动书写sql语句
                
之后在写django项目的时候 一个django就对应一个数据库
    不要出现多个项目使用同一个数据的情况(******)

欠失モデルチェンジ検索のフィールド

修正フィールド

直接修改代码 然后执行数据库迁移命令即可(两条一条不能少)
                # 方式1  设置默认值
                email = models.EmailField(default='[email protected]')  # varchar
                # 方式2   允许字段为空
                phone = models.BigIntegerField(null=True)
                # 直接在提示中给默认值
                gender = models.CharField(max_length=32)
python manage.py makemigrations
python manage.py migrate

削除フィールド

直接注释掉对应的字段 然后再执行数据库迁移命令即可(谨慎使用)

欠失はモデルチェンジの検索テーブルデータ

data = models.User.objects.filter(username=username)  # <QuerySet [<User: User object>]>
        """
        filter返回的结果是一个"列表",里面才是真正数据对象
        filer括号内可以放多个关键字参数 这多个关键字参数在查询的时候 是and关系
        """
        user_list = models.User.objects.all()  # models.User.objects.filter()
        """
        结果是一个"列表" 里面是一个个的数据对象
        """

増加

user_obj = models.User.objects.create(username=username,password=password)
        print(user_obj,user_obj.username,user_obj.password)
        # create方法会有一个返回值  返回值就是当前被创建的对象本身

変更

    models.User.objects.filter(id=edit_id).update(username=username,password=password)
        """
        批量操作  会将filter查询出来的列表中所有的对象全部更新
        """

削除された(通常の状況下で使用されません)

models.User.objects.filter(id=delete_id).delete()
        """
            批量操作  会将filter查询出来的列表中所有的对象全部删除
        """

おすすめ

転載: www.cnblogs.com/hj59988326/p/11914648.html