主要逻辑就是
先分析表结构
用 show columns 获得表结构信息,提取到主键,当然没有主键的特殊表有另外的逻辑!
获取各个字段的类型, 默认值 等信息 根据这些信息 表单自动化生成 前台录入表单甚至表单验证 以及生成提交后的逻辑处理部分,修改时 同 新添加差不多 不过是根据主键 update信息,删除 则简单点 根据主键 删除记录即可!
理论上 理想结构就是这样的,但是实际项目的复杂程度是不一样的,简单的CRUD可以说是个鸡肋!
有些CMS比如 phpcms 内部都有 “自定义模型” 其实这就是 CRUD 的一种形式
还有 流行框架都有 CRUD 生成逻辑,研究一下这些代码就可以了!
过程和思路也就如此
1在配置项中定义:
12345'SESSION_TYPE' => 'Redis', //session保存类型'SESSION_PREFIX' => 'sess_', //session前缀'REDIS_HOST' => '127001' //REDIS服务器地址'REDIS_PORT' => 6379, //REDIS连接端口号'SESSION_EXPIRE' => 3600, //SESSION过期时间
2在ThinkPHP\Library\Think\Session\Driver目录下新建Redisclassphp文件
文件内容如下:
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162<phpnamespace Think\Session\Driver;class Redis {// Redis连接对象 private $redis;// Session过期时间 private $expire; / 打开方法 @param type $path @param type $name @return type / public function open($path, $name) { $this->expire = C('SESSION_EXPIRE') C('SESSION_EXPIRE') : ini_get('sessiongc_maxLifetime'); $this->redis = new Redis(); return $this->redis->connect(C('REDIS_HOST'), C('REDIS_PORT')); } / 关闭 @return type / public function close() { return $this->redis->close(); } / 读取 @param string $id @return type / public function read($id) { $id = C('SESSION_PREFIX') $id; $data = $this->redis->get($id); return $data $data : ''; } / 写入 @param string $id @param type $data @return type / public function write($id, $data) { $id = C('SESSION_PREFIX') $id; return $this->redis->set($id, $data, $this->expire); } / 销毁 @param string $id / public function destroy($id) { $id = C('SESSION_PREFIX') $id; $this->redis->delete($id); } / 垃圾回收 @param type $maxLifeTime @return boolean / public function gc($maxLifeTime) { return true; }}
memcached的方法和Redis差不多一样!
因为你Users Model的对应的表明没改,在这个Users模型类里,有这样的方法:
public static function tableName()
{
return '{{%users1}}'; // users1是你的新表名
}
而且直接执行Sql查询,好像不是这样用的吧?
我一般都是这样的
Yii::$app->getDb()->createCommand($sql)->queryAll()
Yii::$app->getDb()->createCommand($sql)->queryOne()
Yii::$app->getDb()->createCommand($sql)->excute()
区别你可以看看源代码的说明。(Yii2上的用法,yii1x应该差不多,你稍微改改就应该没问题)
以上就是关于根据数据库信息生成基本的PHP *** 作数据表的函数,生成CRUD这四个代码全部的内容,包括:根据数据库信息生成基本的PHP *** 作数据表的函数,生成CRUD这四个代码、php yii框架 *** 作redis问题。可以获取到redis对象信息,但是set总是报错。、PHP中使用YII框架的问题等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)