首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

“禁止用 select * 作为查询字段列表”落地指南

一、背景 《阿里巴巴 Java 开发手册》 MySQL 数据库部分,ORM 映射部分,谈到: 【强制】 在表查询中,一律不要使用 * 作为查询的字段列表,需要哪些字段必须明确写明。...SELECT email FROM user WHERE id = #{id} select> 正如手册上所说的,这种写法带来的好处是: 1)增加查询分析器解析成本。...【1】继续使用 UserDO 作为方法返回值: >: 省事,减少对象定义 >: 无法根据函数名或返回值明确知道哪些属性被赋值哪些属性没有被赋值。...反例: UserDO getUserDetailById(Long id) 这里的方法名是对 “用户详情页面需要字段”的业务描述,还是“用户全部字段”的描述?...正例: String getEmailById(Long id) UserSimpleDO getSimpleById(Long id) [1] 如果使用容易歧义的类通用化的函数名称,返回值是通用的

1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    “禁止用 select * 作为查询字段列表”落地指南

    一、背景 《阿里巴巴 Java 开发手册》 MySQL 数据库部分,ORM 映射部分,谈到: 【强制】 在表查询中,一律不要使用 * 作为查询的字段列表,需要哪些字段必须明确写明。..."> SELECT email FROM user WHERE id = #{id} select> 正如手册上所说的,这种写法带来的好处是: 1)增加查询分析器解析成本。...【1】继续使用 UserDO 作为方法返回值: >: 省事,减少对象定义 >: 无法根据函数名或返回值明确知道哪些属性被赋值哪些属性没有被赋值。...反例: UserDO getUserDetailById(Long id) 这里的方法名是对 “用户详情页面需要字段”的业务描述,还是“用户全部字段”的描述?...正例: String getEmailById(Long id) UserSimpleDO getSimpleById(Long id) [1] 如果使用容易歧义的类通用化的函数名称,返回值是通用的

    95610

    【自然框架】之通用权限(八):权限到字段(列表、表单、查询)

    8、 权限到列表(表单、查询) 9、 权限的验证 10、 资源方面的权限 11、 角色管理的程序(给客户用的) 12、 权限下放 13、 个性化设置 A、 【自然框架】之通用权限(外传):杂谈 列表...table>的HTML。...主要的目的就是显示数据。他和GridView相比,myGrid可以很方便的根据表里的数据绘制表头。如果用GridView的话也可以,只不过是要使用模板列,还要用到绑定数据的方式。...这个就比较复杂,目前我还没有完全掌握,所以我就采用了古老的asp的方式,拼接字符串。 权限到列表 这个和权限到节点是一个意思,就是加一个查询条件就可以了。我也不多说了。...表单 myForm 说实在的权限到表单的情况,到目前为止我还没有遇到。为什么加上了呢,主要是因为实现方式和前面的是一样的,只需要加上一个查询语句就可以了。 查询 mySearch 同理如上。

    98970

    MongoDB-_id字段的含义介绍

    MongoDB中的主键无需明确指定,每一条记录被添加到集合之后, MongoDB都会自动添加主键,MongoDB中文档主键的名称叫做 _id,是一个ObjectId类型的数据,格式如下: study...> db.user.find() [ { _id: ObjectId("62c44b4d5604b99daa91103e"), name: '小博' } ] 数一下_id这个字段的长度,我们发现一共有24...位,我们将_id字段的内容拆分成4部分去分别看其对应的含义: 62c44b4d 5604b9 9daa 91103e 1-8位字符:插入数据的时候对应的时间戳 9-14位字符:代表主机的唯一标识符...= 62c6fdb6e3a9741ea11d9883为例,1-8位为62c6fdb6,将16进制转换为1657208246,这个就是对应的数据插入的时间,转换为时间格式后为: _id字段虽然为系统自动生成的一个唯一标识...,但是,用户也可以自定义这个id的值: db.getCollection("user").insert({ "_id":"1", "name": "大刀王五", "age": 29

    1.1K20

    Django -- 如何优雅的提交表单

    前言 前面的内容我们基本上以 get请求作为例子,那 post请求Django是如何处理的呢?本章内容我们就来介绍Django如何发起和处理 post请求的。...{%csrf_token%} 是Django 用来防止跨站点请求伪造。Django 内部的POST表单都要如此。 视图 我们还要创建一个视图来实现这个新增cat 的功能。...Django 为此提出了一种较为简便的方法Form ,Django 中的表单有一下两个作用: 渲染表单模板 验证数据是否合法 下面我们来介绍下他的使用。...,且是必填的,最大长度为10, label='name_form' 的作用是渲染html 表单中字段为 name 的 label 为 name_form。...form.is_valid() 表示对POST请求中的数据按照当时定义表单字段时定义的规则校验。

    3.3K20

    Django的ORM字段类型-2

    模型类-字段选项 字段选项:指定创建的列的额外信息 允许出现多个字段选项,多个选项之间使用,隔开 primary key 如果设置为True,表示该列为主键,如果指定一个字段为主键,则此数据库不会创建...Id字段 blank 设置为True的时候,字段可以为空。...设置为False的时候字段是必须填写的 null 如果设置为True则表示该列允许为空....默认的情况下为False,如果不为空的话需要设置default来设置默认值 default 设置所在列的默认值,如果字段选项null=False的话建议添加此选项 db_index 如果设置为True表示为该列增加索引...unique 如果设置为True表示该字段在数据库中的值必须是唯一的(不能重复出现) db_column 指定列名称,如果不指定的话则采用属性名作为列名 verbose_name 设置此字段在admin

    66130

    Django 2.1.7 Admin - 注册模型、自定义显示列表字段

    Admin站点 内容发布的部分由网站的管理员负责查看、添加、修改、删除数据,开发这些重复的功能是一件单调乏味、缺乏创造力的工作,为此,Django能够根据定义的模型类自动地生成管理模块。...使用Django的管理模块,需要按照如下步骤操作: 1.管理界面本地化 2.创建管理员 3.注册模型类 4.自定义管理页面 1.管理界面本地化 本地化是将显示的语言、时间等使用本地的习惯,这里的本地化就是进行中国化...在列表页中点击"增加"可以进入增加页,Django会根据模型类的不同,生成不同的表单控件,按提示填写表单内容后点击"保存",完成数据创建,创建成功后返回列表页。...在列表页中点击某行的第一列可以进入修改页。 按照提示进行内容的修改,修改成功后进入列表页。在修改页点击“删除”可以删除一项。 删除:在列表页勾选想要删除的复选框,可以删除多项。...4.自定义管理页面 在列表页只显示出了ServerInfo object,对象的其它属性并没有列出来,查看非常不方便。Django提供了自定义管理页面的功能,比如列表页要显示哪些值。

    1.1K20

    Django 2.1.7 Admin管理后台 - 注册模型、自定义显示列表字段

    、添加、修改、删除数据,开发这些重复的功能是一件单调乏味、缺乏创造力的工作,为此,Django能够根据定义的模型类自动地生成管理模块。...使用Django的管理模块,需要按照如下步骤操作: 1.管理界面本地化 2.创建管理员 3.注册模型类 4.自定义管理页面 1.管理界面本地化 本地化是将显示的语言、时间等使用本地的习惯,这里的本地化就是进行中国化...在列表页中点击"增加"可以进入增加页,Django会根据模型类的不同,生成不同的表单控件,按提示填写表单内容后点击"保存",完成数据创建,创建成功后返回列表页。...在列表页中点击某行的第一列可以进入修改页。 按照提示进行内容的修改,修改成功后进入列表页。在修改页点击“删除”可以删除一项。 删除:在列表页勾选想要删除的复选框,可以删除多项。...4.自定义管理页面 在列表页只显示出了ServerInfo object,对象的其它属性并没有列出来,查看非常不方便。 Django提供了自定义管理页面的功能,比如列表页要显示哪些值。

    2.8K40

    37.Django1.11.6文档

    另一个方面,GET 适合网页搜索这样的表单,因为这种表示一个GET 请求的URL 可以很容易地作为书签、分享和重新提交。 Django在表单中的角色 处理表单是一件很复杂的事情。...还有一个参数: choices 用来作为该字段选项的一个二元组组成的可迭代对象(例如,列表或元组)或者一个可调用对象。 参数的格式与模型字段的choices 参数相同。...与模型验证的交互 作为验证过程的一部分,clean()将调用与表单字段对应的每个模型字段的ModelForm 方法。 ...(6)提供初始值 作为一个有参数的表单, 在实例化一个表单时可以通过指定initial字段来指定表单中数据的初始值. 这种方式指定的初始值将会同时替换掉表单中的字段和值. ...ModelAdmin.exclude 如果设置了这个属性,它表示应该从表单中去掉的字段列表。

    24.4K80

    django 1.8 官方文档翻译:5-1-4 内建的Widget

    Widgets Widget 是Django 对HTML 输入元素的表示。Widget 负责渲染HTML和提取GET/POST 字典中的数据。 小贴士 不要将Widget 与表单字段搞混淆。...表单字段负责验证输入并直接在模板中使用。Widget 负责渲染网页上HTML 表单的输入元素和提取提交的原始数据。但是,Widget 需要赋值给表单的字段。...指定Widget 每当你指定表单的一个字段的时候,Django 将使用适合其数据类型的默认Widget。若要查找每个字段使用的Widget,参见内建的字段文档。...假设表单myform 具有一个字段beatles,它使用RadioSelect 作为Widget: {% for radio in myform.beatles %} 的Widget 的Widget,用于值为一个列表的字段。 choices 当表单字段没有choices 属性时,这个属性是可选的。

    5K40
    领券