:59' ,不支持时区,8字节存储 如果不需要考虑时区问题,直接用 datatime类型替换 timestamp,替换的思路: 1....新建一个 datatime类型的字段(新建一列,用来替换原来的); ALTER TABLE `student` ADD `create_time` DATETIME NOT NULL default '...将原来字段列的数据拷贝到新的字段列中; UPDATE `student` SET `create_time` = `temp_create_time`; 4....删除原来的列; ALTER TABLE `student` DROP `temp_create_time`; 5....完整sql 如下:(需要注意,原来的 timestamp的默认值,这个也需要加上) ALTER TABLE `student` CHANGE `create_time` `temp_create_time
mysql> create database samp_db1 character set gbk; Query OK, 1 row affected (0.00 sec) 数据库字符编码指定为 gbk...选择要操作的数据库 已经登录后可以直接选择数据库 mysql> use samp_db1; Database changed 创建数据表 以建立person_t数据表为例 mysql> create...查询表中的数据 select 列名称 from 表名称 [查询条件]; 多插入了一些数据后 mysql> select name, age from student; +-------+-----+ |...,运用得当会节省运行时间 改 - 修改表中的数据 基本的使用形式为: update 表名称 set 列名称=新值 where 更新条件; 我们终于拿到了李四的联系方式,将数据库中的tell更新 mysql...address列 mysql> alter table student add address char(70); 在名为 age 的列后插入列 birthday mysql> alter table
character set 字符集,如果没有指定字符集,则以所在数据库的字符集为准 collate 校验规则,如果没有指定校验规则,则以所在数据库的校验规则为准 现在创建一张表user1: mysql...; Query OK, 0 rows affected (0.00 sec) mysql> 创建表user2: mysql> create table if not exists user2(...(0.02 sec) //也可以不指定,直接创建 mysql> create table if not exists user3 (name char(32)); Query OK, 0 rows...xingming varchar(60) DEFAULT NULL; 向表中插入数据insert into values mysql> insert into user values (1,'张三...','12345','2010-10-1'); Query OK, 1 row affected (0.00 sec) mysql> insert into user values (2,'李四','
MySQL表的增删改查(基础) 据库最主要的操作就是增(create)删(update)改(retrieve)查(delete)。(CURD) 注意:进行增删改查操作的时候,请务必选中数据库。...在MySQL中,当前一次插入一条记录,分10次插入,效率要远低于一次把10个记录一起插入。因为MySQL是一个“客户端服务器”结构的程序。 原因: 由于网络请求和响应的时间开销引起的。...写代码不能依赖自带的顺序!!! 不加order by,看起来好像是根据插入的顺序,依次排序的,但实际上,mysql并没有对顺序做任何承诺。...在这个代码中,此处的where子句不能够使用列的别名来比较。 比如: 这取决于mysql内部的实现。mysql里执行查询操作的时候,现针对每一行记录,计算条件,并按照条件筛选。...mysql支持的模糊匹配功能是非常有限的。但是在实际开发中,可能会遇到更加复杂的情况。于是发明了一个东西, 正则表达式,来描述这种字符串的规则的。
MySQL基本查询 表的增删改查:CRUD Create(创建)包含insert Retrieve(读取)包含select Update(更新) Delete(删除) 一.增加数据Create 主要是...exam_math; 3.查询字段为表达式 在MySQL数据类型的介绍中,select可以执行相应的各种表达式,函数。...实际上 MySQL 不对数据操作,所以比 DELETE 更快,但是TRUNCATE在删除数据的时候,并不经过真正的事物,所以无法回滚。...将上述SQL保存到文件中,然后在MySQL中使用source命令依次执行文件中的SQL。如下: 执行完文件中的SQL后查看数据库,就能看到多了一个名为scott的数据库。...都是对表进行各种的增删查改,尤其对于查找,表与表之间因外键的联系等。
正因为主键和unique都有先查询的过程,MySQL就会默认给primary key和unique 这样的列,自动添加索引,来提高查询速度。...注意: 实际开发中,大部分的表,一般都会带有一个主键,主键往往是一个整数表示的id 在mysql中,一个表里,只能有一个主键,不能有多个 虽然主键不能有多个,mysql允许把多个列放到一起共同作为一个主键...(联合主键) 主键另外一个非常常用的方法,就是使用mysql自带的“自增主键”作为主键的值。...mysql的数据量比较小,所有的数据都在一个mysql服务器上,自增主键是可以很好地工作的,如果mysql的数据量很大,一台主机放不下就需要进行分库分表,使用多个主机来进行存储。...针对这种关系: student(id,name); class(class,name,studentIds); 注意:这种在MySQL中不可行,因为MySQL中没有一个像数组这样的类型。
UNIQUE - 保证某列的每行必须有唯一的值。 DEFAULT - 规定没有给列赋值时的默认值。 PRIMARY KEY - NOT NULL 和 UNIQUE 的结合。...确保某列(或两个列多个列的结合)有唯一标识,有助于更容易更快速地找到表中的一个特定的记录。 FOREIGN KEY - 保证一个表中的数据匹配另一个表中的值的参照完整性。...CHECK - 保证列中的值符合指定的条件。对于MySQL数据库,对CHECK子句进行分析,但是忽略CHECK子句。...,语法: foreign key (字段名) references 主表(列) 用例: -- 创建班级表,有使用MySQL关键字作为字段时,需要使用``来标识 DROP TABLE IF EXISTS...三大范式: 第一范式(1NF): 第一范式是指数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值,即实体中的某个属性不能有多个值,或不能有重复的属性。
(20) comment '姓名', qq_mail VARCHAR(20) comment 'QQ邮箱' ); 单行数据+全列插入 -- 插入两条记录,value_list 数量必须和定义表的列的数量及顺序一致...查询的列越多,意味着需要传输的数据量越大; -- 2. 可能会影响到索引的使用。(索引待后面课程讲解) SELECT * FROM exam_result; ?...指定列查询 -- 指定列的顺序不需要按定义表的顺序来 SELECT id, name, math FROM exam_result; ?...别名: 为查询结果中的列指定别名,表示返回的结果集中,以别名作为该列的名称,语法: SELECT column [AS] alias_name [...]...ORDER BY column [ASC|DESC], [...]; 没有 ORDER BY 子句的查询,返回的顺序是未定义的,永远不要依赖这个顺序 NULL 数据排序,视为比任何值都小,升序出现在最上面
,'13311112222','重庆市江北区','123@qq.com',1,'5001112222222222','1.jpg'); ### 这里列名的顺序与定义表时的列名的顺序无关...,只要值能对得上上面列名的顺序就行 第二种形式: 省略列名的列举时,值的顺序要与表定义时的列的顺序一致。...(新表不带主外键关系) create table newGrade select * from grade; 将查询出来的数据存入到新建的表中。...,子表中有引用主表的数据时,删除操作都会报错 先查看foreign_key_checks系统变量的值,show VARIABLES like 'foreign_key_checks' 结果是ON 打开状态...,字段名n=值n where 条件 update student set gender='男' where studentno%2=0 学号是偶数的记录变成男
大家好,又见面了,我是你们的朋友全栈君。 更改MySQL用户密码 MySQL用户是一条记录,其中包含登录信息,帐户特权以及MySQL帐户访问和管理数据库的主机信息。登录信息包括用户名和密码。...在某些情况下,需要更改MySQL数据库中的用户密码。 要更改任何用户帐户的密码,必须记住以下信息: 您要更改的用户帐户的详细信息。 用户要更改其密码的应用程序。...MySQL允许我们以三种不同的方式更改用户帐户密码,如下所示: UPDATE语句 设置密码声明 ALTER USER陈述 让我们看看如何通过使用上面的语句详细地更改MySQL中的用户帐户密码: 使用UPDATE...语句更改用户帐户密码 该语句是更改用户密码以更新MySQL数据库的用户表的第一种方法。...假设您要更改或更新从本地主机连接的用户pett的密码,密码为jtp12345,请执行以下SQL语句: 如果您使用的是MySQL 5.7.6或更高版本,则以上语句将不起作用。
mysql> show variables like 'collation_%'; mysql> show variables like 'character_set_%'; 缺省是latin1编码...修改库的编码: mysql> alter database db_name character set utf8; 修改表的编码: mysql> ALTER TABLE table_name CONVERT...TO CHARACTER SET utf8 COLLATE utf8_general_ci; 可以在mysql中设置编码,单个设置 mysql> set character_set_connection...=utf8; mysql> set character_set_database=utf8; mysql> set character_set_results=utf8; mysql> set character_set_server...,这样确保缺省编码是utf8
XMAPP简介 XAMPP(Apache+MySQL/MariaDB+PHP+Perl)开头的X代表X-OS,代表可以在任何常见操作系统下使用,包括Windows、Mac、Linux,开源平台。...XAMPP(Apache+MySQL+PHP+PERL)是一个功能强大的建站集成软件包。这个软件包原来的名字是 LAMPP,但是为了避免误解,最新的几个版本就改名为 XAMPP 了。...许多人通过他们自己的经验认识到安装 Apache 服务器是件不容易的事儿。如果您想添加 MySQL、PHP 和 Perl,那就更难了。...XAMPP 是一个易于安装且包含 MySQL、PHP 和 Perl 的 Apache 发行版。XAMPP的确容易安装和使用:只需下载,解压缩,启动即可。...2.安装XMAPP 2.1 首先我在D盘创建了一个文件夹XMAPP,然后在XMAPP创建了三个文件夹。 ?
SQL服务器的狭隘的,保守的存储引擎与MySQL服务器的可扩展,开放的存储引擎绝然不同。...MySQL不完全支持陌生的关键词,所以它比SQL服务器要少一些相关的数据库。同时,MySQL也缺乏一些存储程序的功能,比如MyISAM引擎联支持交换功能。...20一个很表面的区别就是mysql的安装特别简单,而且文件大小才110M(非安装版),相比微软这个庞然大物,安装进度来说简直就是….. 21mysql的管理工具有几个比较好的,mysql_front,...22mysql的存储过程只是出现在最新的版本中,稳定性和性能可能不如mssql。 23 同样的负载压力,mysql要消耗更少的CPU和内存,mssql的确是很耗资源。...24php连接mysql和mssql的方式都差不多,只需要将函数的mysql替换成mssql即可。
前言 前面我们学习了MySQL数据库和数据表的创建、删除。接下来我们就需要将数据保存在数据表中。今天我们就来学习数据表的增删查改(CRUD)。...MySQL 通过 insert 语句来添加一条或多条数据。...查询(Retrieve) MySQL 通过 select 语句来查询数据,查询结果通常会生成一个临时表。...总分 from result; 2.5 去重 MySQL 使用 distinct关键字对某列数据进行去重: -- 数学成绩98重复了 select math from result; select distinct...and 的优先级高于or,在同时使用的,需要使用小括号()括起来优先执行的部分。
null 和unique 的结合,确保某列(或两个列多个列的结合)有唯一标 识,有助于更容易更快速地找到表中的一个特定的记录。...foreign key:外键约束,保证一个表中的数据匹配另一个表中的值的参照完整性。...id 这一列的数据不能为空。...测试:插入 id 为空的记录是否能成功插入 insert into student values (null,'张三',18); 3. unique 唯一 创建表的时候,指定某类的值不能重复。...,在这条语句执行后,确保 MySQL 插入外键中的每一个非空值已经在被参照表中作为主键出现。
Mysql账户管理入门 可以这样讲,能否对数据库的账户进行基本的管理,区分"小白"和"老鸟"的一个衡量标准....Mysql数据库管理系统中,root用户拥有最高权限(与Linux类似),但不能让每一名开发者都拥有这么高的权限,所以要对不同级别的使用者进行相应的授权....Mysql的用户权限信息都存储在数据库mysql中的user表中; 坦率的讲…普通程序员,根本用不到这方面的知识 查看已有的数据库账户 1.登录数据库 mysql -uroot -p 2.进入mysql...数据库 use mysql; 3.查看已有账户信息(可登录的主机ip,用户名,加密后的密码) select host,user,authentication_string from user; 账户信息...新密码"mike321"生效 root用户修改下属用户的密码(需要root用户登录): root改密码的本质是修改mysql数据库中user表中字段authentication_string中的值 密文
可以在application.yml添加配置项: spring: datasource: driver-class-name: com.mysql.jdbc.Driver # 使用开发用数据库...book_dev url: jdbc:mysql://192.168.99.100:32770/my_blog?
前言 这里我已经将MySQL的数据库编码设置为UTF-8,所以下面现实的都是UTF-8。 ...设置MySQL数据库的编码方式有三种,分别是基于session会话的、基于全局gloable的、永久性改变的。...正文 1.首先连接到MySQL : mysql -uroot -proot 2.输入\s,即可查看数据库的字符编码 3.查看数据库的详细编码 输入:show variables like '%char...6.设置全局的数据库字符编码,即使基于整个MySQL服务的,当重启MySQL服务的时候,编码依然会变为原来的字符编码 set global character_set_database=gbk; ...但是我们重启MySQL数据库的时候,编码又是回复为原来的utf-8了。
背景:目前正在进行业务重构,需要对使用MySQL的业务库表进行重新设计,在迁移时,遇到了中文字符乱码问题(源库表的默认编码是LATIN1,新库表的默认编码为UTF8),故重新学习了下MySQL编码和解码相关知识...MySQL字符集编码简介 MySQL内部支持多种字符集,而字符集和编码可以等同。同一时候,MySQL中不同层次有不同的字符集编码格式,主要有四个层次:server,数据库,表和列。...character_set_system:这是mysql server用来存储元数据的编码,通常就是utf8,不要去改动它。...4个关于字符值的警告,这里分析下编码转换过程: MySQL客户端发送的插入语句含有"中文"字符串,其编码是跟我们的环境相关的,由于终端编码为UTF-8,因此"中文"的字节表示为"\xE4\xB8\xAD...MySQL Server端收到数据后,会按照character_set_client设置的编码转化为character_set_connection指定的编码,这里2个编码相同,实际不会发生转换(当插入的数据前面有
Python3自诩解决了编码问题,但还是有一系列的坑。本文就记录下前几天遇到的python3编码问题。mysql编码问题附带介绍。...mysql编码问题 查看当前的数据库编码: mysql> show variables like 'character%'; +--------------------------+----------...编码; ● character_set_filesystem:可以理解为文件的最终存储形式,是二进制形式的; ● character_set_server:MySQL服务器默认编码; ● character_set_results...:MySQL会把数据转换成该编码后,再发送给客户端,例如该编码为UTF8,那么如果客户端不使用UTF8来解读,那么就会出现乱码,说明客户端必须使用result指定的编码来解码; 一条数据库连接的过程如下...通过set names utf8 保证client、connection和result 的编码一致: mysql> show variables like 'character%'; +--------
领取专属 10元无门槛券
手把手带您无忧上云