Mysql数据库中,设置id为自动增加,向数据库中插入数据时,SQL语句怎么写?

JSP操作Mysql数据库时,设置id为自动增加,向数据库中插入数据时,SQL语句是怎么写的?例如:表user中:有id  name &nb... JSP 操作Mysql数据库时,设置id为自动增加,向数据库中插入数据时,SQL语句是怎么写的?例如:表user中:有id   name   passwd三个属性,id为主键,并设置为自动增加的。插入数据时, insert into user values( ???? ); 这个语句是怎么写的?   展开
 我来答
请让我好好路过
2018-10-22 · TA获得超过6100个赞
知道答主
回答量:22
采纳率:0%
帮助的人:6320
展开全部

在建立表的时候设置id为自动增长的 [id] [int] IDENTITY (1, 1)

SQL语句是insert into  user(name,passwd) values (name  ,passwd)。新增一条数据 id 就会自动加1

INSERT INTO是sql数据库中的语句,可以用于向表格中插入新的行。

扩展资料

(1) 数据记录筛选:

sql="select * from 数据表 where字段名=字段值 order by字段名[desc]"(按某个字段值降序排列。默认升序ASC)

sql="select * from 数据表 where字段名like '%字段值%' order by 字段名 [desc]"

sql="select top 10 * from 数据表 where字段名=字段值 order by 字段名 [desc]"

sql="select top 10 * from 数据表 order by 字段名 [desc]"

sql="select * from 数据表 where字段名in ('值1','值2','值3')"

sql="select * from 数据表 where字段名between 值1 and 值2"

(2) 更新数据记录:

sql="update 数据表 set字段名=字段值 where 条件表达式"

sql="update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式"

(3) 删除数据记录:

sql="delete from 数据表 where 条件表达式"

sql="delete from 数据表" (将数据表所有记录删除)

(4) 添加数据记录:

sql="insert into 数据表 (字段1,字段2,字段3 …) values (值1,值2,值3 …)"

sql="insert into 目标数据表 select * from 源数据表" (把源数据表的记录添加到目标数据表)

(5) 数据记录统计函数:

AVG(字段名) 得出一个表格栏平均值

COUNT(*;字段名) 对数据行数的统计或对某一栏有值的数据行数统计

MAX(字段名) 取得一个表格栏最大的值

MIN(字段名) 取得一个表格栏最小的值

SUM(字段名) 把数据栏的值相加

引用以上函数的方法:

sql="select sum(字段名) as 别名 from 数据表 where 条件表达式"

set rs=conn.excute(sql)

用 rs("别名") 获取统计的值,其它函数运用同上。

查询去除重复值:select distinct * from table1

(6) 数据表的建立和删除:

CREATE TABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度) …… )

(7) 单列求和:

SELECT SUM(字段名) FROM 数据表

参考资料——百度百科SQL insert into

爱可生云数据库
2020-05-26 · MySQL开源数据库领先者
爱可生云数据库
爱可生,金融级开源数据库和数据云服务整体解决方案提供商;优秀的开源数据库技术,企业级数据处理技术整体解决方案提供商;私有云数据库云服务市场整体解决方案提供商。
向TA提问
展开全部

随着 MySQL 8.0.16 的发布,我们为 MGR 添加了一些功能,以增强其高可用性。其中一个功能是能够在某些情况下启用已离开组的成员自动重新加入,而无需用户干预。

为了理解这个功能的好处以及如何使用它,我们将快速查看它背后的概念以及它首先存在的动机。


介绍

MGR 允许 MySQL 用户轻松管理高可用组,并完成保证系统高可用所需的所有特征,例如容错或故障检测。

MGR 中提供的基本保证之一是该组呈现给用户的是一个不可分割的整体,这意味着一旦成员加入或离开该组,该更改将立即被其他成员得知。默认情况下,组内的数据本身最终是一致的,尽管可以被修改。为了实现这种保证,MGR 使用组成员服务,以及通过一致性算法检测有冲突的事务并中止它们。MGR 的这一方面超出了本文的范围,与成员自动重新加入功能并不完全相关,本文不作赘述。

组内新成员必须符合一些条件。其中新成员需要在事务方面赶上组进度(是通过选择组内一个成员来将已处理的事务流式传输给他,在 MGR 中称为“捐赠”)。最后,只要在此“分布式恢复”过程中没有遇到任何错误,组内新成员将被声明为 ONLINE 状态。

MGR 依靠组通信层 (GCS) 来管理组。该层实现了用于解决冲突事务的一致性算法,并强制执行一些通信特性。对于实现前面提到的组的不可分割视图,这些特性至关重要,如消息的总顺序、安全传递或视图同步等。

GCS 需要能够检测组中哪些成员失效或看起来失效。一旦这些成员被检测为失效,就将其从该组中移除,以便保持该组正常使用。为此 GCS 在每个成员中引入了一个故障检测器,用于分析组内交换的消息。如果它在一段时间内没有收到来自指定成员的消息,则故障检测器将对该成员产生“怀疑”,并认为该成员可能已经失效。成员从“怀疑”到真正失效的等待时间是可以配置的。


重新加入成员存在的问题

我们已经了解 MGR 必须为了高可用提供的策略,以及它如何实现,接下来请看示例:

一个小组由三个成员组成,其中一个成员偶尔会遇到丢失数据包、断连或者其它导致无法解决的错误情况的影响组内通信。还要考虑这些错误持续时间超过 group_replication_member_expel_timeout的值。

其中一个组员发生故障,小组的其他成员将决定踢出该成员。问题是,一旦该成员重新入组,他将被组驱逐加入失败,需要通过手动干预。

如果该成员的驱逐超时属性设置不为 0,则它将在被驱逐前等待满足该时间量(将超时设置为 0 意味着他将永远等待)。超时后成员将被驱逐并重新建立连接,并且无法重新加入旧组,需要再次手动干预。

于此,当存在网络故障时,显然需要手动干预。

在 MySQL 8.0.16 中,我们引入了自动重新加入组的功能,一旦成员被驱逐出组,它就会自动尝试重新加入该组,直到达到预设的次数为止。有时每次重试之间至少等待5分钟。


如何启动自动重新加入?

可以通过将group_replication_autorejoin_tries设置为所需的重试次数来开启并使用自动重新加入功能。

    SET GLOBAL group_replication_autorejoin_tries = 3

默认值为 0,表示服务器禁用自动重新加入。


如何验证自动重新加入?

与 MySQL 中的许多功能一样,自动重新加入过程是可以监测的。自动重新加入的可检测性依赖于性能模式基础架构,阶段式收集有关数据。

他们获取以下信息:

  • 事件发生的线程ID(THREAD_ID)

  • 活动名称(EVENT_NAME) 

  • 起止时间戳以及事件的总持续时间(TIMER_START,TIMER_END 和 TIMER_WAIT)

  • 在事件停止之前完成的工作单位和预估工作单位(WORK_COMPLETED,WORK_ESTIMATED)

  • 因此,当自动重新加入过程开始时,它将在performance schema中注册一个名为“stage / grouprpl / Undergoing auto-rejoinprocedure”的事件。使用表performance_schema.events_stage_current,  performance_schema.events_stages_summary_global_by_event_name和performance_schema.events_stages_history_long我们可以观察到以下内容:

  • 是否正在进行自动重新加入程序

  • 到目前为止,已经减少重试的次数

  • 直到下一次重试的估计剩余时间

  • 自动重新加入过程状态

    可以通过过滤包含“auto-rejoin”字符串的活动事件来查找自动重新加入过程状态(即,是否正在进行):

  • SELECT COUNT(*) FROM performance_schema.events_stages_current

  • WHERE EVENT_NAME LIKE '%auto-rejoin%';

  • COUNT(*)

  • 1

  • 查询结果存在,证明服务器上运行了自动重新加入过程。

    到目前为止的重试次数

    如果正在进行自动重新加入程序,我们可以通过选择阶段事件上的工作单元数来检查到目前为止尝试的重试次数: 

  • SELECT WORK_COMPLETED FROM performance_schema.events_stages_current WHERE

  • EVENT_NAME LIKE '%auto-rejoin%';

  • WORK_COMPLETED

  • 1

  • 在这个例子中,到目前为止只有一次尝试。

    预计到下次重试的剩余时间

    在每次重新加入尝试之间,服务器将处于 5 分钟的可中断睡眠中。 重新加入尝试直到成功或失败之间的时间是无法估计的。 因此,为了粗略估计剩余时间,我们可以将到目前为止尝试的重试次数乘以 5 分钟,并减去到目前为止的阶段事件所花费的时间,以估计我们还需要多长时间:

  • SELECT (300.0 - ((TIMER_WAIT*10e-12) - 300.0 * num_retries)) AS time_remaining FROM

  • (SELECT COUNT(*) - 1 AS num_retries FROM

  • performance_schema.events_stages_current WHERE EVENT_NAME LIKE '%auto-rejoin%') AS T,

  • performance_schema.events_stages_current WHERE EVENT_NAME LIKE '%auto-rejoin%';

  • time_remaining

  • 30.0

  • 所以在这个例子中,在下一次重新加入之前还有 30 秒。注意性能模式表中的所有时间记帐都以微秒精度保持,因此我们将 TIMER_WAIT 缩放为秒。

    使用自动重新加入与驱逐超时的权衡

    到目前为止,在这篇文章中我们只关注自动重新加入。实际上,有两种不同的方法可以实现离开组的成员的重新加入:

  • 设置自动重新加入尝试次数来实现自动重新加入

  • 设置该成员的驱逐超时时间然后配合手动干预

  • 能有延缓删除组内可疑成员,并且如果配置为足够长的驱逐超时时间,则增加了重新建立连接的机会,再次与组进行交互。

    虽然这两个功能实现了相同的目标,但它们的工作方式是不同的,并且需要权衡。通过使用驱逐超时,您可以维护组中可疑的成员,其缺点是您无法添加或删除成员或选择新的主机。如果通过使用自动重新加入,该成员将不再是该组的正常组员,将保持在 superreadonly 模式,直到重新加入该组。但在此期间,重新加入成员的同步旧数据的可能性将增加。自动重新加入过程可监控,而驱逐超时不是真正可监控的。

    所以,总结一下:

  • 驱逐超时的优点

  • - 该成员一直在该组内

    - 可能更适合足够小的网络故障

  • 驱逐超时的缺点

  • - 在怀疑某个成员时,无法在该组上添加/删除成员

    - 在怀疑某个成员时,无法选择新的主机

    - 您无法监控此过程

  • 自动重新加入的优点

  • - 该组将在没有重新加入成员的情况下运行,您可以添加/删除成员并选择新的主机

    - 您可以监控该过程

  • 自动重新加入的缺点

  • - 您增加了重新加入成员上过时读取的可能性

    - 可能不适合足够小的网络故障

    总而言之,我从启用自动重新加入中获得了什么?

    通过启用自动重新加入,您可以减少对MySQL实例的手动干预的需要。您的系统

    更加适应瞬间网络故障,同时满足对容错性和高可用的保证。

    摘要

    我们引入了一个名为group_replication_autorejoin_tries的新系统变量,允许用户设置 MGR 成员在被驱逐或与组的大多数人失去联系后尝试重新加入组的次数。

    默认情况下,此自动重新加入过程处于关闭状态。它能帮助用户在面对瞬间网络故障时避免对 MGR 成员进行手动干预。

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
smallglory
2012-03-08 · TA获得超过191个赞
知道小有建树答主
回答量:109
采纳率:0%
帮助的人:79万
展开全部
ID 如果是自动增加的话,是不用管的,你只要插入name 与 passwd,id就会相应的加一条。
语句是:insert into user(name,passwd) values ('张三','123');
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
抠脚小圣
2019-05-20
知道答主
回答量:2
采纳率:0%
帮助的人:1649
展开全部
在创建表的时候就将自增写好:
比如:`id` int(11) NOT NULL auto_increment,就是让id这个属性自增。
你需要在创建数据库的语句最后写这么一句:AUTO_INCREMENT=1。表明自增数字从1开始。之后插入数据的sql语句就正常写就行了:insert into user values( ??);根据你的实际情况:插入数据时只需要插入name和password就好,所以values中的“?”两个就够了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
unitech2010
2012-03-09 · TA获得超过1062个赞
知道小有建树答主
回答量:1025
采纳率:100%
帮助的人:907万
展开全部
在建立表的时候设置id为自动增长的 [id] [int] IDENTITY (1, 1)
在insert into user(name,passwd) values (name ,passwd) 就可以了。你新增一条数据 id 就会自动加1
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(7)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式