在数据库中创建存储过程,比如存储过程的名字叫做 test
在java中和正常使用sql的方法一样, sql = "call test(B1,B2)", B1和B2是假设你将要插入b表中的数据
假设b表的结构是(ID int auto_incremet, B1 int, B2 int)
假设a表的结构是(ID int)
CREATE test(B1 int, B2 int) #假设A1和A2是将要插入b表中的数据
BEGIN
declare new_id as int; #声明自增长所添加的ID
insert into b(B1,B2) values(B1,B2); #给b插入新的记录
select last_insert_id() into new_id; #取得新插入记录的ID
insert into a(ID) values(new_id); #把新插入的ID写入a表
select new_id; #如果需要的话存储过程返回新得到的ID给客户端
END
注意: 为什么推荐使用存储过程,而不是直接在java程序中使用select last_insert_id(); 因为这个函数是打开当前端口时,返回最后一个插入的自增长的ID, 如果不用存储过程,可能当前链接关闭,或有其他的应用也在其他有自增长ID的表中插入新的记录, 这时你取回的ID就是错误的。
你创建表的时候就应该建立id-->id
int
primary
key
auto_increment
如果应经创建成功
ALTER
TABLE
`TableName`
MODIFY
COLUMN
`FieldName`
VARCHAR(14)
你好自增ID呢 是会在你使用插入或者修改语句的时候进行递增+1的,打个比方 如果你的插入语句写错了插入数据不成功,但是数据库的id还是会+1,想要避免或者重新添加ID为73的数据可以打开表设计 把他的自动增长先设为否,然后 insert into 手动插一条id为73的数据进入 插入好之后再把字段增长给调回来
dbcc checkident ('table_name', reseed, new_reseed_value) 当前值设置为 new_reseed_value。如果自创建表后没有将行插入该表,则在执行 DBCC CHECKIDENT 后插入的第一行将使用 new_reseed_value 作为标识。否则,下一个插入的行将使用 new_reseed_value + 1。如果 new_reseed_value 的值小于标识列中的最大值,以后引用该表时将产生 2627 号错误信息。
方法二不会清空已有数据, *** 作比较灵活,不仅可以将自增值归零,也适用于删除大量连续行后,重新设置自增值并插入新的数据;或从新的值开始,当然不能和已有的冲突。
当表中有了一下数据后
执行语句 DBCC CHECKIDENT ('dboPerson', RESEED, 10) 后再通过Management Studio添加数据时,ID就会自动从11开始,也就是new_reseed_value+1开始
CREATE TABLE users (
id int(5) NOT NULL auto_increment,
name varchar(20)NOT NULL,
PRIMARY KEY (`id`)
)
MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。
MySQL是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。
MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,它分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。
由于其社区版的性能卓越,搭配 PHP 和 Apache 可组成良好的开发环境。
1、例如给某表添加一个Num自增列,这张表已经有很多行数据了,通过sqlserver表设计器,添加一个新字段Num,如图所示,
2、添加字段后,点击保存,会d出一个小框“不允许保存更改。所做的更改要求删除并重新创建一下表”,这个要求不能满足啊,这么多的数据,删除了怎么办?
3、点击SQL Server Management Studio顶部的菜单工具->选项,
4、打开选项d窗界面如图所示,默认展开的是常规选项,
5、拖动左侧的菜单,找到并点击表设计器->表设计器和数据库设计器,
6、在右侧出现的表选项中,找到并 取消勾选阻止保存要求重新创建表的更改,点击确定按钮,
7、再次在表设计界面,点击保存,如果表中的数据量很大的话,会有这个验证警告:“将定义更改保存到包含有大量数据的表中可能需要很长时间”,此项可以忽略,
8、直接点击是按钮,就可以保存成功了。
create
table
aa(
id
int
IDENTITY(1,1),
name
varchar(20)
)
id
就是
自动增长
的
IDENTITY
(seed
,
increment)
第一个参数
seed
插入到表中的第一个行使用的值
第二个参数
increment
与前一个插入的行的标识值相加的增量值
id
的值将是
1,2,3,4
以上就是关于mysql数据库问题,如何同一个 *** 作添加两个表(a表,b表),并把b表的id添加到a表字段中,b表id自动增长全部的内容,包括:mysql数据库问题,如何同一个 *** 作添加两个表(a表,b表),并把b表的id添加到a表字段中,b表id自动增长、mysql数据库如何为表中已有的主键字段增加自增属性sql语句怎么写、关于数据库表字段自增长的问题等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)