数据库create用法,数据库create database
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” 的数据库:
数据库表可以通过 CREATE TABLE 语句来添加。