mysql安装


  • 下载社区版本MySQL软件包(地址),或者windows installer
  • 接压缩安装包到目标路径
  • 在系统变量Path中加入目标路径
  • 在mysql安装路径下,修改配置文件mysql-default.ini:

    basedir = C:\mysql\mysql(mysql所在目录)

    datadir = C:\mysql\mysql\data(mysql所在目录\data)

  • 以管理员身份启动CMD,运行安装: mysqld -install
  • 启动mysql: net start mysql
  • 登陆mysql:mysql -u root -p
  • 更改密码:mysql> update mysql.user set password=PASSWORD('123') where User='root' ;
  • mysql> flush privileges

表操作


  • 创建 create table [模式名].tablename(column_name 数据类型 default 值,......);

  • 删除表: drop table table_name;
  • 重命名表名:alter table table_name rename to new_table_name;
  • 添加列: alter table tablename add ......;
  • 修改列: alter table tablename modify ......;
  • 删除列: alter table tablename drop column_name;
  • 重命名列名:alter table tablename change old_column_name new_column_name;
  • 删除表中的数据:truncate tabl_name;

约束


  • 非空约束:在列定义和修改是追加 not null,取消非空约束追加 null;
  • 唯一约束:UNIQUE
    • 列级约束语法:在列定义后加 unique 关键字;
    • 表级约束语法(为多列建立组合约束):在创建表或修改表(add)时加入:unique(列名) 指定约束名:constraint 约束名 unique(列名,列名,....);(几个列名对应值组合不一样)
    • 删除唯一约束:alter table table_name drop index 约束名;
  • 主键约束:primary key
    • 在定义列时,追加 primary key
    • 表级约束语法:constraint 约束名 primary key(列名),或者 primary key(列名);
    • 删除主键约束:alter table table_name drop primary key;
    • 增加主键约束:add primary key(列名); modify 列名 primary key;
    • 主键自增长:auto_increment primary key
  • 外键约束:references table_name(column_name)
    • 列级约束:追加 references table_name(column_name);
    • 表级约束:foreign key(column_name) references table_name(column_name);
    • 为外键约束指定名字:constraint 约束名 foreign key(column_name) references table_name(column_name);
    • 删除约束:drop foreign key 约束名;
    • 外键约束可以自参照;
    • 主表删除时动作:追加 on delete cascade 或 on delete set null;
    • 列的值可以为null;
  • CHECK约束:追加 check(表达式);(不过,不起作用)

索引


  • 创建:create index index_name on table(column_name);
  • 删除:drop index index_name on table(column_name) ;
  • mysql数据库要求不同表,索引可以相同,oracle则要求索引名全局唯一;

视图


  • 创建:create or replace view view_name as 查询语句;
  • with check option ,创建的视图不可修改;
  • oracle 数据库:with read only;
  • 删除:drop view view_name;

记录的插入,修改,删除


  • 插入:insert into table_name[ (column_name,.......)] values(value,......);或者可以用select查询子句来插入值;
  • update:update table_name set column_name=value where 条件表达式;
  • delete from : delete from table_name where条件表达式;

MySQL密码重置


  • net stop mysql
  • mysqld -nt --skip-grant-tables
  • 打开一个新命入令行窗口,执行mysql,此时不需密码即可连接
  •  use mysql;
    update user set password=password("新密码") where user="root";
    flush privileges;
    exit;
  • 进任务管理器关闭mysqld -nt进程
  • net start mysql

tips


  • 利用Explain命令分析sql执行效率

【9-2】mysql数据库学习01的更多相关文章

  1. MySQL数据库学习: 01 —— 数据库的概述

    壹 概述 一 了解SQL 1.1 数据库基础 1.1.1 什么是数据库 数据库(database)保存有组织的数据的容器(通常是一个文件或一组文件). 易混淆:人们常常用“数据库”这个词语来代表他们使 ...

  2. MySQL数据库学习笔记(十二)----开源工具DbUtils的使用(数据库的增删改查)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  3. MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  4. MySQL数据库学习笔记(九)----JDBC的ResultSet接口(查询操作)、PreparedStatement接口重构增删改查(含SQL注入的解释)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  5. Mysql数据库学习笔记之数据库索引(index)

    什么是索引: SQL索引有两种,聚集索引和非聚集索引,索引主要目的是提高了SQL Server系统的性能,加快数据的查询速度与减少系统的响应时间. 聚集索引:该索引中键值的逻辑顺序决定了表中相应行的物 ...

  6. MYSQL数据库学习笔记1

      MYSQL数据库学习笔记1 数据库概念 关系数据库 常见数据库软件 SQL SQL的概念 SQL语言分类 数据库操作 创建数据库 查看数据库的定义 删除数据库 修改数据库 创建表 数据类型 约束 ...

  7. MySQL数据库学习笔记<一>

    MySQL基本概念以及简单操作   一.MySQL   MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于Oracle 旗下产品.MySQL 是最流行的关系型数据库管理系 ...

  8. MySQL数据库学习初步

    我使用的环境是Win7,开始学习PHP和MySQL,并且买了本<Head First PHP & MySQL>,可以从Head First Labs官网获得HeadFirst系列书 ...

  9. mysql数据库学习目录

    前面的话 对于前端工程师来说,数据库并不是主要技能点,但是基本的增删改查操作还是需要了解的.小火柴将mysql数据库的学习记录整理如下 目录  前端学数据库之基础操作 前端学数据库之数据类型 前端学数 ...

随机推荐

  1. angularjs 自带的过滤器

    一,内置的过滤器 1,uppercase,lowercase大小转换 {{ "lower cap string" | uppercase }}     //结果:LOWER CAP ...

  2. OPENGGL深度测试

    深度测试是为了解决那些在绘图过程中本应该被隐藏的面结果却出现了,例如: 绘图代码中先绘制了一个一个近处的立方体,后绘制了一个远处的立方体,结果在绘制过程中,远处的立方体总是在近处的立方体后绘制,所以在 ...

  3. 【BZOJ-1692&1640】队列变换 后缀数组 + 贪心

    1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1153  Solved: 482[Submit][St ...

  4. 【bzoj2190】 SDOI2008—仪仗队

    http://www.lydsy.com/JudgeOnline/problem.php?id=2190 (题目链接) 题意 一个N*N的方阵,问右下角的人能看到几个人. Solution 如果一个人 ...

  5. 洛谷P1565 牛宫

    题目描述 AP 神牛准备给自己盖一座很华丽的宫殿.于是,他看中了一块N*M 的矩形空地. 空地中每个格子都有自己的海拔高度.AP 想让他的宫殿的平均海拔在海平面之上(假设 海平面的高度是0,平均数都会 ...

  6. TextView里限制输入字数的方法

    一开始采用的方法是函数textView:shouldChangeTextInRange:replacementText:来进行判断: //键入Done时,插入换行符,然后执行addBookmark - ...

  7. Alpha版本十天冲刺——Day 9

    站立式会议 会议总结 队员 今日完成 问题 明日要做 感想 对学长说的话的感受 鲍亮 无 获取图片未解决 获取图片,发帖接口,争取完成此版本预期功能 不知不觉只剩两天时间了,这两天接连遇到发图片,获取 ...

  8. LABjs(类似于LazyLoad,但它更加方便管理依赖关系)

    动态加载JS函数 一般性的,当我们需要加载js文件的时候都会使用script标签来实现,类似于如下代码: <script type="text/javascript" src ...

  9. eclipse配置gradle

    1.Grandle官网下载Gradle 2.解压文件,配置到环境变量 3.测试安装成功,$ gradle -v 4.打开eclipse,Help-->Install new software,输 ...

  10. wpf 保存控件中的内容为图片格式

    黄色的是wpf控件的名称! //保存到特定路径            FileStream fs = new FileStream(@"C:\image.png", FileMod ...