数据库create用法,数据库create database

http://www.itjxue.com  2023-01-21 16:33  来源:未知  点击次数: 

mysql怎么用语句建表

mysql使用create语句进行创建数据库表,具体语法:

CREATE TABLE table_name (column_name column_type);

其中需要表名,表中字段名,字段属性;示例:创建一个学生信息表 sql如下

CREATE TABLE IF NOT EXISTS `student`(

`student_id` INT UNSIGNED AUTO_INCREMENT,

`student_name` VARCHAR(100) NOT NULL,

`student_age` int(3) NOT NULL,

PRIMARY KEY ( `student_id` ))ENGINE=InnoDB DEFAULT CHARSET=utf8;

ThinkPHP:create()方法有什么用呢?

1.create方法可以对POST提交的数据进行处理(通过表中的字段名称与表单提交的名称对应关系自动封装数据实例),例如user表中有一个字段名叫"username",如果表单中有一个input name="username" value="小明",那么$User = M('User'); $data = $User-create(); echo $data['username'];就会输出"小明",不用你用$_POST['username']去接收。

2.用create方法可以对表单进行令牌验证,防止表单重复提交。

3.可以对数据自动验证,前提是你必须手动在Model文件夹中建立一个UserModel.class.php文件,在其中加入验证规责

protected $_validate = array(

array('username','require','用户名必须', 1),

);

4.可以对字段自动赋值,前提还是必须手动在Model文件夹中建立一个UserModel.class.php文件,在其中加入

protected $_auto = array(

array('create_time','time',self::MODEL_INSERT,'function'),

);

那么user的注册时间将自动赋值为当前时间

附上create方法的源码:

/**

* 创建数据对象 但不保存到数据库

* @access public

* @param mixed $data 创建数据

* @param string $type 状态

* @return mixed

*/

public function create($data='',$type='') {

// 如果没有传值默认取POST数据

if(empty($data)) {

$data = $_POST;

}elseif(is_object($data)){

$data = get_object_vars($data);

}

// 验证数据

if(empty($data) || !is_array($data)) {

$this-error = L('_DATA_TYPE_INVALID_');

return false;

}

// 检查字段映射

$data = $this-parseFieldsMap($data,0);

// 状态

$type = $type?$type:(!empty($data[$this-getPk()])?self::MODEL_UPDATE:self::MODEL_INSERT);

// 检测提交字段的合法性

if(isset($this-options['field'])) { // $this-field('field1,field2...')-create()

$fields = $this-options['field'];

unset($this-options['field']);

}elseif($type == self::MODEL_INSERT isset($this-insertFields)) {

$fields = $this-insertFields;

}elseif($type == self::MODEL_UPDATE isset($this-updateFields)) {

$fields = $this-updateFields;

}

if(isset($fields)) {

if(is_string($fields)) {

$fields = explode(',',$fields);

}

// 判断令牌验证字段

if(C('TOKEN_ON')) $fields[] = C('TOKEN_NAME');

foreach ($data as $key=$val){

if(!in_array($key,$fields)) {

unset($data[$key]);

}

}

}

// 数据自动验证

if(!$this-autoValidation($data,$type)) return false;

// 表单令牌验证

if(C('TOKEN_ON') !$this-autoCheckToken($data)) {

$this-error = L('_TOKEN_ERROR_');

return false;

}

// 验证完成生成数据对象

if($this-autoCheckFields) { // 开启字段检测 则过滤非法字段数据

$fields = $this-getDbFields();

foreach ($data as $key=$val){

if(!in_array($key,$fields)) {

unset($data[$key]);

}elseif(MAGIC_QUOTES_GPC is_string($val)){

$data[$key] = stripslashes($val);

}

}

}

// 创建完成对数据进行自动处理

$this-autoOperation($data,$type);

// 赋值当前数据对象

$this-data = $data;

// 返回创建的数据以供其他调用

return $data;

}

add方法就简单了,

1.对create方法中创建的数据对象进行插入数据库。

例如:

$User = M('User');

$User-create(array('username'='小明')); //这里没有从表单接收数据

$User-add();

将会生成insert into think_uesr ('username')values('小明')

2.可以进行数据中回调处理,类似于java中Spring框架的AOP思想,前提还是必须手动在Model文件夹中建立一个UserModel.class.php文件,在其中加入

// 插入数据前的回调方法

protected function _before_insert($data,$options) {

}

// 插入成功后的回调方法

protected function _after_insert($data,$options) {

}

在插入之前做些什么在_before_insert中写自己的逻辑,在插入之后做些什么在_after_insert中写自己的逻辑。

如何用SQL语句创建数据库

在SQL语句中,CREATE DATABASE 语句用于创建数据库。

具体用法如下:

示例:

下面的 SQL 语句创建一个名为 “my_db” 的数据库:

-from 树懒学堂

数据库表可以通过 CREATE TABLE 语句来添加。

(责任编辑:IT教学网)

更多

推荐站内动态文章