发布网友 发布时间:2022-05-03 11:05
共5个回答
懂视网 时间:2022-05-03 15:26
这种方式相对较简单,不用改动表结构,只需在需要区分查询的字段前加上关键字。这种方式也是有缺点的,每次写查询的时候都要注意加关键字,并可能需要改动的代码较多。
在创建表的时候进行限制
CREATE TABLE `tb_user1` (
`id` BIGINT (20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT ‘用户id‘,
`username` VARCHAR (50) BINARY NOT NULL COMMENT ‘用户名‘,
PRIMARY KEY (`id`)
) ENGINE = INNODB DEFAULT CHARSET = utf8 COMMENT = ‘用户表‘;
mysql> show create table tb_user1;
tb_user1 | CREATE TABLE `tb_user1` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT ‘用户id‘,
`username` varchar(50) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL COMMENT ‘用户名‘,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT=‘用户表‘
1 row in set
或者 使用
CREATE TABLE `tb_user2` (
`id` BIGINT (20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT ‘用户id‘,
`username` VARCHAR (50) NOT NULL COMMENT ‘用户名‘,
`info` VARCHAR (100) NOT NULL COMMENT ‘详情描述‘,
PRIMARY KEY (`id`)
) ENGINE = INNODB DEFAULT CHARSET = utf8 COLLATE=utf8_bin COMMENT = ‘用户表‘;
mysql> show create table tb_user2;
tb_user2 | CREATE TABLE `tb_user2` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT ‘用户id‘,
`username` varchar(50) COLLATE utf8_bin NOT NULL COMMENT ‘用户名‘,
`info` varchar(100) COLLATE utf8_bin NOT NULL COMMENT ‘详情描述‘,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT=‘用户表‘
使用 NGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
会将字段中varchar类型的全部设置区分大小写。这两种查看表的详情,本质上都是 在字段上 加上了 COLLATE utf8_bin
。
总结:
字段值的大小写由mysql的校对规则来控制。提到校对规则,就不得不说字符集。字符集是一套符号和编码,校对规则是在字符集内用于比较字符的一套规则。 一般而言,校对规则以其相关的字符集名开始,通常包括一个语言名,并且以ci(大小写不敏感)、cs(大小写敏感)或_bin(二元)结束 。
比如 utf8字符集,,如下表:
1)utf8bin:utf8bin将字符串中的每一个字符用二进制数据存储,区分大小写。
2)utf8generalci:utf8generaci不区分大小写,ci为case insensitive的缩写,即大小写不敏感。
3)utf8generalcs:utf8generalcs区分大小写,cs为case sensitive的缩写,即大小写敏感。
3、ON DUPLICATE KEY UPDATE
mysql提供了这样的语法,即当我们往表里插数据里,如果数据已经存在(通过主键或唯一索引确定),我们可以对已存在的记录做更新操作。如:
INSERT USER(id,username) VALUES(1,‘张三丰‘) ON DUPLICATE KEY UPDATE username=‘王老五‘
面的sql意思是,如果id为1的记录不存在,则insert一条id=1、username=张三丰的记录;否,将id为1记录的username改为王老五。这只是插入单行数据,mysql甚至支持批量操作,如:INSERT INTO table (id,a,b,c) select id,a,b,c from xxx ON DUPLICATE KEY UPDATE a=VALUES(a),b=VALUES(b),c=VALUES(c)
即通过insert into ...from 来批量插入,然后通过values(xxx)来取得结果集中对应的字段值。
mysql的那点事儿,你知道吗
标签:记录 数据存储 批量操作 innodb dup efault linu 存储 描述
热心网友 时间:2022-05-03 12:34
mysql 是数据库管理软件,一般配合 PHP 使用,由 PHP 对其进行调用,也可独立使用,若独立使用 mysql,要进入 DOS ,执行 “mysql.exe -h主机IP -u用户名 -p密码”来登录数据库管理系统,然后可能进行建库、删库、建表、查询、修改、删除、授权等等各种操作。热心网友 时间:2022-05-03 13:52
打开?你指的是启动数据库么....热心网友 时间:2022-05-03 15:27
一般都是在程序里面,SQL2000在程序Microsoft SQL Server下面的企业管理器热心网友 时间:2022-05-03 17:18
一般都是通过SQLyogEnt 、 Navicat 8工具来调用的