中文字幕视频在线看,亚洲精品无码久久久久av老牛,亚洲精品无码av片,亚洲av影院一区二区三区,亚洲国产精品成人久久久

mysql自動(dòng)增長(zhǎng)怎么設(shè)置(mysql怎么往表里插數(shù)據(jù))

mysql和oracle插入的時(shí)候有一個(gè)很大的區(qū)別是,oracle支持序列做id,mysql本身有一個(gè)列可以做自增長(zhǎng)字段,mysql在插入一條數(shù)據(jù)后,如何能獲得到這個(gè)自增id的值呢?

方法一:是使用last_insert_id

mysql> SELECT LAST_INSERT_ID;

產(chǎn)生的ID 每次連接后保存在服務(wù)器中。這意味著函數(shù)向一個(gè)給定客戶端返回的值是該客戶端產(chǎn)生對(duì)影響AUTO_INCREMENT列的最新語句第一個(gè) AUTO_INCREMENT值的。這個(gè)值不能被其它客戶端影響,即使它們產(chǎn)生它們自己的 AUTO_INCREMENT值。這個(gè)行為保證了你能夠找回自己的 ID 而不用擔(dān)心其它客戶端的活動(dòng),而且不需要加鎖或處理。

每次mysql_query操作在mysql服務(wù)器上可以理解為一次“原子”操作, 寫操作常常需要鎖表的, 是mysql應(yīng)用服務(wù)器鎖表不是我們的應(yīng)用程序鎖表。

值得注意的是,如你一次插入了多條記錄,這個(gè)函數(shù)返回的是第一個(gè)記錄的ID值。

因?yàn)長(zhǎng)AST_INSERT_ID是基于Connection的,只要每個(gè)線程都使用獨(dú)立的Connection對(duì)象,LAST_INSERT_ID函數(shù) 將返回該Connection對(duì)AUTO_INCREMENT列最新的insert or update*作生成的第一個(gè)record的ID。這個(gè)值不能被其它客戶端(Connection)影響,保證了你能夠找回自己的 ID 而不用擔(dān)心其它客戶端的活動(dòng),而且不需要加鎖。使用單INSERT語句插入多條記錄, LAST_INSERT_ID返回一個(gè)列表。

LAST_INSERT_ID 是與table無關(guān)的,如果向表a插入數(shù)據(jù)后,再向表b插入數(shù)據(jù),LAST_INSERT_ID會(huì)改變。

方法二:是使用max(id)

使用last_insert_id是基礎(chǔ)連接的,如果換一個(gè)窗口的時(shí)候調(diào)用則會(huì)一直返回10

如果不是頻繁的插入我們也可以使用這種方法來獲取返回的id值

select max(id) from user;

這個(gè)方法的缺點(diǎn)是不適合高并發(fā)。如果同時(shí)插入的時(shí)候返回的值可能不準(zhǔn)確。

方法三:是創(chuàng)建一個(gè)存儲(chǔ)過程,在存儲(chǔ)過程中調(diào)用先插入再獲取最大值的操作

DELIMITER $$
DROP PROCEDURE IF EXISTS `test` $$
CREATE DEFINER=`root`@`localhost` PROCEDURE `test`(in name varchar(100),out oid int)
BEGINinsert into user(loginname) values(name);
select max(id) from user into oid;
select oid;
END $$
DELIMITER ;call test('gg',@id);

方法四:使用@@identity

select @@IDENTITY

@@identity是表示的是最近一次向具有identity屬性(即自增列)的表插入數(shù)據(jù)時(shí)對(duì)應(yīng)的自增列的值,是系統(tǒng)定 義的全局變量。一般系統(tǒng)定義的全局變量都是以@@開頭,用戶自定義變量以@開頭。比如有個(gè)表A,它的自增列是id,當(dāng)向A表插入一行數(shù)據(jù)后,如果插入數(shù)據(jù) 后自增列的值自動(dòng)增加至101,則通過select @@identity得到的值就是101。使用@@identity的前提是在進(jìn)行insert操作后,執(zhí)行select @@identity的時(shí)候連接沒有關(guān)閉,否則得到的將是值。

方法五:是使用getGeneratedKeys

Connection conn = ;
Serializable ret = ;PreparedStatement state = .;ResultSet rs=;try {
state.executeUpdate;rs = state.getGeneratedKeys;if (rs.next) {
ret = (Serializable) rs.getObject(1);
}} catch (SQLException e) {
}return ret;

總結(jié)一下,在mysql中做完插入之后獲取id在高并發(fā)的時(shí)候是很容易出錯(cuò)的。另外last_insert_id雖然是基于session的但是不知道為什么沒有測(cè)試成功。

方法6:selectkey:

其實(shí)在ibtias框架里使用selectkey這個(gè)節(jié)點(diǎn),并設(shè)置insert返回值的類型為integer,就可以返回這個(gè)id值。

SelectKey在Mybatis中是為了解決Insert數(shù)據(jù)時(shí)不支持主鍵自動(dòng)生成的問題,他可以很隨意的設(shè)置生成主鍵的方式。

不管SelectKey有多好,盡量不要遇到這種情況吧,畢竟很麻煩。

mysql自動(dòng)增長(zhǎng)怎么設(shè)置(mysql怎么往表里插數(shù)據(jù))

SelectKey需要注意order屬性,像Mysql一類支持自動(dòng)增長(zhǎng)類型的數(shù)據(jù)庫(kù)中,order需要設(shè)置為after才會(huì)取到正確的值。

像Oracle這樣取序列的情況,需要設(shè)置為before,否則會(huì)報(bào)錯(cuò)。

另外在用Spring管理事務(wù)時(shí),SelectKey和插入在同一事務(wù)當(dāng)中,因而Mysql這樣的情況由于數(shù)據(jù)未插入到數(shù)據(jù)庫(kù)中,所以是得不到自動(dòng)增長(zhǎng)的Key。取消事務(wù)管理就不會(huì)有問題。

下面是一個(gè)xml和注解的例子,SelectKey很簡(jiǎn)單,兩個(gè)例子就夠了:

<insert id="insert" parameterType="map">
insert into table1 (name) values (#{name})<selectKey resultType="java.lang.Integer" keyProperty="id">
CALL IDENTITY</selectKey>
</insert>

上面xml的傳入?yún)?shù)是map,selectKey會(huì)將結(jié)果放到入?yún)?shù)map中。用POJO的情況一樣,但是有一點(diǎn)需要注意的是,keyProperty對(duì)應(yīng)的字段在POJO中必須有相應(yīng)的setter方法,setter的參數(shù)類型還要一致,否則會(huì)報(bào)錯(cuò)。

@Insert("insert into table2 (name) values(#{name})")
@SelectKey(statement="call identity", keyProperty="nameId", before=false, resultType=int.class)
int insertTable2(Name name);

上面是注解的形式。

方法:7:使用<insert中的useGeneratedKeys 和keyProperty 兩個(gè)屬性

1.在Mybatis Mapper文件中添加屬

性“useGeneratedKeys”和“keyProperty”,其中keyProperty是Java對(duì)象的屬性名,而不是表格的字段名。

<insert id="insert" parameterType="Spares"
useGeneratedKeys="true" keyProperty="id">
insert into system(name) values(#{name})
</insert>

2.Mybatis執(zhí)行完插入語句后,自動(dòng)將自增長(zhǎng)值賦值給對(duì)象systemBean的屬性id。因此,可通過systemBean對(duì)應(yīng)的getter方法獲取!

int count = systemService.insert(systemBean);
int id = systemBean.getId; //獲取到的即為新插入記錄的ID

注意事項(xiàng)

1.Mybatis Mapper 文件中,“useGeneratedKeys”和“keyProperty”必須添加,而且keyProperty一定得和java對(duì)象的屬性名稱一直,而不是表格的字段名

2.java Dao中的Insert方法,傳遞的參數(shù)必須為java對(duì)象,也就是Bean,而不能是某個(gè)參數(shù)。

作者:學(xué)無止境

版權(quán)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻(xiàn),該文觀點(diǎn)僅代表作者本人。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如發(fā)現(xiàn)本站有涉嫌抄襲侵權(quán)/違法違規(guī)的內(nèi)容, 請(qǐng)發(fā)送郵件至2705686032@qq.com 舉報(bào),一經(jīng)查實(shí),本站將立刻刪除。原文轉(zhuǎn)載: 原文出處:

(0)
尊云-小張的頭像尊云-小張
上一篇 2024 年 5 月 23 日 09:07
下一篇 2024 年 5 月 23 日 09:09

相關(guān)推薦

發(fā)表回復(fù)

登錄后才能評(píng)論

聯(lián)系我們

400-900-3935

在線咨詢: QQ交談

郵件:cong@zun.com

工作時(shí)間:365天無休服務(wù) 24小時(shí)在線

添加微信