当前位置: 首页 > news >正文

龙口市建设局网站耒阳网站开发

龙口市建设局网站,耒阳网站开发,做网站需要提交,高端网站制作网站建设4.SQL约束介绍 (1)主键约束 A、基本内容 基本内容 p r i m a r y primary primary k e y key key约束唯一表示数据库中的每条记录主键必须包含唯一的值(UNIQUE)主键不能包含NULL值(NOT NULL)每个表都应…

4.SQL约束介绍

(1)主键约束

A、基本内容
  • 基本内容
    • p r i m a r y primary primary k e y key key约束唯一表示数据库中的每条记录
    • 主键必须包含唯一的值(UNIQUE)
    • 主键不能包含NULL值(NOT NULL)
    • 每个表都应该有一个主键,并且每个表只能有一个主键
  • 遵循原则
    • 逐渐应当是对用户没有意义的
    • 永远也不要更新主键
    • 主键不应该包含动态变换的数据,如时间戳,创建时间列,修改时间列
    • 逐渐应当由计算机自动生成
B、添加主键约束
  • 创建表时添加主键

    #创建数据表时添加
    create table person(id INT PRIMARY KEY,last_name VARCHAR(100),first_name VARCHAR(100),address VARCHAR(100),city VARCHAR(100)
    );
    

最终输出的表

FieldTypeNullKeyDefaultExtra
idint(20)NOPRI
last_namevarchar(100)YES
first_namevarchar(100)YES
addressvarchar(100)YES
cityvarchar(100)YES
  • 创建表后添加主键

    # 创建后添加约束
    create table person(id INT,last_name VARCHAR(100),first_name VARCHAR(100),address VARCHAR(100),city VARCHAR(100)
    );
    
    • 在创建表后,可以使用ALTER TABLE关键字添加主键
    ALTER TABLE category ADD PRIMARY KEY(cid);
    
C、删除主键约束
  • 格式:alter table category drop primary key;
D、自动增长列

auto_increment(自动增长列)关键字:我们通常在每次插入新记录时,数据库自动生成字段的值

  • 注意:自动增长列类型必须是整型,自动增长列必须为键(一般是主键),自动增长常与主键约束配合使用
  • 创建表时添加自动增长
CREATE TABLE person2(id INT PRIMARY KEY AUTO_INCREMENT,last_name VARCHAR(100),first_name VARCHAR(100),address VARCHAR(100),city VARCHAR(100)
)

最终输出的表

FieldTypeNullKeyDefaultExtra
idint(20)NOPRIauto_increment
last_namevarchar(100)YES
first_namevarchar(100)YES
addressvarchar(100)YES
cityvarchar(100)YES
  • 在创建表之后添加自动增长
ALTER TABLE person2 CHANGE id id INT AUTO_INCERMENT;
  • 示例

    向person中添加数据时,可以不为id字段设置值,或可以设置成null,数据库将自动维护主键值

    输入

    insert into person2(first_name,last_name) values('Bill','Gates');
    或
    insert into person2(id,first_name,last_name) values(null,'Bill','Gates');
    

    在输入select * from person2语句之后,会输出

    idlast_namefirst_nameaddresscity
    1GatesBill
    2GatesBill

    可以看到,从上往下,id的值是

  • 其他

    当主键不是自增长类型时

    • 不为 id 字段设置值

      执行插入语句时若不指定 id 字段值,数据库会报错。因为非自增长主键字段不允许有空值(一般定义为主键时会设置为 NOT NULL ),缺少主键值就无法满足数据完整性约束 。例如在 MySQL 中执行 insert into person2(first_name,last_name) values('Bill','Gates'); 会报错,提示主键字段不能为空 。

    • 将 id 设置成 null

      同样会报错。因为主键具有唯一性和非空性约束,null 值既不符合非空要求,也难以保证唯一性(多个 null 无法区分 ) 。像执行 insert into person2(id,first_name,last_name) values(null,'Bill','Gates'); ,数据库会提示违反主键约束相关错误 。

    总之,非自增长主键要求在插入数据时必须明确指定一个符合其数据类型且唯一的有效值。

(2)非空约束

  • NOTNULL 约束强制列不进行NULL值,强制字段始终包含值,故说明如果不向字段中添加值,就无法插入新记录或者更新记录

  • 示例

CREATE TABLE person3(id INT PRIMARY KEY,last_name VARCHAR(100) NOT NULL,first_name VARCHAR(100),address VARCHAR(100),city VARCHAR(100)
)

最终输出的表

FieldTypeNullKeyDefaultExtra
idint(20)NOPRIauto_increment
last_namevarchar(100)NO
first_namevarchar(100)YES
addressvarchar(100)YES
cityvarchar(100)YES

(3)唯一约束

  • 基础

    • UNIQUE约束唯一标识数据库表中的每条记录
    • UNIQUE和PRIMARY KEY 约束均为列或列集合提供了唯一性的保证
    • PRIMARY KEY 拥有自动定义的UNIQUE约束
  • 注意

    • 每个表中可以有多个UNIQUE约束,但是每个表只能有一个PERIMARY KEY约束
  • 示例

CREATE TABLE person3(id INT PRIMARY KEY,last_name VARCHAR(100) UNIQUE,first_name VARCHAR(100),address VARCHAR(100),city VARCHAR(100)
)

最终输出的表

FieldTypeNullKeyDefaultExtra
idint(20)NOPRIauto_increment
last_namevarchar(100)YESUNI
first_namevarchar(100)YES
addressvarchar(100)YES
cityvarchar(100)YES

(4)默认值约束

  • 当不填写字段对应的值会使用默认值,如果填写时以填写的为准
  • 示例
CREATE TABLE person3(id INT PRIMARY KEY,last_name varchar(100) NOT NULL,first_name varchar(100),address varchar(100),city varchar(100) DEFAULT '北京'
)

最终输出的表

FieldTypeNullKeyDefaultExtra
idint(20)NOPRIauto_increment
last_namevarchar(100)YESUNI
first_namevarchar(100)YES
addressvarchar(100)YES
cityvarchar(100)YES北京

四、窗口函数

  • 基本语法:SELECT SUM() OVER(PARTITION BY ___ ORDER BY ___) FROM TABLE;
  • PARTITION BYGROUP BY的区别
    • GROUP BY分组聚合之后,分组字段有几个取值,就会返回几条结果
    • PARTITION BY返回的结果和原始数据表的条目数是一样的
http://www.dtcms.com/a/437809.html

相关文章:

  • 网站seo化自己可以吗简单个人网站欣赏
  • 旅游网站建设案例psd设计网站模板
  • 阿里云虚拟主机可以做几个网站宜昌建站
  • 大学生个人网站怎么做抖音流量推广神器软件
  • 做网站推广好做吗有什么设计网站推荐
  • 台州知名网站怎么获取免费的wordpress
  • 给做网站建设的一些建议中信建设有限责任公司招标
  • 锦州企业网站建设中山精品网站建设信息
  • 如何采集网站文章表白软件制作器手机版
  • 美耐皿 技术支持 东莞网站建设网站域名变更怎么查询
  • 网站app开发关于网站建设的英文书籍
  • 制作营销网站模板低价自适应网站建设优化建站
  • 网站seo文章该怎么写上海工商网查询官网
  • 网站怎么被百度收录门户网站建设项目招标
  • dede网站栏目管理网站设计建站
  • 南宁手机模板建站太原公司网站建设
  • django网站开发视频教程网上国网app下载安装
  • 外贸网站外链注册公司一年交多少税
  • 软件网站开发平台seo优化交流
  • 宁晋网站建设代理价格微信端怎么建设网站
  • 在哪个网站做一照一码页面模板下载
  • 国外网站页面设计网站开发层次
  • 菜鸟如何建网站中国企业500强怎么评的
  • 路北网站制作专业知识
  • 自己公司内网网站和外网怎么做同步教你如何用天翼云盘做网站
  • 网站建设制作官网深圳加盟网站建设
  • 推荐一些做电子的网站假冒中国建设银行的网站
  • 几何图形生成网站in什么 wordpress
  • 机械网站建设栏目内容云莱坞网站开发
  • wordpress 群站网站建设属于经营什么范围