mysql的库和表相关操作

一、数据库介绍

1、数据库的由来

我们之前所学,数据要想永久保存,都是保存于文件中,毫无疑问,一个文件仅仅只能存在于某一台机器上,这样就带来了许多问题:

(1)程序所有的组件就不可能运行在一台机器上

(2)数据安全问题

(3)并发问题

总结:我们在编写任何程序之前,都需要事先写好基于网络操作一台主机上文件的程序(socket服务端与客户端程序),于是有人将此类程序写成一个专门的处理软件,这就是mysql等数据库管理软件的由来,mysql不仅仅解决的是数据共享的问题,还有查询效率,安全性等一系列问题,总之,把程序员从数据管理中解脱出来,专注于自己的程序逻辑的编写。

2、数据库说明

数据库服务器 -:运行数据库管理软件

数据库管理软件:管理 - 数据库

数据库:即文件夹,用来组织文件 / 表

表:即文件,用来存放多行内容 / 多条记录

3、mysql介绍

MySQL是一个关系型数据库管理系统

(1)分两大类:

  关系型:如sqllite,db2,oracle,access,sql server,MySQL,注意:sql语句通用

  非关系型:mongodb,redis,memcache

(2)可以简单的理解为:

关系型数据库需要有表结构

非关系型数据库是key-value存储的,没有表结构

二、操作

1、mysql数据库环境准备

环境:window7_X86_64

版本:mysql-5.6.38-winx64.zip

下载地址:https://dev.mysql.com/downloads/mysql/

文件路径:E:\mysql-5.6.38-winx64

添加到环境变量:计算机---->属性---->高级系统设置---->环境变量---->系统变量---->path---->E:\mysql-5.6.38-winx64\bin\;

2、登录和设置密码

C:\Users\Administrator> mysqld --install
C:\Users\Administrator> net start MySQL                   #启动mysql数据库
C:\Users\Administrator> mysql                         #默认用户不用密码可以直接登录
mysql> select user();                               #查看当前登录用户,显示的是ODBC用户
C:\Users\Administrator> mysqladmin -uroot -p password "123"     #设置root账号的密码是123

3、重置密码

C:\Users\Administrator> net stop MySQL
C:\Users\Administrator> mysqld --skip-grant-tables

新打开一个终端操作:
C:\Users\Administrator> mysql -uroot -p
mysql > update mysql.user set password=password("") where user='root' and host="localhost";
mysql > flush privileges;
mysql> exit;
C:\Users\Administrator>tasklist |findstr mysql             #查看mysql服务的进程号
mysqld.exe         6316 Console          1    454,544 K

C:\Users\Administrator>taskkill /F /PID 6316               #结束mysql服务
C:\Users\Administrator>net start MySQL                  #启动mysql服务
C:\Users\Administrator> mysql -uroot -p                  #登录不需要密码了

4、同一字符编码

#mysql5.5以上的配置文件配置

[mysqld]

character-set-server=utf8

collation-server=utf8_general_ci

[client]

default-character-set=utf8

[mysql]

default-character-set=utf8

mysql> show variables like '%char%';                           #查看字符编码

5、SQL语言介绍

SQL语言主要用于存取数据、查询数据、更新数据和管理关系数据库系统,SQL语言由IBM开发。SQL语言分为3种类型:

#1、DDL语句    数据库定义语言: 数据库、表、视图、索引、存储过程,例如CREATE DROP ALTER

#2、DML语句    数据库操纵语言: 插入数据INSERT、删除数据DELETE、更新数据UPDATE、查询数据SELECT

#3、DCL语句    数据库控制语言: 例如控制用户的访问权限GRANT、REVOKE

(1)操作文件夹

增:create database db1 charset utf8;

查:show databases;

改:alter database db1 charset latin1;

删除: drop database db1;

(2)操作文件

先切换到文件夹下:use db1

增:create table t1(id int, name char);

查:show tables

改:alter table t1 modify name char(3); alter table t1 change name name1 char(2);

删:drop table t1;

(3)操作文件中的内容/记录

增:insert into t1 values(1, 'egon1'), (2, 'egon2'), (3, 'egon3');

查:select * from t1;

改:update t1 set name = 'sb' where id = 2;

删:delete from t1 where id = 1;

清空表:

delete from t1;  # 如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。

truncate table t1; 数据量大,删除速度比上一条快,且直接从零开始,

auto_increment 表示:自增

primary key    表示:约束(不能重复且不能为空);加速查找

6、库操作

(1)查看数据库

show databases;

show create database db1;

select database();

(2)选择数据库

USE 数据库名

(3) 删除数据库

DROP DATABASE 数据库名;

(4)修改数据库

alter database db1 charset utf8;

7、表操作

(1)创建表

#注意:

1. 在同一张表中,字段名是不能相同

2. 宽度和约束条件可选

3. 字段名和类型是必须的

mysql> show engines;                      #显示所有的存储引擎
mysql> use db1
mysql> create table t1(id int)engine=innodb;
mysql> create table t2(id int)engine=myisam;
mysql> create table t3(id int)engine=memory;
mysql> create table t4(id int)engine=blackhole;
mysql> show tables;                          #查看db1库下的所有的表名
mysql> desc t1;  
                            #查看t1表的表结构
#memory存储引擎,在重启mysql或者重启机器后,表内数据清空
#blackhole存储引擎,往表内插入任何数据,都相当于丢入黑洞,表内永远不存记录

mysql> create table db1.f2 select user,host from mysql.user;          #复制表
mysql> create table db1.f3 select user,host from mysql.user where 1=2;    #只复制表结构(查询的结果不存在,没有值)
mysql> create table db1.f4 like mysql.user;                      #只复制表结构

(2)日期类型

create table student(
    id int,
    name char(16),
    born_year year,
    birth_date date,
    class_time time,
    reg_time datetime
);

insert into student values(1,'wang',now(),now(),now(),now());                     #插入当前时间
insert into student values(2,'wang','1999','1999-11-11','11:11:11',"1990-11-11 11:11:11");  #插入指定时间

(3)字符类型

#char类型:定长,简单粗暴,浪费空间,存取速度快

字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)

#varchar类型:变长,精准,节省空间,存取速度慢

字符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8)

#常用字符串系列:char与varchar

注:虽然varchar使用起来较为灵活,但是char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡

#宽度代表的是字符的个数

create table t6(name char(5));

create table t7(name varchar(5));

(4)修改表ALTER TABLE

语法:

#1.修改表名

ALTER TABLE 表名 RENAME 新表名;

#2.增加字段

ALTER TABLE 表名

ADD 字段名 数据类型[完整性约束条件…],

ADD 字段名 数据类型[完整性约束条件…];

ALTER TABLE 表名

ADD 字段名 数据类型[完整性约束条件…]  FIRST;

ALTER TABLE 表名

ADD 字段名 数据类型[完整性约束条件…]  AFTER 字段名;

#3.删除字段

ALTER TABLE 表名

DROP 字段名;

#4.修改字段

ALTER TABLE 表名

MODIFY 字段名 数据类型[完整性约束条件…];

ALTER TABLE 表名

CHANGE 旧字段名 新字段名 旧数据类型[完整性约束条件…];

ALTER TABLE 表名

CHANGE 旧字段名 新字段名 新数据类型[完整性约束条件…];

#5.删除表

DROP TABLE 表名;

示例:

#1.修改存储引擎

mysql > alter table service engine = innodb;

#2.添加字段

mysql > alter table student10
        -> add name varchar(20) not null,
        -> add age int(3) not null default 22;
        
mysql > alter table student10 add stu_num varchar(10) not null after name;          // 添加name字段之后
mysql > alter table student10 add sex enum('male', 'female') default 'male' first;     // 添加到最前面

#3.删除字段

mysql > alter table student10 drop sex;

mysql > alter table service drop mac;

#4.修改字段类型modify

mysql > alter table student10 modify age int(3);

mysql > alter table student10 modify id int(11) not null primary key auto_increment;    // 修改为主键

#5.增加约束(针对已有的主键增加auto_increment)

mysql > alter table student10 modify id int(11) not null auto_increment;

#6.对已经存在的表增加复合主键

mysql > alter table service2 add primary key(host_ip, port);

#7.增加主键

mysql > alter table student1 modify name varchar(10) not null primary key;

#8.增加主键和自动增长

mysql > alter table student1 modify id int not null primary key auto_increment;

#9.删除主键

a.删除自增约束

mysql > alter table student10 modify id int(11) not null;

b.删除主键

mysql > alter table student10 drop primary key;

(5)枚举类型与集合类型

字段的值只能在给定范围中选择,如单选框,多选框

enum 单选 只能在给定的范围内选一个值

set 多选 在给定的范围内可以选择一个或一个以上的值

create table employee(
    id int,
    name char(10),
    sex enum('male','female','other'),
    hobbies set('play','eat','music','read')
);
insert into employee values(1,'li','male','music,read');
insert into employee values(2,'wang','xxxx','music,read');

原文地址:http://blog.51cto.com/qidian510/2072077

时间: 2024-10-11 16:25:44

mysql的库和表相关操作的相关文章

mysql数据库的库和表相关命令

数据库的创建.删除 一.数据库相关的命令 数据库的创建 create  {database|schema}  db_name  [character set=]  [collate = ];创建数据库.如果数据库以存在会报错 create {database|schema} [if not exists] db_name  [character set=]  [collate = ];表示如果这个数据库不存在则创建 其中[character set = ]  用来设置默认字符集 [collate

MySQL之表相关操作

一 存储引擎介绍 存储引擎即表类型,mysql根据不同的表类型会有不同的处理机制 详见:http://www.cnblogs.com/linhaifeng/articles/7213670.html 二 表介绍 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段 id,name,qq,age称为字段,其余的,一行内容称为一条记录 三 创建表 #语法: create table 表名( 字段名1 类型[(宽度) 约束条件], 字段名2 类型[(宽

Mysql之表相关操作2

表的相关操作2 参考:http://www.cnblogs.com/linhaifeng/articles/7232894.html#_label6 一.修改表 语法: 1. 修改表名 ALTER TABLE 表名 RENAME 新表名; 2. 增加字段 ALTER TABLE 表名 ADD 字段名 数据类型 [完整性约束条件-], ADD 字段名 数据类型 [完整性约束条件-]; ALTER TABLE 表名 ADD 字段名 数据类型 [完整性约束条件-] FIRST; ALTER TABLE

python学习第三十九天:mysql表相关操作

表的完整性约束 约束条件与数据类型的宽度一样,都是可选参数 作用:用于保证数据的完整性和一致性 主要分为: not null  标识该字段不能为空 default   为该字段设置默认值 unsigned  无符号 zerofill   使用0填充 auto_increment  标识该字段的自动增长(整数类型,而且为主键) primary key   标识该字段为该表的主键,可以唯一的标识记录 foreign key   标识该字段为该表的外键 unique key    标识该字段的值是唯一

mysql 之库, 表的简易操作

一. 库的操作 1.创建数据库 创建数据库: create database 库名 charset utf8;   charset uft8  可选项 1.2 数据库命名规范: 可以由字母.数字.下划线.@.#.$ 区分大小写 唯一性 不能使用关键字如 create select 不能单独使用数字 最长128位 2.数据库基本操作: 1 查看数据库 show databases; show create database db1; select database(); 2 选择数据库 USE 数

mysql对库,表,数据类型的操作以及完整性约束

一丶对库的操作 求救语法: help create database; 1.创建数据库 CREATE DATABASE 数据库名 charset utf8; 2.数据库的命名规则: 可以由字母.数字.下划线.@.#.$ 区分大小写 唯一性 不能使用关键字如 create select 不能单独使用数字 最长128位 # 基本上跟python或者js的命名规则一样 3.数据库的相关操作: #查看数据库 show databases; #查看当前库 show create database db1;

第三篇:表相关操作

一 存储引擎介绍 存储引擎即表类型,mysql根据不同的表类型会有不同的处理机制 详见:http://www.cnblogs.com/linhaifeng/articles/7213670.html 二 表介绍 表相当于文件,表中的一条记录就相当于文件的一行内容,不同的是,表中的一条记录有对应的标题,称为表的字段 id,name,qq,age称为字段,其余的,一行内容称为一条记录 三 创建表 #语法: create table 表名( 字段名1 类型[(宽度) 约束条件], 字段名2 类型[(宽

MySQL DDL-对库和表的操作

#DDL /* 数据定义语言 库和表的管理 一.库的管理 创建.修改.删除 二.表的管理 创建.修改.删除 创建:create 修改: alter 删除:drop */ 一.库的管理 #1.库的创建 /* 语法: create database 库名称; */ #案例:创建库Books create database if not exists Books; #2.库名称的修改 由于rename存在安全隐患,推荐直接在文件夹中更改 进入:C:\ProgramData\MySQL\MySQL Se

ORM表相关操作

一般操作 看专业的官网文档,做专业的程序员! 必知必会13条 <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <3> get(**kwargs): 返回与所给筛选条件相匹配的对象,返回结果有且只有一个,如果符合筛选条件的对象超过一个或者没有都会抛出错误. <4> exclude(**kwargs): 它包含了与所给筛选条件不匹配的对象 <5> values(*field): 返回