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

mysql中以下正确的sql是_MySQL数据库中下面两句话的区别:

展开全部

一、key与primary key区别

CREATE TABLE wh_logrecord (

logrecord_id int(11) NOT NULL auto_increment,

user_name varchar(100) default NULL,

operation_time datetime default NULL,

logrecord_operation varchar(100) default NULL,

PRIMARY KEY (logrecord_id),

KEY wh_logrecord_user_name (user_name)

)

解析:

KEY wh_logrecord_user_name (user_name)

本表的user_name字段与wh_logrecord_user_name表user_name字段建立外键

括号62616964757a686964616fe78988e69d8331333335323462外是建立外键的对应表,括号内是对应字段

类似还有 KEY user(userid)

当然,key未必都是外键

总结:

Key是索引约束,对表中字段进行约束索引的,都是通过primary foreign unique等创建的。常见有foreign key,外键关联用的。

KEY forum (status,type,displayorder) # 是多列索引(键)

KEY tid (tid) # 是单列索引(键)。

如建表时: KEY forum (status,type,displayorder)

select * from table group by status,type,displayorder 是否就自动用上了此索引,

而当 select * from table group by status 此索引有用吗?

key的用途:主要是用来加快查询速度的。

二、KEY与INDEX区别

批注:这部分我仍云里雾里。

KEY通常是INDEX同义词。如果关键字属性PRIMARY KEY在列定义中已给定,则PRIMARY

KEY也可以只指定为KEY。这么做的目的是与其它数据库系统兼容。 PRIMARY KEY是一个唯一KEY,此时,所有的关键字列必须定义为NOT

NULL。如果这些列没有被明确地定义为NOT NULL,MySQL应隐含地定义这些列。一个表只有一个PRIMARY KEY。

MySQL 中Index 与Key 的区别

Key即键值,是关系模型理论中的一部份,比如有主键(Primary Key),外键(Foreign

Key)等,用于数据完整性检否与唯一性约束等。而Index则处于实现层面,比如可以对表个的任意列建立索引,那么当建立索引的列处于SQL语句中的

Where条件中时,就可以得到快速的数据定位,从而快速检索。至于Unique Index,则只是属于Index中的一种而已,建立了Unique

Index表示此列数据不可重复,猜想MySQL对Unique Index类型的索引可以做进一步特殊优化吧。

于是乎,在设计表的时候,Key只是要处于模型层面的,而当需要进行查询优化,则对相关列建立索引即可。

另外,在MySQL中,对于一个Primary Key的列,MySQL已经自动对其建立了Unique Index,无需重复再在上面建立索引了。

搜索到的一段解释:

Note that “primary” is called PRIMARY KEY not INDEX.

KEY is something on the logical level, describes your table and database design (i.e. enforces referential integrity …)

INDEX is something on the physical level, helps improve access time for table operations.

Behind every PK there is (usually) unique index created (automatically).

三、mysql中UNIQUE KEY和PRIMARY KEY有什么区别

1,Primary key的1个或多个列必须为NOT NULL,如果列为NULL,在增加PRIMARY KEY时,列自动更改为NOT NULL。而UNIQUE KEY 对列没有此要求

2,一个表只能有一个PRIMARY KEY,但可以有多个UNIQUE KEY

3,主键和唯一键约束是通过参考索引实施的,如果插入的值均为NULL,则根据索引的原理,全NULL值不被记录在索引上,所以插入全NULL值时,可以有重复的,而其他的则不能插入重复值。

alter table t add constraint uk_t_1 unique (a,b);

insert into t (a ,b ) values (null,1); # 不能重复

insert into t (a ,b ) values (null,null);#可以重复

四、使用UNIQUE KEY

CREATE TABLE `secure_vulnerability_warning` (

`id` int(10) NOT NULL auto_increment,

`date` date NOT NULL,

`type` varchar(100) NOT NULL,

`sub_type` varchar(100) NOT NULL,

`domain_name` varchar(128) NOT NULL,

`url` text NOT NULL,

`parameters` text NOT NULL,

`hash` varchar(100) NOT NULL,

`deal` int(1) NOT NULL,

`deal_date` date default NULL,

`remark` text,

`last_push_time` datetime default NULL,

`push_times` int(11) default '1',

`first_set_ok_time` datetime default NULL,

`last_set_ok_time` datetime default NULL,

PRIMARY KEY (`id`),

UNIQUE KEY `date` (`date`,`hash`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8

UNIQUE KEY的用途:主要是用来防止数据插入的时候重复的。

1,创建表时

CREATE TABLE Persons

(

Id_P int NOT NULL,

LastName varchar(255) NOT NULL,

FirstName varchar(255),

Address varchar(255),

City varchar(255),

UNIQUE (Id_P)

)

如果需要命名 UNIQUE 约束,以及为多个列定义 UNIQUE 约束,请使用下面的 SQL 语法:

CREATE TABLE Persons

(

Id_P int NOT NULL,

LastName varchar(255) NOT NULL,

FirstName varchar(255),

Address varchar(255),

City varchar(255),

CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)

)

2,当表已被创建时,如需在 "Id_P" 列创建 UNIQUE 约束,请使用下列 SQL:

ALTER TABLE Persons

ADD UNIQUE (Id_P)

如需命名 UNIQUE 约束,并定义多个列的 UNIQUE 约束,请使用下面的 SQL 语法:

ALTER TABLE Persons

ADD CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)

3,撤销 UNIQUE 约束

如需撤销 UNIQUE 约束,请使用下面的 SQL:

MySQL:

ALTER TABLE Persons

DROP INDEX uc_PersonID

追问

请直接说出二者的区别吗?谢谢

追答

PRIMARY KEY

(id),-本表的id作为主键

PRIMARY KEY

(),-不指定本表的那个字段作为主键,使用默认,

本回答由提问者推荐

2Q==

已赞过

已踩过<

你对这个回答的评价是?

评论

收起

相关文章:

  • mysql安装需要jdkcheck_linux(center OS7)安装JDK、tomcat、mysql 搭建java web项目运行环境...
  • mysql模糊查询员工信息_PHP+MySQL实现模糊查询员工信息功能示例
  • mysql regexp_replace_mysql-使用DISTINCT的REGEXP_REPLACE
  • mysql 上周时间_mysql 获取上周1到周日的时间
  • mysql的备份和恢复命令行_使用MySQL命令行备份和恢复数据库
  • java 双向链表循环_Java实现双向循环链表
  • java 段错误_[原创]记一次java执行段错误及解决过程
  • java反射查询数据库_java反射与注解结合使用(根据传入对象输出查询sql)
  • Java 类Servletrequest_java中servlet中有关HttpServletRequest的不理解
  • java 值 继承_java中的继承
  • java 颜色条_具有多个颜色条的子图
  • java 图片数据管理_Java实现图片内容无损任意角度旋转
  • java流量监控系统demo_搭建一个简单的基于web的网络流量监控可视化系统
  • jquery与java_纯javascript和jquery实现增删改查
  • mysql 批量字段前缀_sqlserver数据库,批量更改表名和字段的前缀 | 学步园
  • Android Volley源码解析
  • CSS 三角实现
  • js算法-归并排序(merge_sort)
  • PHP 7 修改了什么呢 -- 2
  • PHP的Ev教程三(Periodic watcher)
  • Redis字符串类型内部编码剖析
  • Selenium实战教程系列(二)---元素定位
  • Spring Security中异常上抛机制及对于转型处理的一些感悟
  • 从零开始学习部署
  • 翻译--Thinking in React
  • 前端知识点整理(待续)
  • 使用iElevator.js模拟segmentfault的文章标题导航
  • 王永庆:技术创新改变教育未来
  • 做一名精致的JavaScripter 01:JavaScript简介
  • Redis4.x新特性 -- 萌萌的MEMORY DOCTOR
  • Semaphore
  • 不要一棍子打翻所有黑盒模型,其实可以让它们发挥作用 ...
  • ​​​​​​​sokit v1.3抓手机应用socket数据包: Socket是传输控制层协议,WebSocket是应用层协议。
  • ​configparser --- 配置文件解析器​
  • # 睡眠3秒_床上这样睡觉的人,睡眠质量多半不好
  • #我与Java虚拟机的故事#连载09:面试大厂逃不过的JVM
  • $$$$GB2312-80区位编码表$$$$
  • (13):Silverlight 2 数据与通信之WebRequest
  • (2022版)一套教程搞定k8s安装到实战 | RBAC
  • (C++)栈的链式存储结构(出栈、入栈、判空、遍历、销毁)(数据结构与算法)
  • (附源码)springboot炼糖厂地磅全自动控制系统 毕业设计 341357
  • (原創) 如何安裝Linux版本的Quartus II? (SOC) (Quartus II) (Linux) (RedHat) (VirtualBox)
  • .Net Web窗口页属性
  • .NET/C# 使用反射注册事件
  • .net分布式压力测试工具(Beetle.DT)
  • .NET下的多线程编程—1-线程机制概述
  • .pings勒索病毒的威胁:如何应对.pings勒索病毒的突袭?
  • @data注解_SpringBoot 使用WebSocket打造在线聊天室(基于注解)
  • @EnableConfigurationProperties注解使用
  • @ModelAttribute注解使用
  • @modelattribute注解用postman测试怎么传参_接口测试之问题挖掘
  • [ IOS ] iOS-控制器View的创建和生命周期
  • [ vulhub漏洞复现篇 ] Apache APISIX 默认密钥漏洞 CVE-2020-13945
  • [ASP.NET MVC]如何定制Numeric属性/字段验证消息
  • [boost]使用boost::function和boost::bind产生的down机一例