简单介绍Mysql的SQL服务器模式

mysql sql服务器模式
mysql服务器可以以不同的sql模式来操作,并且可以为不同客户端应用不同模式。这样每个应用程序可以根据自己的需求来定制服务器的操作模式。
模式定义mysql应支持哪些sql语法,以及应执行哪种数据验证检查。这样可以更容易地在不同的环境中使用mysql,并结合其它数据库服务器使用mysql。
你可以用–sql-mode=”modes”选项启动mysqld来设置默认sql模式。如果你想要重设,该值还可以为空(–sql-mode =””)。
你还可以在启动后用set [session|global] sql_mode=’modes’语句设置sql_mode变量来更改sql模式。设置global变量时需要拥有super权限,并且会影响从那时起连接的所有客户端的操作。设置session变量只影响当前的客户端。任何客户端可以随时更改自己的会话 sql_mode值。
modesis是用逗号(‘,’)间隔开的一系列不同的模式。你可以用select @@sql_mode语句查询当前的模式。默认值是空(没有设置任何模式)。
主要重要sql_mode值
・ansi
更改语法和行为,使其更符合标准sql。
・strict_trans_tables
如果不能将给定的值插入到事务表中,则放弃该语句。对于非事务表,如果值出现在单行语句或多行语句的第1行,则放弃该语句。本节后面给出了更详细的描述。
・traditional
make mysql的行为象“传统”sql数据库系统。该模式的简单描述是当在列中插入不正确的值时“给出错误而不是警告”。注释:一旦发现错误立即放弃insert/update。如果你使用非事务存储引擎,这种方式不是你想要的,因为出现错误前进行的数据更改不会“滚动”,结果是更新“只进行了一部分”。
本手册指“严格模式”,表示至少strict _trans_tables或strict _all_tables被启用的模式。
下面描述了支持的所有模式:
・allow_invalid_dates
在严格模式下不要检查全部日期。只检查1到12之间的月份和1到31之间的日。这在web应用程序中,当你从三个不同的字段获取年、月、日,并且想要确切保存用户插入的内容(不进行日期验证)时很重要。该模式适用于date和datetime列。不适合timestamp列,timestamp列需要验证日期。
启用严格模式后,服务器需要合法的月和日,不仅仅是分别在1到12和1到31范围内。例如,禁用严格模式时’2004-04-31’是合法的,但启用严格模式后是非法的。要想在严格模式允许遮掩固定日期,还应启用allow_invalid_dates。
・ansi_quotes
将‘”‘视为识别符引号(‘`’引号字符),不要视为字符串的引号字符。在ansi模式,你可以仍然使用‘`’来引用识别符。启用ansi_quotes后,你不能用双引号来引用字符串,因为它被解释为识别符。
・error_for_pision_by_zero
在严格模式,在insert或update过程中,如果被零除(或mod(x,0)),则产生错误(否则为警告)。如果未给出该模式,被零除时mysql返回null。如果用到insert ignore或update ignore中,mysql生成被零除警告,但操作结果为null。
・high_not_precedence
not使用mysql0的优先顺序是使用mysql1例如not a between b and c被解释为not (a between b and c)。在一些旧版本mysql中, 表达式被解释为(not a) between b and c。启用high_not_precedencesql模式,可以获得以前的更高使用mysql2的结果。

mysql> SET sql_mode = '';mysql> SELECT NOT 1 BETWEEN -5 AND 5;        -> 0mysql> SET sql_mode = 'broken_not';mysql> SELECT NOT 1 BETWEEN -5 AND 5;        -> 1

・IGNORE_SPACE
允许使用mysql3名和‘(‘之间有空格。强制将所有函数名视为保存的字。结果是,如果你想要访问保存为字的数据库、表或列名,你必须引用它。例如,因为有USER()函数,使用mysql4中的user表名和该表内的User列被保存下来,因此你必须引用它们:

SELECT "User" FROM mysql."user";

・NO_AUTO_CREATE_USER
防止GRANT自动创建新用户,除非还指定了密码。
・NO_AUTO_VALUE_ON_ZERO
NO_AUTO_VALUE_ON_ZERO影响AUTO_INCREMENT列的处理。一般情况,你可以向该列插入NULL或0生成下一个序列号。NO_AUTO_VALUE_ON_ZERO禁用0,因此只有NULL可以生成下一个序列号。
如果将0保存到表的AUTO_INCREMENT列,该模式会很有用。(不推荐采用该惯例)。例如,如果你用mysqldump转储表并使用mysql5,MySQL遇到0值一般会生成新的序列号,生成的表的内容与转储的表不同。重载转储文件前启用NO_AUTO_VALUE_ON_ZERO可以解决该问题。mysqldump在输出中自动包括启用NO_AUTO_VALUE_ON_ZERO的语句。
・NO_BACKSLASH_ESCAPES
禁用反斜线字符(‘’)做为字符串内的使用mysql6字符。启用该模式,反斜线则成为普通字符。
・NO_DIR_IN_CREATE
创建表时,忽视所有INDEX DIRECTORY和DATA DIRECTORY指令。该选项对从复制服务器有用。
・NO_ENGINE_SUBSTITUTION
如果需要的存储引擎被禁用或未编译,可以防止自动替换存储引擎。
・NO_FIELD_OPTIONS
不要在SHOW CREATE TABLE的输出中打印MySQL专用列选项。该模式在可移植模式(portability mode)下用于mysqldump。
・NO_KEY_OPTIONS
不要在SHOW CREATE TABLE的输出中打印MySQL专用使用mysql7选项。该模式在可移植模式(portability mode)下用于mysqldump。
・NO_TABLE_OPTIONS
不要在SHOW CREATE TABLE的输出中打印MySQL专用表选项(例如ENGINE)。该模式在可移植模式(portability mode)下用于mysqldump。
・NO_UNSIGNED_SUBTRACTION
在减运算中,如果某个操作数没有符号,不要将结果标记为UNSIGNED。请注意这样使UNSIGNED BIGINT不能100%用于上下文中。参见12.8节,“Cast函数和操作符”。
・NO_ZERO_DATE
在严格模式,不要将 ‘0000-00-00’做为合法日期。你仍然可以用IGNORE选项插入零日期。在非严格模式,可以接受该日期,但会生成警告。
・NO_ZERO_IN_DAT
在严格模式,不接受月或日部分为0的日期。如果使用IGNORE选项,我们为类似的日期插入’0000-00-00’。在非严格模式,可以接受该日期,但会生成警告。
・ONLY_FULL_GROUP_BY
不要让GROUP BY部分中的查询指向未选择的列。
・PIPES_AS_CONCAT
将||视为使用mysql8操作符(+)(同CONCAT()),而不视为OR。
・REAL_AS_FLOAT
将REAL视为FLOAT的同义词,而不是DOUBLE的同义词。
・STRICT_TRANS_TABLES
为所有存储引擎启用严格模式。非法数据值被拒绝。后面有详细说明。
・STRICT_TRANS_TABLES
为事务存储引擎启用严格模式,也可能为非事务存储引擎启用严格模式。后面有详细说明。
严格模式控制MySQL如何处理非法或丢失的输入值。有几种原因可以使一个值为非法。例如,使用mysql9错误,不适合列,或超出范围。当新插入的行不包含某列的没有显示定义DEFAULT子句的值,则该值被丢失。
对于事务表,当启用STRICT_ALL_TABLES或STRICT_TRANS_TABLES模式时,如果语句中有非法或丢失值,则会出现错误。语句被放弃并滚动。
对于非事务表,如果插入或更新的第1行出现坏值,两种模式的行为相同。语句被放弃,表保持不变。如果语句插入或修改多行,并且坏值出现在第2或后面的行,结果取决于启用了哪个严格选项:
・对于STRICT_ALL_TABLES,MySQL返回错误并忽视剩余的行。但是,在这种情况下,前面的行已经被插入或更新。这说明你可以部分更新,这可能不是你想要的。要避免这点,最好使用单行语句,因为这样可以不更改表即可以放弃。
・对于STRICT_TRANS_TABLES,MySQL将非法值转换为最接近该列的合法值并插入调整后的值。如果值丢失,MySQL在列中插入隐式 默认值。在任何情况下,MySQL都会生成警告而不是给出错误并继续执行语句。13.1.5节,“CREATE TABLE语法”描述了隐式默认值。
严格模式不允许非法日期,例如’2004-04-31’。它不允许禁止日期使用“零”部分,例如’2004-04-00’或“零”日期。要想禁止,应在严格模式基础上,启用NO_ZERO_IN_DATE和NO_ZERO_DATE SQL模式。
如果你不使用严格模式(即不启用STRICT_TRANS_TABLES或STRICT_ALL_TABLES模式),对于非法或丢失的值,MySQL将插入调整后的值并给出警告。在严格模式,你可以通过INSERT IGNORE或UPDATE IGNORE来实现。参见13.5.4.22节,“SHOW WARNINGS语法”。

Giiso写作机器人 Giiso写作机器人

Giiso写作机器人,让写作更简单

Giiso写作机器人 56 查看详情 Giiso写作机器人 <!–

简单介绍Mysql的SQL服务器模式

–>

以上就是简单介绍Mysql的SQL服务器模式的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/416758.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 01:36:51
下一篇 2025年11月7日 01:40:31

相关推荐

  • PHP 函数参数绑定在组合函数中的应用?

    php参数绑定在组合函数中通过将变量绑定到查询中的命名参数,可以防止sql注入并提高效率。具体步骤包括:创建数据库连接。准备一个带有命名参数的查询。使用bindparam方法绑定变量到参数。执行查询。获取结果或更新记录数。 PHP 参数绑定在组合函数中的用法 参数绑定是一种节省资源的技术,它可以防止…

    2025年12月9日
    000
  • 不同数据库系统中参数绑定的实现有何异同?

    不同数据库系统中,参数绑定实现的差异主要体现在:参数占位符:常见占位符为问号;准备语句:用于优化查询执行,在准备阶段提供参数值;类型化:不同系统对参数类型化处理不同,有的强制执行,有的允许动态绑定;sql 执行:系统通过匹配参数值和占位符进行操作,处理空值和越界值策略也有差异。 不同数据库系统中参数…

    2025年12月9日
    000
  • 参数绑定在 PHP 代码测试中的作用

    php 单元测试中,参数绑定可增强代码可读性、可维护性和可靠性。它通过使用占位符将输入数据与查询分开,防止 sql 注入攻击,并简化查询更新和维护。 参数绑定在 PHP 代码测试中的作用 引言 参数绑定是一个在 PHP 单元测试中管理数据库交互的宝贵工具。它通过使用占位符将输入数据与查询分开,从而增…

    2025年12月9日
    000
  • PHP 函数参数绑定的目的和作用?

    PHP 函数参数绑定的目的和作用 目的 参数绑定是允许在执行 SQL 查询时动态传递参数的一种技术。它的目的是提高安全性、性能和灵活性。 作用 立即学习“PHP免费学习笔记(深入)”; PHP 函数参数绑定主要用于: 防止 SQL 注入漏洞:通过将参数值与 SQL 查询分开,它可以防止攻击者在输入中…

    2025年12月9日
    000
  • 保护 PHP 应用程序免受 SQL 注入攻击

    阻止 sql 注入攻击对于维护 php 应用程序的安全至关重要。 sql 注入是一个漏洞,允许攻击者在您的数据库上执行任意 sql 代码,可能导致数据泄露或丢失。这是防止 php 中 sql 注入攻击的分步指南,配有实践示例和说明。 1.了解 sql 注入 当用户输入未正确清理并合并到 sql 查询…

    2025年12月9日
    000
  • 使用迁移在 Laravel 中进行数据库架构管理:深入教程

    laravel 迁移是管理数据库架构更改的好方法。它们允许您对数据库结构进行版本控制,并随时间轻松回滚或修改更改。在本指南中,我们将逐步探索在 laravel 中创建、运行和回滚迁移的过程,并提供一个实践示例。 第 1 步:设置 laravel 环境 开始迁移之前,请确保已安装 laravel。您可…

    2025年12月9日
    000
  • PHP 函数参数绑定的最佳实践?

    PHP 函数参数绑定的最佳实践 什么是参数绑定? 参数绑定是一种将值传递给函数参数的技巧,它可以防止 SQL 注入攻击。它涉及在 SQL 查询中使用占位符,然后使用一个单独的过程将值绑定到这些占位符。 最佳实践 立即学习“PHP免费学习笔记(深入)”; 总是使用参数绑定:为函数参数指定值时,使用参数…

    2025年12月9日
    000
  • PHP 参数绑定与 PDO 的关系

    PHP 参数绑定与 PDO 的关系 参数绑定是 PHP 数据对象 (PDO) 中一项重要的功能,它允许我们在执行查询之前将参数传递给 SQL 语句。通过使用参数绑定,我们可以防止 SQL 注入攻击,并提高代码的可读性和可维护性。 如何使用参数绑定 要使用参数绑定,我们需要使用 PDO::prepar…

    2025年12月9日
    000
  • PHP 参数绑定与 SQL 注入的关联

    PHP 参数绑定与 SQL 注入的关联 什么是参数绑定? 参数绑定是一种数据库安全实践,通过占位符将外部数据传送到 SQL 查询中。它可以防止 SQL 注入攻击,后者是攻击者通过未经验证的数据注入恶意代码到数据库的攻击类型。 如何使用参数绑定? 使用 PHP mysqli 扩展执行参数绑定: 立即学…

    2025年12月9日
    000
  • 回答:我如何运行特定的phinx seeder并在phpunit中获取生成的记录?

    这个答案解决了我遇到的一个问题:在 phpunit 上运行 phinx 播种机: 回复回复:我如何运行特定的phinx seeder并获取phpunit中生成的记录? 2024 年 9 月 12 日 0 我有一个像你提到的情况,我需要在单元测试中在 mysql 数据库上运行播种器,因此我执行了以下步…

    2025年12月9日
    000
  • PHP 参数绑定的未来发展趋势

    php 参数绑定未来发展趋势:增强类型安全,支持更严格的类型检查。扩展兼容性,与更多数据库保持兼容。性能优化,提升查询性能。无缝集成框架,方便不同环境下使用。 PHP 参数绑定的未来发展趋势 参数绑定是一种安全并高效地将用户输入或其他数据传递给 SQL 查询的机制。在 PHP 中,参数绑定主要通过 …

    2025年12月9日
    000
  • PHP 函数中如何使用返回值进行分页处理?

    php 分页函数通过返回值实现分页:显示当前页数据(使用 $results)。创建页面导航(使用 $total_pages)。控制分页参数(如 $page、$per_page、$total_count)。 PHP 函数中使用返回值进行分页处理 分页是一种在大型数据集上很常见的技术,它将数据分成较小的…

    2025年12月9日
    000
  • PHP 函数参数绑定中错误处理和异常机制?

    php函数参数绑定中的错误处理涉及错误消息获取(使用mysqli_stmt_error()),而异常机制通过mysqli_stmt_set_exception()设置异常处理器,并在错误发生时抛出mysqli_sql_exception异常,可通过try-catch块捕获。 PHP 函数参数绑定中的…

    2025年12月9日
    000
  • 如何使用 PHP 函数来操作数据库

    使用 PHP 函数操作数据库 PHP 提供了强大的函数库,可以轻松高效地与数据库交互。本文将指导您了解如何使用 PHP 函数执行常见数据库操作,并附有实战案例。 连接数据库 connect_error) { die(“连接失败:” . $conn->connect_error);}?> …

    2025年12月9日
    000
  • Ubuntu 中 Laravel 安装步骤

    要在新的 ubuntu 中设置 laravel,请按照以下步骤操作: 步骤一:更新升级系统包 运行以下命令来更新系统的软件包列表并升级已安装的软件包: sudo apt updatesudo apt upgrade 第 2 步:安装 apache(或 nginx) 对于 web 服务器,您可以选择 …

    2025年12月9日
    000
  • 为什么要在 Laravel 中实现存储库模式?

    laravel 中的存储库模式简介 存储库模式是一种设计模式,用于管理数据访问逻辑并将其集中在一个地方。这种模式有助于将检索和保存数据的逻辑与业务逻辑分开,使代码库更加模块化、可重用和可测试。 在 laravel 中,存储库模式可用于抽象与数据模型(如 eloquent 模型)的交互,使您的代码随着…

    2025年12月9日
    000
  • 使用 Filament 和 Laravel 构建强大的管理面板:分步指南

    laravel 是一个强大的 php 框架,为开发 web 应用程序提供了坚实的基础。 filament 是一个开源、优雅的 laravel 管理面板和表单构建器,可简化管理界面的创建。本指南将引导您使用最新版本的 filament 和 laravel 构建强大的管理面板。 laravel saas…

    2025年12月9日
    000
  • 关于 PHP 代码安全性您应该了解的内容

    在 web 开发方面,php 是一种广泛使用的脚本语言。随着 php 的流行,了解与 php 相关的潜在安全风险以及缓解这些风险的措施至关重要。无论您使用 wordpress 部署 cms 应用程序还是使用 laravel php 框架构建企业应用程序,php 安全性的重要性以及一些值得注意的 ph…

    2025年12月9日
    000
  • 在本地系统上安装 WordPress 并将 WordPress 主题与 XAMPP 结合使用

    是的,您可以使用 XAMPP 在本地系统上安装 WordPress,然后像在实时服务器上一样安装和使用 WordPress 主题。这是帮助您入门的分步指南: 1。安装 XAMPP下载 XAMPP: 前往 XAMPP 网站并下载适合您操作系统的安装程序。 安装 XAMPP: 运行安装程序并按照屏幕上的…

    2025年12月9日
    000
  • PHP 函数中可以使用哪些资源类型?

    php 中的资源类型是一种特殊的数据类型,用于表示指向外部资源(如文件、连接)的引用,支持文件句柄、流句柄、套接字、管道、数据库连接、gd 图像、xml 解析器和内存缓存。创建资源使用内置函数(如 fopen()、stream_socket_client()、mysqli_connect()),使用…

    2025年12月9日
    000

发表回复

登录后才能评论
关注微信