mysql插入的同时返回_mysql中插入记录的同时怎样返回它的id值

表结构

id int(11) not null pri key auto_increment,name varchar(12),backup varchar(50)

现在想插入一条记录的同时,返回他的id值(插入时只是插入name和backup字段的值)。请问该如何写这条语句。谢谢!

你的担心完全多于。 不需要锁表, 返回的ID肯定是你的,基于当前连接session

自动返回最后一个INSERT或 UPDATE 问询为 AUTO_INCREMENT列设置的第一个 发生的值。

mysql> SELECT LAST_INSERT_ID();

-> 195

产生的ID 每次连接后保存在服务器中。这意味着函数向一个给定客户端返回的值是该客户端产生对影响AUTO_INCREMENT列的最新语句第一个 AUTO_INCREMENT值的。这个值不能被其它客户端影响,即使它们产生它们自己的 AUTO_INCREMENT值。这个行为保证了你能够找回自己的 ID 而不用担心其它客户端的活动,而且不需要加锁或处理。

mysql的源代码里面,mysql_insert_id是这么定义的

my_ulonglong STDCALL mysql_insert_id(MYSQL *mysql)

{

return mysql->;last_used_con->;insert_id;

}

MYSQL提供给c++,php等的API一般,有个MYSQL结构体。

结构体里面有insert_id, insert_id的类型 my_ulonglong。 其实就是long long.

每次mysql_query操作在mysql服务器上可以理解为一次“原子”操作, 数据库的写操作常常需要锁表的, 是mysql应用服务器锁表不是我们的应用程序锁表。

附上MYSQL结构体的定义。

typedef struct st_mysql

{

NET net; /* Communication parameters */

gptr connector_fd; /* ConnectorFd for SSL */

char *host,*user,*passwd,*unix_socket,*server_version,*host_info,*info;

char *db;

struct charset_info_st *charset;

MYSQL_FIELD *fields;

MEM_ROOT field_alloc;

my_ulonglong affected_rows;

my_ulonglong insert_id; /* id if insert on table with NEXTNR */

my_ulonglong extra_info; /* Used by mysqlshow */

unsigned long thread_id; /* Id for connection in server */

unsigned long packet_length;

unsigned intport;

unsigned long client_flag,server_capabilities;

unsigned intprotocol_version;

unsigned intfield_count;

unsigned intserver_status;

unsigned intserver_language;

unsigned intwarning_count;

struct st_mysql_options options;

enum mysql_status status;

my_bool free_me; /* If free in mysql_close */

my_bool reconnect; /* set to 1 if automatic reconnect */

/* session-wide random string */

char scramble[SCRAMBLE_LENGTH+1];

/*

Set if this is the original connection, not a master or a slave we have

added though mysql_rpl_probe() or mysql_set_master()/ mysql_add_slave()

*/

my_bool rpl_pivot;

/*

Pointers to the master, and the next slave connections, points to

itself if lone connection.

*/

struct st_mysql* master, *next_slave;

struct st_mysql* last_used_slave; /* needed for round-robin slave pick */

/* needed for send/read/store/use result to work correctly with replication */

struct st_mysql* last_used_con;

LIST*stmts; /* list of all statements */

const struct st_mysql_methods *methods;

void *thd;

/*

Points to boolean flag in MYSQL_RESor MYSQL_STMT. We set this flag

from mysql_stmt_close if close had to cancel result set of this object.

*/

my_bool *unbuffered_fetch_owner;

} MYSQL;

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2007-01-08 16:26

浏览 771

评论

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值