Laravel 4之数据库操作

数据库配置

Laravel数据库配置在app/config/database.php中进行,其中

  1. 'fetch'=> PDO::FETCH_CLASS,

设置数据返回格式,默认以类放回,你以$book->name形式访问数据。如果设置成PDO::FETCH_ASSOC,则以数组形式返回$book['name']

  1. 'default'=>'mysql',

指定数据库连接,在下面的connections中配置你需要的数据库。你也可以创建你自己的多个数据库连接。

  1. 'connections'=> array(
  2. ......
  3. 'mysql'=> array(
  4. 'driver'=>'mysql',
  5. 'host'=>'localhost',
  6. 'database'=>'database',
  7. 'username'=>'root',
  8. 'password'=>'',
  9. 'charset'=>'utf8',
  10. 'collation'=>'utf8_unicode_ci',
  11. 'prefix'=>'',
  12. ),
  13. ......
  14. ),

Schema结构生成器

创建表

  1. Schema::create('users',function($table)
  2. {
  3. $table->increments('id');
  4. $table->string('username',32);
  5. });

创建了一张users表,包含俩个字段。关于其他类型的字段参考官方手册。

字段修饰

  1. $table->string('username');
  2. $table->unique('username');
  3. //链式
  4. $table->string('username')->unique();

其他修饰还包括

  1. $table->string('name')->nullable();
  2. $table->string('name')->default('John Doe');
  3. $table->integer('age')->unsigned();
  4. $table->integer('age')->index();
  5. $table->string('username')->primary();

为多个字段添加修饰

  1. $table->index(array('age','weight'));

更新表

重命名表

  1. Schema::rename('users','idiots');

Schema::table()更新表,添加字段

  1. Schema::table('example',function($table)
  2. {
  3. $table->string('name');
  4. $table->string('name')->after('email');
  5. });

删除字段

  1. $table->dropColumn('name');
  2. $table->dropColumn(array('name','age'));
  3. $table->dropColumn('name','age');

重命名字段

  1. $table->renameColumn('name','nickname');

删除修饰

  1. $table->dropPrimary(array('name','email'));
  2. $table->dropUnique('example_name_unique');
  3. $table->dropIndex('example_name_index');

删除表

  1. Schema::drop('example');
  2. Schema::dropIfExists('example');

指定数据库连接

  1. Schema::connection('mysql')->create('example',function($table)
  2. {
  3. $table->increments('id');
  4. });

检查存在性

  1. Schema::hasTable('author')
  2. Schema::hasColumn('example','id')

设置存储引擎

  1. $table->engine ='InnoDB';

Migrations

Migrations是一种数据库版本控制工具,其当前数据库保持最新或是返回到过去的某个版本。

创建Migrations

使用 Artisan 命令行的migrate:make命令创建一个Migrations

  1. $ php artisan migrate:make create_users
  2. CreatedMigration:2013_06_30_124846_create_users
  3. Generating optimized class loader
  4. Compiling common classes

会创建一个PHP文件在app/database/migrations/2013_06_30_124846_create_users.php,里面包含两个默认函数up()down().然后我们可以在里面创建表或是删除表

  1. publicfunction up()
  2. {
  3. Schema::create('users',function($table)
  4. {
  5. $table->increments('id');
  6. $table->string('name',128);
  7. $table->string('email');
  8. $table->string('password',60);
  9. $table->timestamps();
  10. });
  11. }
  12. publicfunction down()
  13. {
  14. Schema::drop('users');
  15. }

我们也可以让migrate为我们自动创建表样式

  1. $ php artisan migrate:make create_users --create --table=users

还可以使用--path=app/migs选项指定路径

运行Migrations

Laravel会自动安装Migrations,你也可以手动安装Migrations

  1. $ php artisan migrate:install

运行Migrations

  1. $ php artisan migrate
  2. Migration table created successfully.
  3. Migrated:2013_08_20_044917_create_users

运行时有可能出现[PDOException] SQLSTATE[HY000] [2002] No such file or director错误,那是因为你的mysql.sock设置不正确。还有就是命令行的PHP是系统默认的PHP而不是XAMPP中的PHP,因此你需要修改系统默认的php.ini文件,找到并修改pdo_mysql.default_socket

  1. pdo_mysql.default_socket=/Applications/XAMPP/xamppfiles/var/mysql/mysql.sock

运行某路径下的Migrations

  1. $ php artisan migrate --path=app/migs

运行某个包下的所有迁移

  1. $ php artisan migrate --package=vendor/package

回滚Migrations

回滚最后一次迁移

  1. $ php artisan migrate:rollback

回滚所有迁移

  1. $ php artisan migrate:reset

回滚所有迁移并重新运行所有迁移

  1. $ php artisan migrate:refresh
  2. $ php artisan migrate:refresh --seed

结束

[转]Laravel 4之数据库操作的更多相关文章

  1. [Laravel] Laravel的基本数据库操作部分

    [laravel] laravel的数据库配置 找到程序目录结构下.env文件 配置基本的数据库连接信息 DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=blog ...

  2. laravel中的数据库操作(增删改查)方法一

    导入命名空间和DBnamespace App\Http\Controllers; use Illuminate\Support\Facades\DB; public function index(){ ...

  3. laravel框架总结(七) -- 数据库操作

      1.使用DB门面进行基本操作 一旦你设置好了数据库连接,就可以使用 DB facade 来进行查找.DB facade 提供每个类型的查找方法:select.update.insert.delet ...

  4. laravel 数据库操作

    1 配置信息 1.1配置目录: config/database.php 1.2配置多个数据库 //默认的数据库 'mysql' => [ 'driver' => 'mysql', 'hos ...

  5. laravel基础课程---13、数据库基本操作2(lavarel数据库操作和tp对比)

    laravel基础课程---13.数据库基本操作2(lavarel数据库操作和tp对比) 一.总结 一句话总结: 非常非常接近:也是分为两大类,原生SQL 和 数据库链式操作 学习方法:使用时 多看手 ...

  6. laravel 连接同一服务器上多个数据库操作 、 连接多个不同服务器上的不同数据库操作以及多个数据库操作的事务处理

    !注意:标红的要注意区分开 第一步.配置.env文件(同一服务器上多个数据库) DB_CONNECTION=pgsqlDB_HOST=IP(例如:127.0.0.1)DB_PORT=端口号(例如:54 ...

  7. Laravel—数据库操作与Eloquent模型使用总结

    数据库操作 执行原生SQL //查询 $emp = DB::select('select * from employees where emp_no = 1'); $emp = DB::select( ...

  8. PHP数据库操作:使用ORM

    之前我发了一篇博文PHP数据库操作:从MySQL原生API到PDO,向大家展示PHP是如何使用MySQL原生API.MySQLi面向过程.MySQLi面向对象.PDO操作MySQL数据库的.本文介绍如 ...

  9. Laravel 5.2数据库--多个关联关系,带条件约束的渴求式加载的问题

    ### 今天在连表获取数据的时候,老是获取不到想要的,确实有点无力适从的感觉. 归根到底,还是对laravel不够熟悉,至少是数据库操作那块. ### 问题是这样的: 我想要通过连表中间表,拿中间表的 ...

随机推荐

  1. 使用PHPExcel导入导出excel格式文件

    使用PHPExcel导入导出excel格式文件  作者:zccst  因为导出使用较多,以下是导出实现过程.  第一步,将PHPExcel的源码拷贝到项目的lib下  文件包含:PHPExcel.ph ...

  2. oendir(),readdir(),closedir() 打开/读取/关闭目录

    目录操作 当目标是目录而不是文件的时候,ls -l的结果会显示目录下所有子条目的信息,怎么去遍历整个目录呢?答案马上揭晓! 1. 打开目录 功能:opendir()用来打开参数name指定的目录,并返 ...

  3. 高可用集群(HA)配置

    高可用集群(HA) 1. 准备工作 HA的心跳监测可以通过串口连接监测也可以通过网线监测,前者需要服务器有一个串口,后者需要有一个空闲网卡.HA架构中需要有一个共享的存储设备首先需要在两台机器上安装m ...

  4. SDK文件夹下内容介绍

    Platform-Tools: 这是 adb, fastboot 等工具包.把解压出来的 platform-tools 文件夹放在 android sdk 根目录下,并把 adb所在的目录添加到系统 ...

  5. NSString字符串类型-学习总结

    1.字符串的创建 (1)创建常量字符串 NSString *str = @"This is a String"; //str是变量名 (2)创建空的字符串,给字符串赋值 NSStr ...

  6. $.fn、$.fn.extend和$.extend的区别

    $.fn $.fn是指jquery的命名空间,加在fn上的方法及属性,会对jquery实例每一个有效. 如:扩展$.fn.abc(),即$.fn.abc()是对jquery扩展了一个abc方法,那么后 ...

  7. Reverse digits of an integer.

    class Solution { public: int reverse(int x) { ;//long 是怕中间过程溢出 <<,max=-min-){ ans=ans*+x%; x=x ...

  8. hdu5360 Hiking(水题)

    转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud Hiking Time Limit: 6000/3000 MS (Java/Oth ...

  9. php统计文件夹大小

    function dirsize($dir){ @$dh = opendir($dir); $size = 0; while($file = @readdir($dh)){ if($file!=&qu ...

  10. C++ 使用cl命令编辑时发生的问题收录

    1.cl不是内部或这外部命令,也不是可运行的程序或批处理文件. 这个问题的出现的原因是因为系统找不到cl命令处理程序,无法识别,解决办法: 首先在C盘查找cl.exe,可能会查到多个,先选择第一个,将 ...