IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> SQLAlchemy Column对象中的default与server_default区别 -> 正文阅读

[大数据]SQLAlchemy Column对象中的default与server_default区别

在使用SQLAlchemy的业务中设置的更新时间的server_default不生效时查找原因做了以下测试:

  1. default与server_default同时设置时,default优先级高于server_default。(参考图中time_both_default字段,该字段生效的是default的utc日期字段,即表中数据为8:07,而不是数据库中默认的本地时间即16:07)
  2. default走SQLAlchemy的Python程序,打印出SQL语句的话,相当于向数据库表中该字段插入了default设置的默认值;(参考图中所有设置了default值的字段:int_default、bool_default、time_default、time_both_default,最终入库值均为default的设置值,并且在insert的sql语句中均有体现)
  3. 而设置了server_default则走MySQL表结构中设置的DEFAULT值,打印SQL语句的话,相当于插入时没有插入该字段;(参考图中bool_server_default,值为0,对应insert的sql语句中没有该字段,time_server_default值为数据库默认的本地时间16:07)
  4. 而如果既不设置default也不设置server_default时,如果该字段不给定值,打印SQL语句的话,那么相当于默认该字段插入了None/Null值,数据库中设置的DEFAULT不生效;(参考图中time_not_default字段,SQL语句插入了None值,数据库DEFAULT默认本地时间失效,值为Null)
  5. 而如果sever_default默认值与数据库DEFAULT默认值不一致时,以数据库danDEFALUT值为准,参考第3条,因为此时没有插入该字段,即SQLAlchemy的server_default失效。(参考图中int_server_default,数据库中默认值为NULL,SQLAlchemy模型设置为9,结果为null)

一张图说明以上5点

测试用代码:

#!/usr/bin/env python3
# -*- coding=utf-8 -*-

"""
SQLAlchemy Column对象default与server_default区别。
"""
from datetime import datetime

from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import text, Column, Integer, String, Boolean, DateTime
from sqlalchemy.orm import sessionmaker
from sqlalchemy import create_engine

Base = declarative_base()


class ColumnDefaultTest(Base):
    __tablename__ = 'column_default_test'

    id = Column(Integer, primary_key=True, autoincrement=True)
    name = Column(String(255), comment='名称')
    int_default = Column(Integer, default=10, comment='SQLAlchemy默认')
    int_server_default = Column(Integer, server_default=text("9"), comment='数据库默认')
    bool_default = Column(Boolean, default=1, comment='SQLAlchemy默认')
    bool_server_default = Column(Boolean, server_default=text("0"), comment='数据库默认')
    time_default = Column(DateTime, default=datetime.utcnow, comment='SQLAlchemy默认')
    time_not_default = Column(DateTime, comment='不设置默认值')
    time_server_default = Column(DateTime, server_default=text('CURRENT_TIMESTAMP'), comment='SQLAlchemy默认')
    time_both_default = Column(DateTime, default=datetime.utcnow, server_default=text('CURRENT_TIMESTAMP'), comment='同时默认')


# engine = create_engine('sqlite:///test_default.db', echo=True)
# Base.metadata.create_all(engine)

engine = create_engine('mysql+mysqldb://user:password@127.0.0.1:3306/data_base?charset=utf8mb4', echo=True)
session = sessionmaker(bind=engine)
db = session()
result = db.query(ColumnDefaultTest).all()
print(result)

insert_test = ColumnDefaultTest(name='默认值测试')
db.add(insert_test)
db.commit()

SQL建表语句:

CREATE TABLE `column_default_test` (
  `id` int NOT NULL AUTO_INCREMENT COMMENT 'id',
  `name` varchar(255) DEFAULT NULL COMMENT '名称',
  `int_default` int DEFAULT NULL COMMENT 'SQLAlchemy默认',
  `int_server_default` int DEFAULT NULL COMMENT '数据库默认',
  `bool_default` tinyint DEFAULT NULL COMMENT 'SQLAlchemy默认',
  `bool_server_default` tinyint DEFAULT 0 COMMENT '数据库默认',
  `time_default` datetime DEFAULT NULL COMMENT 'SQLAlchemy默认',
  `time_not_default` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'SQLAlchemy不设置默认值而数据库设置',
  `time_server_default` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '数据库默认',
  `time_both_default` datetime DEFAULT CURRENT_TIMESTAMP COMMENT 'SQLAlchemy与数据库同时设置默认',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB;

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-16 22:27:35  更:2022-03-16 22:29:59 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 17:37:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码