mysql数据库 订阅
MySQL是一种开放源代码的关系型数据库管理系统(RDBMS),使用最常用的数据库管理语言--结构化查询语言(SQL)进行数据库管理。MySQL是开放源代码的,因此任何人都可以在General Public License的许可下下载并根据个性化的需要对其进行修改。MySQL因为其速度、可靠性和适应性而备受关注。大多数人都认为在不需要事务化处理的情况下,MySQL是管理内容最好的选择。 展开全文
MySQL是一种开放源代码的关系型数据库管理系统(RDBMS),使用最常用的数据库管理语言--结构化查询语言(SQL)进行数据库管理。MySQL是开放源代码的,因此任何人都可以在General Public License的许可下下载并根据个性化的需要对其进行修改。MySQL因为其速度、可靠性和适应性而备受关注。大多数人都认为在不需要事务化处理的情况下,MySQL是管理内容最好的选择。
信息
标    志
sakila
说    明
数据库管理系统
中文名
MySQL数据库
类    型
开放源代码的关系型
MySQL数据库数据库简介
[1]  MySQL这个名字,起源不是很明确。一个比较有影响的说法是,基本指南和大量的库和工具带有前缀“my”已经有10年以上,而且不管怎样,MySQL AB创始人之一的Monty Widenius的女儿也叫My。这两个到底是哪一个给出了MySQL这个名字至今依然是个迷,包括开发者在内也不知道。MySQL的海豚标志的名字叫“sakila”,它是由MySQL AB的创始人从用户在“海豚命名”的竞赛中建议的大量的名字表中选出的。获胜的名字是由来自非洲斯威士兰的开源软件开发者Ambrose Twebaze提供。根据Ambrose所说,Sakila来自一种叫SiSwati的斯威士兰方言,也是在Ambrose的家乡乌干达附近的坦桑尼亚的Arusha的一个小镇的名字。MySQL,虽然功能未必很强大,但因为它的开源、广泛传播,导致很多人都了解到这个数据库。它的历史也富有传奇性。
收起全文
精华内容
参与话题
问答
  • My SQL数据库

    千次阅读 2018-05-06 20:49:14
    1.sql 语句应该考虑哪些安全性?(1).防止 Sql 注入(怎么防止sql注入?)通过使用预编译语句(prepared statements)和参数化查询(parameterized queries).使用PDO对象,使用mysqli.过滤输入和转义输出(2)对特殊...
    1.sql 语句应该考虑哪些安全性?

    (1).防止 Sql 注入(怎么防止sql注入?)通过使用预编译语句(prepared statements)和参数化查询(parameterized queries).使用PDO对象,使用mysqli.过滤输入和转义输出

    (2)对特殊字符进行转义、过滤或者使用预编译的 sql 语句绑定变量。

    (3)最小权限原则,特别是不要用 root 账户,为不同的类型的动作或者组建使用不同的账户。
    (4)当 sql 运行出错时,不要把数据库返回的错误信息全部显示给用户,以防止泄露服务器和数据库相关信息。

    2. 简单描述 mysql 中,索引,主键,唯一索引,联合索引的区别,对数据库的性能有什么影响(从读写两方面)(新浪网技术部)

    索引是一种特殊的文件(InnoDB 数据表上的索引是表空间的一个组成部分),它们包含对数据表里所有记录的引用指针。

    普通索引(由关键字 KEY 或 INDEX 定义的索引)的唯一任务是加快对数据的访问速度。普通索引允许被索引的数据列包含重复的值。

    如果能确定某个数据列将只包含彼此各不相同的值,在为这个数据列创建索引的时候就应该用关键字 UNIQUE 把它定义为一个唯一索引。也就是说,唯一索引可以保证数据记录的唯一性

    主键,是一种特殊的唯一索引,在一张表中只能定义一个主键索引,主键用于唯一标识一条记录,使用关键字 PRIMARY KEY 来创建。
    索引可以覆盖多个数据列,如像 INDEX(columnA, columnB)索引,这就是联合索引
    索引可以极大的提高数据的查询速度,但是会降低插入、删除、更新表的速度,因为在执行这些写操作时,还要操作索引文件。

    3. 如何用命令把 mysql 里的数据备份出来(酷讯 PHP 工程师笔试题)

    (1). 导出一张表
    mysqldump -u 用户名 -p 密码 库名 表名 > 文件名(如 D:/a.sql)
    (2). 导出多张表
    mysqldump -u 用户名 -p 密码 库名 表名 1 表名 2 表名 3 > 文件名(如 D:/a.sql)
    (3). 导出所有表
    mysqldump -u 用户名 -p 密码 库名 > 文件名(如 D:/a.sql)
    (4). 导出一个库

    mysqldump -u 用户名 -p 密码 -B 库名 > 文件名(如 D:/a.sql)

    4.MySQL 数据库中的字段类型 varchar 和 char 的主要区别是什么?哪种字段的查找效率要高,为什么?
    char 表示定长,长度固定,varchar表示变长,即长度可变区别之二,存储的容量不同
    对 char 来说,最多能存放的字符个数 255,和编码无关。

    而 varchar 呢,最多能存放 65532 个字符。VARCHAR 的最大有效长度由最大行大小和使用的字符集

    UTF8 一个字符占三个字节, 最多能存 21844 个字符

    两相比较,char 的效率高,没有碎片,尤其更新比较频繁的时候,方便数据文件指针的操作。但不够灵活,在实际使用时,应根据实际需求来选用合适的数据类型。

    5. IP 该如何保存?

    最简单的办法是使用字符串(varchar)来保存,如果从效率考虑的话,可以将 ip 保存为整型(unsigned int),使用 php 或 mysql 提供的函数将 ip 转换为整型,然后存储即可。

    PHP 函数:long2ip()和 ip2long()

    MySQL 函数:inet_aton()和 inet_ntop

    6. MYSQL 取得当前时间的函数是?格式化日期的函数是?

    current_time()用于取得当前时间
    date_format(datetime, format)用于格式化日期,如:select date_format(now(),'%Y%m%d');

    7. 请简述项目中优化 sql 语句执行效率的方法,从哪些方面,sql 语句性能如何分析?
    1. 尽量选择较小的列
    2. 将where中用的比较频繁的字段建立索引
    3. select子句中避免使用‘*’
    4. 避免在索引列上使用计算、not in 和<>等操作
    5. 当只需要一行数据的时候使用limit 1
    6. 保证单表数据不超过200W,适时分割表。
    8. 数据库中的事务是什么?

    事务(transaction)是作为一个单元的一组有序的数据库操作。如果组中的所有操作都成功,则认为事务成功,即使只有一个操作失败,事务也不成功。如果所有操作完成,事务则提交,其修改将作用于所有其他数据库进程。如果一个操作失败,则事务将回滚,该事务所有操作的影响都将取消。

    ACID 四大特性,原子性、隔离性、一致性、持久性。

    9. What's the difference between mysql_fetch_row() and mysql_fetch_array()? (Yahoo)

    mysql_fetch_row() 从和指定的结果标识关联的结果集中取得一行数据并作为数组返回。每个结果的列储存在一个数组的单元中,偏移量从 0 开始。
    mysql_fetch_array() 是 mysql_fetch_row() 的扩展版本。除了将数据以数字索引方式储存在数组中之外,还可以将数据作为关联索引储存,用字段名作为键名。
    mysql_fetch_array() 中可选的第二个参数 result_type 是一个常量,可以接受以下值:
    MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH。其默认值是 MYSQL_BOTH。
    如 果 用 了 MYSQL_BOTH , 将 得 到 一 个 同 时 包 含 关 联 和 数 字 索 引 的 数 组 。 用MYSQL_ASSOC 只得到关联索引(如同 mysql_fetch_assoc() 那样),用 MYSQL_NUM 只得到数字索引(如同 mysql_fetch_row() 那样)。

    10. 请写出 php 连 mysql 连接中,获取下一个自增长 id 值的方法,可以写多个(酷讯)

    方法一,使用 show table status ,然后获取 auto_increment 的值
    方法二,使用 select max(id) + 1 from table
    方法三,如果是刚插入记录,可以使用 last_insert_id() + 1 获得

    11. php 访问数据库有哪几步?

    主要有以下几个步骤:

    1. 连接数据库服务器:mysqli_connect('host','user','password');
    2. 选择数据库:mysql_select_db(数据库名);
    3. 设置从数据库提取数据的字符集:mysql_query("set names utf8");
    4. 执行 sql 语句:mysql_query(sql 语句);
    5. 处理结果集
    6. 关闭与数据库服务器的连接:mysql_close($link);
    12.请简述数据库设计的范式及应用。
    第一范式:若关系模式 R 的每一个属性是不可再分解的,且有主键,则属于第一范式。
    第二范式:若 R 属于第一范式,且所有的非主键属性都完全函数依赖于主键属性,则满足第二范式。
    第三范式:若 R 属于第二范式,且所有的非主键属性没有一个是传递函数依赖于候选主键属性,则满足第三范式。

    13. php 连接 mysql 之后,如何设置 mysql 的字符集编码为 utf8?

    mysql_query(“set names utf8”);

    14. 解释 MySQL 外连接、内连接与自连接的区别 (小米)

    先说什么是交叉连接,交叉连接又叫笛卡尔积,它是指不使用任何条件,直接将一个表的所有记录和另一个表中的所有记录一一匹配。
    内连接则是只有条件的交叉连接,根据某个条件筛选出符合条件的记录,不符合条件的记录不会出现在结果集中,即内连接只连接匹配的行。
    外连接其结果集中不仅包含符合连接条件的行,而且还会包括左表、右表或两个表中的所有数据行,这三种情况依次称之为左外连接,右外连接,和全外连接。

    左外连接,也称左连接,左表为主表,左表中的所有记录都会出现在结果集中,对于那
    些在右表中并没有匹配的记录,仍然要显示,右边对应的那些字段值以 NULL 来填充。
    右外连接,也称右连接,右表为主表,右表中的所有记录都会出现在结果集中。
    左连接和右连接可以互换,MySQL 目前还不支持全外连接。

    
    

    15.简述在mysql数据库中myISAM和InnoDB的区别

    (1)构成上:MyISAM的表在磁盘中有三个文件组成,分别是表定义文件,数据文件,索引文件,而InnoDB的表由表定义文件,表空间数据和日志文件组成。

    (2)安全方面,MyISAM强调的是性能,其查询效率较高,但是不支持事务和外键等安全方面的性能,而InnoDB支持事务和外键都能高级功能,查询效率较低

    (3)对锁的支持,MyISAM支持表锁,InnoDB支持行锁

    [!!]16. 简述存储过程的适用情况

    当需要处理复杂的查询和运算时,可以使用存储过程。
    从应用分层的原则,大量使用存储过程导致业务逻辑分散在 DB 和应用服务器层,不利于维护和更新。
    总体来说,存储程序可以用,但要慎重,最好只用来维护,不用于业务逻辑和支撑高并发高性能的东西。

    17.存储例程是存储在数据库中的预编译对象。包括存储过程(procedure)和用户自定义函数(UDF)。能永久存储一组sql语句。

    区别:1函数作用域有限。不可以从函数修改数据库表。2函数与其他任何表达式一样可用于sql语句中,但是存储过程必须使用call语句调用。

    18.视图:视图是虚拟表,本身没有数据,对视图查询比较缓慢(1)作用:来限制用户对关键数据的访问,确保数据的安全性。(2)可以存储复杂查询,有助于简化复杂查询的执行。

    19.视图限制:(1)不能在临时表创建视图(2)不能创建临时视图(3)不能在视图创建触发器,索引(4)视图的底层表或视图必须存在(5)视图定义的select语句不能在from子句中包含子查询

    20.可更新视图:在视图上执行插入更新删除操作可以修改到底层表

      以下视图不可更新(1)列列表中存在聚合函数(2)select 语句中存在distinct ,group by,having子句

    (3)select语句存在子查询(4)from子句存在不可更新视图

    21.触发器:是预编译并存储在数据库中的小程序。

    作用:维护数据库的完整性并提高其性能。使用数据库保证表间数据的一致性并执行特定操作有关的操作。

    22.PDO:是用于与不同类型数据库通信的轻量级接口。它提供一组公共方法以访问不同数据库。而且它将数据库与应用程序分离,因此又称数据库访问抽象层。

    特性:  一致编码,灵活性,相当好的性能,支持面向对象的特性

    23.SQL优化:优化注意事项(1)应在搜索条件中常用的列上建立索引

    (2)不应在仅包含一些惟一值的列上创建索引

    (3)尽量在可能时使用连接代替子查询。处理连接比子查询效率高

    (4)需要在查询中比较的列应为相同数据类型

    (5)仅在需要时在like运算符中使用通配符

    (6)正确使用长度定义列

    (7)尽量对列使用not null约束

    (8)尽量对字符串使用enum数据类型

    优化措施(1)优化表:要重新获取未使用的空间以及降低表的片段化程度 可以使用optimize table

    (2)优化索引:MySQL服务器使用不同算法在内部处理索引,例如B树索引,哈希索引,创建索引时,可以在一些存储引擎中显示指定索引类型。

    (3)优化查询:分析查询,选择最佳最有效的执行方法。可使用查询执行计划 explain+select

    (4)优化DML语句:load data infile语句使用文本文件将数据插入表,bulk_insert_buffer_size增加缓存内存大小的系统变量

    使用low_priority关键字优化update语句

    为优化删除性能,可以增加key_buffer_size变量的值

    展开全文
  • My SQL数据库概念

    2018-07-13 20:08:38
    My SQL数据库概念 MySQL是一个精巧的SQL数据库管理系统,而且是开源的数据管理系统,是一个真正的多用户、多线程SQL数据库服务器。MySQL 主要目标是快速、健壮和易用。MySQL数据库的最常用标准化语言为SQL结构化...

    My SQL数据库概念

    MySQL是一个精巧的SQL数据库管理系统,而且是开源的数据管理系统,是一个真正的多用户、多线程SQL数据库服务器。MySQL 主要目标是快速、健壮和易用。MySQL数据库的最常用标准化语言为SQL结构化查询语言。

    数据库能做什么

    • 存储大量数据,方便查询和操作

    • 保持数据信息的一致、完整

    • 共享和安全

    • 通过组合分析,产生新的有用信息

     

    数据库和应用程序

    应用程序

    • 作用:响应操作并显示结果、向数据库请求数据

    • 要求:美观、操作简单方便

    数据库

    • 作用:存储数据、检索数据、生成新的数据

    • 要求:统一、安全、性能等

    数据库的好处:

    1. 持久化数据到本地

    2. 可以实现结构化查询,方便管理

     

    DB:

        数据库(database):存储数据的“仓库”。它保存了一系列有组织的数据的容器。

    DBMS

        数据库管理系统(Database Management System),又称为数据库软件(产品)。数据库是通过DBMS创建和操作的容器,用于管理DB中的数据。

    SQL

        结构化查询语言(Structure Query Language):专门用来与数据库DBMS通信的语言。

    SQL的优点:

    1. 不是某个特定数据库供应商专有的语言几乎所有的DBMS都支持SQL

    2. 简单易学

    3. 一种强有力的语言,灵活使用其语言元素,可以进行非常复杂和高级的数据库操作。

     

    数据库特点

    1. 将数据放到表中,表再放到库中。

    2. 一个数据库中可以有多个表,每个表都有一个对应的名字,用来标识自己。表名具有唯一性。

    3. 表具有一些特性,这些特性定义了数据在表中如何存储,类似java中“类”的设计。

    4. 表由列组成,也称为字段。所有表都是由一个或多个列组成的,每一列类似java中的“属性”。

    5. 表中的数据是按行存储的,每一行类似于java中的“对象”。

     

    MySQL的优点

    • 成本低:开放源代码

    • 性能高:执行很快

    • 简单:很容易安装和使用

    为什么选择My SQL数据库

    目前,绝大多数使用Linux操作系统的互联网企业都在使用MySQL作为后端的数据库,从大型的BAT门户,到电商门户平台、分类门户平台等都是。

    1、性能卓越,服务稳定,很少出现异常宕机

    2、开发源代码且无版权制约,自主性强,使用成本低

    3、历史悠久,社区及用户非常活跃,遇到问题,可以很快获取到帮助

    4、软件体积小,安装使用简单,并且易于维护,安装及维护成本低

    5、支持多种操作系统,提供多种API接口,支持多种开发语言,特别对流行的PHP语言无缝支持

    6、品牌口碑效应,使得企业无需考虑就直接用之

    展开全文
  • My sql数据库基本操作

    2020-09-15 10:07:25
    My sql数据库的基本使用方法 1、Cmd ——输入 mysql -u root -p 密码123456这条命令进入my sql 用户界面 2、为啥设置环境变量:方便找到my sql,不配置的话需要找到my sql的路径再输入命令,使之在任何目录下都能...

    一、基本知识点
    JDBC:Java数据库连接,(Java Database Connectivity,简称JDBC)是Java语言中用来规范客户端程序如何来访问数据库的应用程序接口,提供了诸如查询和更新数据库中数据的方法。
    软件设计原则:向下兼容,高内聚低耦合
    分布式数据库系统:DDS (Distributed Database System)
    Char和varchar:char 表示定长,长度固定,varchar表示变长
    Char如果存入数据的实际长度比指定长度要小 会补空格至指定长度 如果存入的数据的实际长度大于指定长度 低版本会被截取 高版本会报错;
    Varchar类型如果存入的数据的实际长度比指定的长度小 会缩短到实际长度 如果存入 数据的实际长度大于指定长度 低版本会被截取 高版本会报错;区别之二,存储的容量不同
    Mysql支持运算符和位移<<
    索引:index
    主键:Primary key
    原数据:meta data查看数据库一些信息例如版本等
    二、进入环境
    1、 安装MySQL,配置环境变量
    为何设置环境变量?方便找到my sql,不配置的话需要找到my sql的路径再输入命令,使之在任何目录下都能调用my sql.
    2、在“开始”输入Cmd(打开提示命令符)

    2、输入MySQL-u root -p和密码进入MySQL用户界面。

    三、MySQL基本操作
    1、对数据库的操作
    启动数据库Net star mysql80;
    断开数据库连接 Net stop mysql80;
    mysql> show variables like ‘version’;查询显示数据库版本
    mysql> show databases;显示数据库
    mysql> create database mydb;创建数据库
    mysql> drop database if exists mydb2;删除数据库

    mysql> use mydb;使用目标数据库
    Exit退出数据库;
    2、对表的操作
    mysql> create table users (userID varchar(10),userName varchar(10));创建表
    mysql> create temporary table user6
    -> select * from user4;创建Temporary临时表,当前数据库连接断开,再进入则无效
    mysql> drop table if exists users2;删除表
    mysql> show tables;显示表
    mysql> alter table users
    -> add userAge varchar(10);增加一列表的属性,增加制定位置是使用after,没有before;
    Mysql>alter table users
    -> drop userAge;删除表的属性
    mysql> alter table users
    -> rename users2;改变表的名字
    mysql>desc users2;查看表的字段
    3、对数据的操作
    mysql> insert into users values (‘001’,‘jxnu’);增
    mysql> select * from users where userName like ‘%pk%’;选
    mysql> update users set userName=‘pk’ where userID=“003”;改
    mysql> delete from users where usersID=‘003’;删

    展开全文
  • My SQL数据库学习思维导图

    My SQL数据库学习思维导图

    在这里插入图片描述

    展开全文
  • MY SQL 介绍 MYSQL是一个关系型数据库管理系统,由瑞典my sqlAB公司开发,目前属于甲骨文公司(Oracle)旗下产品。...由于其体积小,速度快,总体拥有成本低,特别是开放源码这一特点,my sql数据库成为一
  • 实现Visual Stutio 2015 软件中VB.NET语言设计的界面与My SQL数据库连接,支持数据库表内已有的用户登录。
  • SQL SERVER 转换为MY SQL 数据库.pdf 将SQL SERVER 转换为MY SQL 数据库.pdf
  • 安装my sql数据库安装详细教程安装my sql数据库安装详细教程一、安装二、环境变量配置三、验证安装 安装my sql数据库安装详细教程 一、安装 1、双击打开上面我们下载好的安装包,进行如下所示操作: 2.这里我们需要...
  • My SQL数据库基本操作

    千次阅读 2019-04-14 19:34:33
    My SQL数据库 数据库(Database)简称DB,是按照数据结构来组织、存储和管理数据的仓库,其本身可看作电子化的文件柜。用户可以对文件中的数据进行增加、删除、修改、查找等操作。 数据库的优点: 低成本、跨平台、...
  • MySQL Administrator是一个专门用于管理 My SQL 4.X 和 5.X My SQL数据库的软件,可以使用这个软件备份My SQL数据库,还原My SQL数据库。 例如:申请成功后,你将获得以下参数: 数据库IP:**.**.**.*** 数据库...
  • Eclipse连接到My sql数据库之前操作 Eclipse连接到My sql数据库之前操作 1:首先是安装My sql数据库(为了减少你的麻烦,按照下面的连接,下载即可)百度云链接:http://pan.baidu.com/s/1mitWmbm ...
  • 自主开发数据库修复工具,Oracle 数据库修复,IBM DB2 数据库修复,MY SQL 数据库修复,SQL Server 数据 库修复,Sybase 数据库,Foxpro 数据库,Access 数据库,Informix 数据库,SAS 数据库 ,Dbase 数据库,NCR ...
  • MySQL Administrator 是一个专门用于管理 My SQL 4.X 和 5.X My SQL数据库的软件,可以使用这个软件备份My SQL数据库,还原My SQL数据库。   例如:申请成功后,你将获得以下参数: 数据库IP:**.**.**.**...
  • My SQL 数据库服务器常用操作命令

    千次阅读 2014-10-16 11:54:29
    window 下链接MY SQL数据库服务器 cmd: mysql -h
  • 创建My SQL 数据库

    2019-05-26 19:57:40
    创建数据库CREATE DATABASE '数据库名' ;CREATE TABLE '数据表名';...以此MY SQL软件为例 在于 PHP study进行连接后 进入主页面 单击查询按钮 单击新建查询 **在查询编辑器中编写 **** CREATE DATABASE ‘数...
  • My SQL数据库整理

    2020-07-27 22:28:08
    1. 创建数据库 CREATE DATABASE 数据库名; CREATE DATABASE student; 2. 指定要操作的数据库 USE 数据库名; USE student; 3.创建数据库表 CREATE TABLE 数据表名  (  字段名1 数据类型[完整性约束条件]...
  • MySQL Administrator 是一个专门用于管理 My SQL 4.X 和 5.X My SQL数据库的软件,可以使用这个软件备份My SQL数据库,还原My SQL数据库。   例如:申请成功后,你将获得以下参数: 数据库IP:**.**.**.*** ...
  • 之前开发中一直用的是sql server 数据库,最近接到公司一个老的项目,用的my sql数据库做的,功能做了一大部分,现在客户要求对原程序和数据库进行服务器的迁移工作。产品经理给出预估时间大概需要2天时间,全新...
  • My SQL数据库(享精品公开课)》笔记
  • 1. 下载my sql数据库https://dev.mysql.com/downloads/mysql/5.5.htmlhttp://dev.mysql.com/get/Downloads/MySQL-5.5/mysql-5.5.49-linux2.6-x86_64.tar.gz 2. 本地上传、解压并移动MySQL二进制软件包到指定的...
  • 本文详细记录了MySQL数据库的安装过程,为初学者了解MySQL数据库的安装、配置数据库提供方便。
  • Eclipse连接到My sql数据库的操作总结/配置数据库驱动 Eclipse连接到MYSQL数据库的操作 (自己亲测,开始学习Eclipse(我的Eclipse版本是4.5.2,Jdbc驱动器的jar包版本是5.1.7,亲测可以使用)连接到...
  • My sql数据库索引

    2019-07-09 09:24:52
    数据库索引(提高查询速度,添加索引主要用于查询) Unique key 索引名(字段名,也可以逗号隔开添加多个唯一索引) 全文索引 不支持Innodb,只支持myISAM 数据表类型 添加正确的索引 管理索引 索引执行性能 ....

空空如也

1 2 3 4 5 ... 20
收藏数 6,581
精华内容 2,632
关键字:

mysql数据库

mysql 订阅