5_主键

有哪些约束条件?

-- 不为空  not null

-- 可以为空   null

-- 默认(缺省)    default ‘默认值’        -- 没写就填入默认值

-- auto_increment       -- 设置自增字段,每个表只有一个,为主键设置,主键本身也是索引

-- primary key              -- 给某个字段设置主键

如何对同一个字段设置多个约束?

约束之间,用空格隔开

为什么需要自增字段?

-- 保证每插入一个数据,主键进行自增,保证数据唯一,为主键设置

什么是主键?

-- 表中自增列为主键,主键的值是唯一,唯一确定这一行数据的的值,会自动创建索引

-- 也可以在列外定义

-- primary key(‘字段’)

-- 也可以两个字段联合起来做主键

-- 一张表只能有一个主键

时间: 2024-10-27 04:56:58

5_主键的相关文章

主键类型定义错了调试了半天

package com.itheima.demo1; import javax.persistence.Entity;import javax.persistence.GeneratedValue;import javax.persistence.GenerationType;import javax.persistence.Id;import javax.persistence.Table; @Entity@Table(name="u_user")public class User

2 column数据构成主键的表转化为1 column为主键的表

问题:假设有张学生成绩表(tb)如下:姓名 课程 分数张三 语文 74张三 数学 83张三 物理 93张三 德语 null李四 语文 74李四 数学 84李四 物理 94李四 英语 80想变成(得到如下结果): 姓名 语文 数学 物理 英语 德语---- ---- ---- ----李四 74   84   94  ? 60张三 74   83   93  80 ? 这里name和course确定唯一一条记录,作为主键. 转化后只有name作为主键,另一个主键的具体值被作字段,不难理解,一个横坐

MySQL主键删除/添加

2修改数据库和表的字符集alter database maildb default character set utf8;//修改数据库的字符集alter table mailtable default character set utf8;//修改表的字符集如果您想要把表默认的字符集和所有字符列(CHAR, VARCHAR, TEXT)改为新的字符集,应使用如下语句:ALTER TABLE tbl_name CONVERT TO CHARACTER SET charset_name;警告:前面

Hibernate之:各种主键生成策略与配置详解

1.assigned 主键由外部程序负责生成,在 save() 之前必须指定一个.Hibernate不负责维护主键生成.与Hibernate和底层数据库都无关,可以跨数据库.在存储对象前,必须要使用主键的setter方法给主键赋值,至于这个值怎么生成,完全由自己决定,这种方法应该尽量避免. <id name="id" column="id"> <generator class="assigned" /> </id&g

Chapter 1. 数据库概述、主键、外键

数据库 database: 存储数据的仓库,用表来分类数据 特点:海量存储:查找速度快:并发性问题的控制:安全性:数据完整性(保存在数据库中的数据是正确的真实的) 数据库软件:DBSM   database management system 常见数据库软件:MySQL  MSSQL server  Oracle  Access SQL:Structured Query Language 结构化查询语言   特点:语言简洁.易学易用. SQL Server:是一种基于网络的大型数据库软件.主要用

MyBatis+MySQL 返回插入的主键ID

需求:使用MyBatis往MySQL数据库中插入一条记录后,需要返回该条记录的自增主键值. 方法:在mapper中指定keyProperty属性,示例如下: <insert id="insertAndGetId" useGeneratedKeys="true" keyProperty="userId" parameterType="com.chenzhou.mybatis.User"> insert into us

MyBatis insert操作返回主键

在写毕业设计的时候总是发现有一些小的细节问题,比如说...... MyBatis insert操作后怎么返回主键? 原来不懂的时候是调用一个select语句,将刚刚insert的对象再传入进去查出主键,但是这么写主键就没有意义了,什么都可以放到数据库里面去查. 在说,这样也会引起很多其他的问题.比如说你要查一下post表,在你不知道post_id的情况下你利用了post_name去查询post对象. 万一post_name有重复的呢?怎么办?所以有了这篇博客. 网上有很多大神写了很多mybati

Hibernate的主键生成策略的介绍

Hibernate主键的生成策略: 就是在配置文件中class中的配置项 <id name="id" column="id"> <generator class="increment"/> </id> native:适用于代理主键,代理主键就是没有业务含义的主键,通常用id表示,根据底层数据库对自动生成标识符的能力来选择identity.sequence.hilo identify:适用于代理主键,有底层数据库

mybatis+MySQL UUID主键生成策略

<insert id="insert" parameterType="com.gzwb.wbspm.model.SpmInvoice" > <selectKey keyProperty="invoiceId" //主键列名 resultType="string" //主键类型 order="BEFORE" //执行insert语句之前先得到主键> SELECT REPLACE(UUI