重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
一、首先我们看对于同一张student表,对于mysql,sql server,oracle中它们都是怎样创建主键的
为高明等地区用户提供了全套网页设计制作服务,及高明网站建设行业解决方案。主营业务为成都网站设计、做网站、高明网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
1、在mysql中
create table Student(
Student_ID int(6) NOT NULL PRIMARY KEY AUTO_INCREMENT,
Student_Name varchar(10) NOT NULL,
Student_Age int(2) NOT NULL
);
insert into student(student_name,student_age) values('zhangsan',20);
2、在sql server中
create table Student(
Student_ID int primary key identity(1,1),
Student_Name varchar2(10) NOT NULL,
Student_Age number(2) NOT NULL
);
insert into student(student_name,student_age) values('zhangsan',20);
3、在oracle中
create table Student(
Student_ID number(6) NOT NULL PRIMARY KEY,
Student_Name varchar2(10) NOT NULL,
Student_Age number(2) NOT NULL
);
而oracle如果想设置主键自增长,则需要创建序列
CREATE SEQUENCE student_sequence
INCREMENT BY 1
NOMAXVALUE
NOCYCLE
CACHE 10;
insert into Student values(student_sequence.nextval,'aa',20);
如果使用了触发器的话,就更简单了
create or replace trigger student_trigger
before insert on student
for each row
begin
select student_sequence.nextval into :new.student_id from dual;
end student_trigger;
此时插入的时候触发器会帮你插入id
insert into student(student_name,student_age) values('wangwu',20);
至此,mysql,sql server,oracle中怎样创建表中的自增长主键都已完成。
看一看出oracle的主键自增较mysql和sql sever要复杂些,mysql,sqlserver配置好主键之后,插入时,字段和值一一对应即可,数据库就会完成你想做的,但是在oracle由于多了序列的概念,如果不使用触发器,oracle怎样实现主键自增呢?
insert id="add" parameterType="Student"
selectKey keyProperty="student_id" resultType="int" order="BEFORE"
select student_sequence.nextval from dual
/selectKey
insert into student(student_id,student_name,student_age) values(#{student_id},#{student_name},#{student_age})
/insert
或者
insert id="save" parameterType="com.threeti.to.ZoneTO"
selectKey resultType="java.lang.Long" keyProperty="id" order="AFTER"
SELECT SEQ_ZONE.CURRVAL AS id from dual
/selectKey
insert into TBL_ZONE (ID, NAME ) values (SEQ_ZONE.NEXTVAL, #{name,jdbcType=VARCHAR})
/insert
二、MyBatis 插入时候获取自增主键方法有二
以MySQL5.5为例:
方法1:
insert id="insert" parameterType="Person" useGeneratedKeys="true" keyProperty="id"
insert into person(name,pswd) values(#{name},#{pswd})
/insert
方法2:
insert id="insert" parameterType="Person"
selectKey keyProperty="id" resultType="long"
select LAST_INSERT_ID()
/selectKey
insert into person(name,pswd) values(#{name},#{pswd})
/insert
插入前实体id属性为0;
插入后实体id属性为保存后自增的id;
以下即为范例代码
---
按照说明编译即可用,稍加修改即可存储2进制文件
view
plaincopy
to
clipboardprint?
/*
mysql数据库存储二进制数据
linux
用途:
用
mysql_stmt_send_long_data()来向blob字段写入2进制数据流.
注意点:需要注意的是bind结构的buffer_type字段,必须与要输入的数据类型相符,
如:只写入一个long
数据,则用mysql_type_long,写入字符流,用mysql_type_string,
写入2进制数据流,用mysql_type_blob
具体这个参数各字段的含义参见
mysql5.0手册
compile:
g++
-i/usr/include/mysql
-l/usr/lib/mysql
-lmysqlclient
mysql_test.cpp
准备工作:
create
database
test;
use
test;
create
table
`bintest`
(
`id`
int(11)
not
null
default
0,
`data`
blob
)
engine=myisam;
*/
一、修改自增长序列的值
alter table table_name auto_increment=n;
注意:n只能大于已有的auto_increment的整数值,小于的值无效.
show table status like 'table_name' 的返回结果里的auto_increment列就是表的现有值.
二、控制主键的起点
create table 表名
(
......
) engine=INNODB auto_increment=1001 default charset=gbk;
三、自增主键归零
如果曾经的数据都不需要的话,可以直接清空所有数据,并将自增字段恢复从1开始计数
truncate table 表名
四、获取自增主键
通过SQL select LAST_INSERT_ID()函数
通过SQL @@IDENTITY 变量
五、说明
AUTO_INCREMENT数据列必须有唯一索引,以避免序号重复。
AUTO_INCREMENT数据列必须具备NOT NULL属性。
设置AUTO_INCREMENT属性的数据列应该是一个正数序列,所以应该把该数据列声明为UNSIGNED,这样序列的编号个可增加一倍。
oracle数据库添加自动增长是自己建一个序列sequence,,
mysql数据库是直接创建表时添加列的auto_increment属性就行了,,
-=================-========
设置主键就是 创建表时指定列的 primarykey属性,,
=============-==============-==========
你最好下载一个mysql数据库对应的可视化界面操作的工具 【比如SQLyogEnt.exe】
在工具里操作那个会很简单的,,,
=======-================================-===================